65 lines
3.0 KiB
Makefile
65 lines
3.0 KiB
Makefile
|
#
|
||
|
# 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
|