Le 18/09/2010 00:42, Wolfgang Denk a écrit : > Dear Albert ARIBAUD, > > In message<4c93e978.9010...@free.fr> you wrote: >> >>> u-boot.map for this board shows: >>> >>> ... >>> arch/powerpc/lib/cache.o(.text) >>> .text 0x40007c20 0x64 arch/powerpc/lib/cache.o >>> 0x40007c20 flush_cache >>> 0x00008000 . = DEFINED >>> (env_offset)?env_offset:. >>> *fill* 0x40007c84 0x37c 00 >>> common/env_embedded.o(.ppcenv) >>> .ppcenv 0x40008000 0x8000 common/env_embedded.o >>> 0x40008000 environment >>> 0x4000c000 redundand_environment >>> *(.text) >>> .text 0x40010000 0x4 common/env_embedded.o >>> 0x40010000 env_size >>> .text 0x40010004 0x0 lib/libgeneric.a(ctype.o) >>> ... >>> >>> So we are "wasting" 0x37c = 892 bytes of memory for an unused gap. >>> The last changes where the object placing had to be changed due to >>> code size etc. were commit 32482be6 (Feb 19, 2009), and before that >>> fe57bb19 (Sep 18, 2002). Having to tweak this file every 7 years or >>> so is something I'm considering to be acceptable. YMMV... >> >> This is a simple alignment. I do not need to align code, I need to map >> *one* symbol, namely _start, at a given location, here 0xffff0000, so >> that the 64 KB sector which contains start is not wasted and the image >> resides in as few sectors as possible. > > And I map *one* symbol, namely environment, at a given location, here > 0x40008000. > > It seems you are not willing or trying or able to understand. I give > up here.
I *am* willing to understand, and *able* I think too; I believe I never expressed any doubt on your own will or ability to understand, and I would appreciate if you kept your doubts about me to yourself. I still fail to see a mapping of _start at a given here, at least I fail to see a manual action to get there. Are we both talking about the boards/tqc/tqm8xx/u-boot.lds linker file? If so, then it places _start right at the beginning of the .text section (line 58 of the linker file) -- just like all linker files I saw so far -- and does the alignment trick on the location pointer later, at line 67, which aligns the location of env_embedded, not of _start. Maybe the intent was to move env_embedded out of the sector where start.o et al. are put; but then, that is not what I am look for. I do not want to isolate _start within a given sector; I want to make sure it gets flashed at a given location, where it cannot end up if it was mapped at the beginning of the iagem, because the image is bigger than the space from the reset vector location to the end of the addressable space. > Viele Grüße, > > Wolfgang Denk Amicalement, -- Albert. _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de http://lists.denx.de/mailman/listinfo/u-boot