mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 19:43:32 +00:00
39bf41f4eb
- Python static hello world now 1.8mb - Python static fully loaded now 10mb - Python HTTPS client now uses MbedTLS - Python REPL now completes import stmts - Increase stack size for Python for now - Begin synthesizing posixpath and ntpath - Restore Python \N{UNICODE NAME} support - Restore Python NFKD symbol normalization - Add optimized code path for Intel SHA-NI - Get more Python unit tests passing faster - Get Python help() pagination working on NT - Python hashlib now supports MbedTLS PBKDF2 - Make memcpy/memmove/memcmp/bcmp/etc. faster - Add Mersenne Twister and Vigna to LIBC_RAND - Provide privileged __printf() for error code - Fix zipos opendir() so that it reports ENOTDIR - Add basic chmod() implementation for Windows NT - Add Cosmo's best functions to Python cosmo module - Pin function trace indent depth to that of caller - Show memory diagram on invalid access in MODE=dbg - Differentiate stack overflow on crash in MODE=dbg - Add stb_truetype and tools for analyzing font files - Upgrade to UNICODE 13 and reduce its binary footprint - COMPILE.COM now logs resource usage of build commands - Start implementing basic poll() support on bare metal - Set getauxval(AT_EXECFN) to GetModuleFileName() on NT - Add descriptions to strerror() in non-TINY build modes - Add COUNTBRANCH() macro to help with micro-optimizations - Make error / backtrace / asan / memory code more unbreakable - Add fast perfect C implementation of μ-Law and a-Law audio codecs - Make strtol() functions consistent with other libc implementations - Improve Linenoise implementation (see also github.com/jart/bestline) - COMPILE.COM now suppresses stdout/stderr of successful build commands
62 lines
1.6 KiB
C
62 lines
1.6 KiB
C
#ifndef COSMOPOLITAN_LIBC_SYMBOLS_H_
|
|
#define COSMOPOLITAN_LIBC_SYMBOLS_H_
|
|
#include "libc/assert.h"
|
|
#include "libc/elf/elf.h"
|
|
#include "libc/runtime/ezmap.internal.h"
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
COSMOPOLITAN_C_START_
|
|
|
|
struct Symbol {
|
|
unsigned x; /* start (relative to addr_base) */
|
|
unsigned y; /* start + size - 1 (inclusive) */
|
|
};
|
|
|
|
struct SymbolTable {
|
|
size_t count; /* of `symbols` */
|
|
size_t mapsize; /* of this object */
|
|
intptr_t addr_base; /* IMAGE_BASE_VIRTUAL */
|
|
intptr_t addr_end; /* _end - 1 */
|
|
unsigned *names; /* relative to `name_base` */
|
|
char *name_base; /* double-nul terminated w/ empty first */
|
|
struct Symbol symbols[]; /* sorted and non-overlapping intervals */
|
|
};
|
|
|
|
struct SymbolTable *GetSymbolTable(void);
|
|
const char *FindComBinary(void);
|
|
const char *FindDebugBinary(void);
|
|
struct SymbolTable *OpenSymbolTable(const char *) nodiscard;
|
|
int CloseSymbolTable(struct SymbolTable **);
|
|
void __hook(void *, struct SymbolTable *);
|
|
|
|
forceinline int GetSymbol(struct SymbolTable *t, intptr_t a) {
|
|
unsigned l, m, r, n, k;
|
|
if (t) {
|
|
l = 0;
|
|
r = n = t->count;
|
|
k = a - t->addr_base;
|
|
while (l < r) {
|
|
m = (l + r) >> 1;
|
|
if (t->symbols[m].y < k) {
|
|
l = m + 1;
|
|
} else {
|
|
r = m;
|
|
}
|
|
}
|
|
if (l < n && t->symbols[l].x <= k && k <= t->symbols[l].y) {
|
|
return l;
|
|
}
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
forceinline char *GetSymbolName(struct SymbolTable *t, int s) {
|
|
if (t && s != -1) {
|
|
return t->name_base + t->names[s];
|
|
} else {
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
COSMOPOLITAN_C_END_
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
#endif /* COSMOPOLITAN_LIBC_SYMBOLS_H_ */
|