Hi, On 13 May 2018 at 16:45, Eugeniu Rosca <roscaeuge...@gmail.com> wrote: > Hi Simon, > > On Mon, May 14, 2018 at 08:00:40AM +1000, Simon Glass wrote: >> Hi, >> >> On 13 May 2018 at 03:13, Eugeniu Rosca <roscaeuge...@gmail.com> wrote: >> > From: Rob Herring <r...@kernel.org> >> > >> > This adds the following commits from upstream: >> > >> > aadd0b65c987 checks: centralize printing of property names in failure >> > messages >> > 88960e398907 checks: centralize printing of node path in check_msg >> > f1879e1a50eb Add limited read-only support for older (V2 and V3) device >> > tree to libfdt. >> > 37dea76e9700 srcpos: drop special handling of tab >> > 65893da4aee0 libfdt: overlay: Add missing license >> > 962a45ca034d Avoid installing pylibfdt when dependencies are missing >> > cd6ea1b2bea6 Makefile: Split INSTALL out into >> > INSTALL_{PROGRAM,LIB,DATA,SCRIPT} >> > 51b3a16338df Makefile.tests: Add LIBDL make(1) variable for portability >> > sake >> > 333d533a8f4d Attempt to auto-detect stat(1) being used if not given proper >> > invocation >> > e54388015af1 dtc: Bump version to v1.4.6 >> > a1fe86f380cb fdtoverlay: Switch from using alloca to malloc >> > c8d5472de3ff tests: Improve compatibility with other platforms >> > c81d389a10cc checks: add chosen node checks >> > e671852042a7 checks: add aliases node checks >> > d0c44ebe3f42 checks: check for #{size,address}-cells without child nodes >> > 18a3d84bb802 checks: add string list check for *-names properties >> > 8fe94fd6f19f checks: add string list check >> > 6c5730819604 checks: add a string check for 'label' property >> > a384191eba09 checks: fix sound-dai phandle with arg property check >> > b260c4f610c0 Fix ambiguous grammar for devicetree rule >> > fe667e382bac tests: Add some basic tests for the pci_bridge checks >> > 7975f6422260 Fix widespread incorrect use of strneq(), replace with new >> > strprefixeq() >> > fca296445eab Add strstarts() helper function >> > cc392f089007 tests: Check non-matching cases for >> > fdt_node_check_compatible() >> > bba26a5291c8 livetree: avoid assertion of orphan phandles with overlays >> > c8f8194d76cc implement strnlen for systems that need it >> > c8b38f65fdec libfdt: Remove leading underscores from identifiers >> > 3b62fdaebfe5 Remove leading underscores from identifiers >> > 2d45d1c5c65e Replace FDT_VERSION() with stringify() >> > 2e6fe5a107b5 Fix some errors in comments >> > b0ae9e4b0ceb tests: Correct warning in sw_tree1.c >> > >> > Commit c8b38f65fdec upstream ("libfdt: Remove leading underscores from >> > identifiers") changed the multiple inclusion define protection, so the >> > kernel's libfdt_env.h needs the corresponding update. >> > >> > Signed-off-by: Rob Herring <r...@kernel.org> >> > [ Linux commit: 9130ba884640328bb78aaa4840e5ddf06ccafb1c ] >> > [erosca: - Fixup conflicts in include/linux/libfdt_env.h caused by >> > v2018.03-rc4 >> > commit b08c8c487083 ("libfdt: move headers to <linux/libfdt.h> >> > and <linux/libfdt_env.h>") >> > - Fix build errors in lib/libfdt/fdt_ro.c, tools/libfdt/fdt_rw.c >> > by: >> > - s/_fdt_mem_rsv/fdt_mem_rsv_/ >> > - s/_fdt_offset_ptr/fdt_offset_ptr_/ >> > - s/_fdt_check_node_offset/fdt_check_node_offset_/ >> > - s/_fdt_check_prop_offset/fdt_check_prop_offset_/ >> > - s/_fdt_find_add_string/fdt_find_add_string_/] >> > Signed-off-by: Eugeniu Rosca <ero...@de.adit-jv.com> >> > --- >> > >> > v1-v2: >> > * Newly pushed >> > >> > include/linux/libfdt_env.h | 6 +- >> > lib/libfdt/fdt_ro.c | 18 +- >> > scripts/dtc/checks.c | 439 ++++++++++++++++++--------- >> > scripts/dtc/dtc-parser.y | 17 +- >> > scripts/dtc/dtc.c | 7 +- >> > scripts/dtc/dtc.h | 11 +- >> > scripts/dtc/flattree.c | 2 +- >> > scripts/dtc/libfdt/fdt.c | 13 +- >> > scripts/dtc/libfdt/fdt.h | 6 +- >> > scripts/dtc/libfdt/fdt_overlay.c | 51 ++++ >> > scripts/dtc/libfdt/fdt_ro.c | 132 ++++++-- >> > scripts/dtc/libfdt/fdt_rw.c | 90 +++--- >> > scripts/dtc/libfdt/fdt_sw.c | 24 +- >> > scripts/dtc/libfdt/fdt_wip.c | 10 +- >> > scripts/dtc/libfdt/libfdt.h | 37 +-- >> > scripts/dtc/libfdt/libfdt_env.h | 33 +- >> > scripts/dtc/libfdt/libfdt_internal.h | 32 +- >> > scripts/dtc/livetree.c | 10 +- >> > scripts/dtc/srcpos.c | 5 - >> > scripts/dtc/srcpos.h | 6 +- >> > scripts/dtc/util.h | 9 +- >> > scripts/dtc/version_gen.h | 2 +- >> > tools/libfdt/fdt_rw.c | 2 +- >> > 23 files changed, 632 insertions(+), 330 deletions(-) >> >> Can you please check that this does not adversely impact code size? > > Sure. Here are the sizes before and after this patch (sandbox): > > 1. ELF size comparison shows 96 bytes increase > $ du -b u-boot.before u-boot.after > 8055864 u-boot.before > 8055960 u-boot.after > > 2. BIN size comparison shows no change > $ du -b u-boot.bin.before u-boot.bin.after > 3377256 u-boot.bin.before > 3377256 u-boot.bin.after > > 3. "size" tool gives more details about ELF file size increase: > $ size u-boot.before u-boot.after > text data bss dec hex filename > 1199720 76952 291760 1568432 17eeb0 u-boot.before > 1199736 76952 291760 1568448 17eec0 u-boot.after
Thanks for the info. That seems OK, but please check sandbox_spl (or better yet one of the Thumb2 SPL images that uses libfdt) since it is SPL that matters most. > > 4. "bloaty" (diff mode) gives even more details (confirming the above) > $ bloaty -d compileunits u-boot.after -- u-boot.before > VM SIZE FILE SIZE > -------------- -------------- > +2.5% +30 lib/libfdt/fdt.c +96 +1.5% > [ = ] 0 lib/libfdt/fdt_sw.c +21 +0.1% > +2.6% +16 [LOAD [RX]] +16 +2.6% > [ = ] 0 lib/libfdt/fdt_overlay.c +16 +0.1% > [ = ] 0 [section .debug_str] +2 +0.0% > [ = ] 0 fs/ext4/ext4_common.c -5 -0.0% > [ = ] 0 common/fdt_support.c -11 -0.0% > -3.3% -14 [section .text] -14 -3.3% > [ = ] 0 [Unmapped] -25 -0.7% > +0.0% +32 TOTAL +96 +0.0% BTW buildman has a -B flag that shows function size. Regards, Simon _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot