# # Copyright (C) 2012 Marek Vasut <marex@denx.de> # # See file CREDITS for list of people who contributed to this # project. # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as # published by the Free Software Foundation; either version 2 of # the License, or (at your option) any later version. # ######################################################################### ## # make_u_boot_list - Generate contents of u_boot_list section # 1: The name of the resulting file (usually u-boot.lst) # 2: Files to analyze for possible u_boot_list entries # # This function generates the contents of the u_boot_list section, # including all the border symbols for it's subsections. The operation # of this function is as follows, numbering goes per lines: # # 1) Dump the ELF header sections from all files supplied via $(2) # 2) Filter out all other stuff that does not belong into .u_boot_list # section. # 3) Fix up the lines so that the resulting output is is in format # ".u_boot_list.*". # 4) Remove the last .something$, since that only contains the name # of the variable to be put into a subsection. This name is irelevant # for generation of border symbols, thus of no interest, remove it. # 5) Take each line and for every dot "." in that line, print the whole # line until that dot "." . This is important so that we have all # parent border symbols generated as well. # 6) Load every line and firstly append "\a" at the end and print the # line. Next, append "@" at the end and print the line. Finally, # append "~" at the end of line. This will make sense in conjunction # with 6) and 7). # 7) Sort the lines. It is imperative to use LC_COLLATE=C here because # with this, the "\a" symbol is first and "~" symbol is last. Any # other symbols fall inbetween. Symbols like "@", which marks the # end of current line (representing current section) and ".", which # means the line continues and thus represents subsection. # 8) With such ordering, all lines ending with "\a" will float at the # begining of all lines with the same prefix. Thus it is easy to # replace "\a" with __start and make it the __start border symbol. # Very similarly for "~", which will be always at the bottom and so # can be replaced by "__end" and made into the __end border symbol. # Finally, every line ending with "@" symbol will be transformed # into " *(SORT(${line}*)); " format, which in the linker parlance # will allow it to trap all symbols relevant to the subsection. # define make_u_boot_list $(1): $(2) $(OBJDUMP) -h $(2) | \ sed -n -e '/.*\.u_boot_list[^ ]\+/ ! {d;n}' \ -e 's/.*\(\.u_boot_list[^ ]\+\).*$$$$/\1/' \ -e 's/\.[^\.]\+$$$$//' \ -e ':s /^.\+$$$$/ { p;s/^\(.*\)\.[^\.]*$$$$/\1/;b s }' | \ sed -n -e 'h;s/$$$$/\a/p;g;s/$$$$/@/p;g;s/$$$$/~/p;' | \ LC_COLLATE=C sort -u | \ sed -n -e '/\a$$$$/ { s/\./_/g;s/\a$$$$/__start = .;/p; }'\ -e '/~$$$$/ { s/\./_/g;s/~$$$$/__end = .;/p; }'\ -e '/@$$$$/ { s/\(.*\)@$$$$/*(SORT(\1.*));/p }' > $(1) endef