f8c987f8f1
Often during debugging session it's very interesting to see what data we were dealing with. For example what we write or read to/from memory or peripherals. This change introduces functions that allow to dump binary data with one simple function invocation like: ------------------->8---------------- print_hex_dump_bytes("", DUMP_PREFIX_OFFSET, buf, len); ------------------->8---------------- which gives us the following: ------------------->8---------------- 00000000: f2 b7 c9 88 62 61 75 64 72 61 74 65 3d 31 31 35 ....baudrate=115 00000010: 32 30 30 00 62 6f 6f 74 61 72 67 73 3d 63 6f 6e 200.bootargs=con 00000020: 73 6f 6c 65 3d 74 74 79 53 33 2c 31 31 35 32 30 sole=ttyS3,11520 00000030: 30 6e 38 00 62 6f 6f 74 64 65 6c 61 79 3d 33 00 0n8.bootdelay=3. 00000040: 62 6f 6f 74 66 69 6c 65 3d 75 49 6d 61 67 65 00 bootfile=uImage. 00000050: 66 64 74 63 6f 6e 74 72 6f 6c 61 64 64 72 3d 39 fdtcontroladdr=9 00000060: 66 66 62 31 62 61 30 00 6c 6f 61 64 61 64 64 72 ffb1ba0.loadaddr 00000070: 3d 30 78 38 32 30 30 30 30 30 30 00 73 74 64 65 =0x82000000.stde 00000080: 72 72 3d 73 65 72 69 61 6c 30 40 65 30 30 32 32 rr=serial0@e0022 00000090: 30 30 30 00 73 74 64 69 6e 3d 73 65 72 69 61 6c 000.stdin=serial 000000a0: 30 40 65 30 30 32 32 30 30 30 00 73 74 64 6f 75 0@e0022000.stdou 000000b0: 74 3d 73 65 72 69 61 6c 30 40 65 30 30 32 32 30 t=serial0@e00220 000000c0: 30 30 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00.............. ... ------------------->8---------------- Source of hexdump.c was copied from Linux kernel v4.7-rc2. Signed-off-by: Alexey Brodkin <abrodkin@synopsys.com> Cc: Anatolij Gustschin <agust@denx.de> Cc: Mario Six <mario.six@gdsys.cc> Cc: Simon Glass <sjg@chromium.org> Cc: Tom Rini <trini@konsulko.com> Cc: Stefan Roese <sr@denx.de>
72 lines
1.9 KiB
Makefile
72 lines
1.9 KiB
Makefile
# SPDX-License-Identifier: GPL-2.0+
|
|
#
|
|
# (C) Copyright 2007 Semihalf
|
|
|
|
# Provide symbol API_BUILD to signal that the API example is being built.
|
|
KBUILD_CPPFLAGS += -DAPI_BUILD
|
|
|
|
ifeq ($(ARCH),powerpc)
|
|
LOAD_ADDR = 0x40000
|
|
endif
|
|
ifeq ($(ARCH),arm)
|
|
LOAD_ADDR = 0x1000000
|
|
endif
|
|
ifeq ($(ARCH),mips)
|
|
ifdef CONFIG_64BIT
|
|
LOAD_ADDR = 0xffffffff80200000
|
|
else
|
|
LOAD_ADDR = 0x80200000
|
|
endif
|
|
endif
|
|
|
|
# Resulting ELF and binary exectuables will be named demo and demo.bin
|
|
extra-y = demo
|
|
|
|
# Source files located in the examples/api directory
|
|
OBJ-y += crt0.o
|
|
OBJ-y += demo.o
|
|
OBJ-y += glue.o
|
|
OBJ-y += libgenwrap.o
|
|
|
|
# Source files which exist outside the examples/api directory
|
|
EXT_COBJ-y += lib/crc32.o
|
|
EXT_COBJ-y += lib/ctype.o
|
|
EXT_COBJ-y += lib/div64.o
|
|
EXT_COBJ-y += lib/hexdump.o
|
|
EXT_COBJ-y += lib/string.o
|
|
EXT_COBJ-y += lib/time.o
|
|
EXT_COBJ-y += lib/vsprintf.o
|
|
EXT_COBJ-y += lib/charset.o
|
|
EXT_COBJ-$(CONFIG_LIB_UUID) += lib/uuid.o
|
|
EXT_SOBJ-$(CONFIG_PPC) += arch/powerpc/lib/ppcstring.o
|
|
ifeq ($(ARCH),arm)
|
|
EXT_SOBJ-$(CONFIG_USE_ARCH_MEMSET) += arch/arm/lib/memset.o
|
|
endif
|
|
|
|
# Create a list of object files to be compiled
|
|
OBJS := $(OBJ-y) $(notdir $(EXT_COBJ-y) $(EXT_SOBJ-y))
|
|
targets += $(OBJS)
|
|
OBJS := $(addprefix $(obj)/,$(OBJS))
|
|
|
|
#########################################################################
|
|
|
|
quiet_cmd_link_demo = LD $@
|
|
cmd_link_demo = $(LD) --gc-sections -Ttext $(LOAD_ADDR) -o $@ $(filter-out $(PHONY), $^) $(PLATFORM_LIBS)
|
|
|
|
$(obj)/demo: $(OBJS) FORCE
|
|
$(call if_changed,link_demo)
|
|
|
|
# demo.bin is never genrated. Is this necessary?
|
|
OBJCOPYFLAGS_demo.bin := -O binary
|
|
$(obj)/demo.bin: $(obj)/demo FORCE
|
|
$(call if_changed,objcopy)
|
|
|
|
# Rule to build generic library C files
|
|
$(addprefix $(obj)/,$(notdir $(EXT_COBJ-y))): $(obj)/%.o: lib/%.c FORCE
|
|
$(call cmd,force_checksrc)
|
|
$(call if_changed_rule,cc_o_c)
|
|
|
|
# Rule to build architecture-specific library assembly files
|
|
$(addprefix $(obj)/,$(notdir $(EXT_SOBJ-y))): $(obj)/%.o: arch/$(ARCH)/lib/%.S FORCE
|
|
$(call if_changed_dep,as_o_S)
|