mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-21 04:14:34 +00:00

When bringing in the series 'arm: dts: am62-beagleplay: Fix Beagleplay Ethernet"' I failed to notice that b4 noticed it was based on next and so took that as the base commit and merged that part of next to master. This reverts commitc8ffd1356d
, reversing changes made to2ee6f3a5f7
. Reported-by: Jonas Karlman <jonas@kwiboo.se> Signed-off-by: Tom Rini <trini@konsulko.com>
43 lines
1,019 B
C
43 lines
1,019 B
C
/*
|
|
* Helper functions for working with the builtin symbol table
|
|
*
|
|
* Copyright (c) 2008-2009 Analog Devices Inc.
|
|
* Licensed under the GPL-2 or later.
|
|
*/
|
|
|
|
|
|
/* We need the weak marking as this symbol is provided specially */
|
|
extern const char system_map[] __attribute__((weak));
|
|
|
|
/* Given an address, return a pointer to the symbol name and store
|
|
* the base address in caddr. So if the symbol map had an entry:
|
|
* 03fb9b7c_spi_cs_deactivate
|
|
* Then the following call:
|
|
* unsigned long base;
|
|
* const char *sym = symbol_lookup(0x03fb9b80, &base);
|
|
* Would end up setting the variables like so:
|
|
* base = 0x03fb9b7c;
|
|
* sym = "_spi_cs_deactivate";
|
|
*/
|
|
const char *symbol_lookup(unsigned long addr, unsigned long *caddr)
|
|
{
|
|
const char *sym, *csym;
|
|
char *esym;
|
|
unsigned long sym_addr;
|
|
|
|
sym = system_map;
|
|
csym = NULL;
|
|
*caddr = 0;
|
|
|
|
while (*sym) {
|
|
sym_addr = hextoul(sym, &esym);
|
|
sym = esym;
|
|
if (sym_addr > addr)
|
|
break;
|
|
*caddr = sym_addr;
|
|
csym = sym;
|
|
sym += strlen(sym) + 1;
|
|
}
|
|
|
|
return csym;
|
|
}
|