5 #include "../i/private.h"
18 sdb_set(db,
"qnx.code_index",
sdb_fmt(
"0x%x", lmfh->code_index), 0);
19 sdb_set(db,
"qnx.stack_index",
sdb_fmt(
"0x%x", lmfh->stack_index), 0);
20 sdb_set(db,
"qnx.heap_index",
sdb_fmt(
"0x%x", lmfh->heap_index), 0);
21 sdb_set(db,
"qnx.argv_index",
sdb_fmt(
"0x%x", lmfh->argv_index), 0);
22 sdb_set(db,
"qnx.code_offset",
sdb_fmt(
"0x%x", lmfh->code_offset), 0);
23 sdb_set(db,
"qnx.stack_nbytes",
sdb_fmt(
"0x%x", lmfh->stack_nbytes), 0);
24 sdb_set(db,
"qnx.heap_nbytes",
sdb_fmt(
"0x%x", lmfh->heap_nbytes), 0);
25 sdb_set(db,
"qnx.image_base",
sdb_fmt(
"0x%x", lmfh->image_base), 0);
72 offset += lrec.data_nbytes;
78 offset +=
sizeof(lmf_record);
92 ptr->
vsize = lrec.data_nbytes -
sizeof(lmf_resource);
116 ptr->
vaddr = ldata.offset;
117 ptr->
vsize = lrec.data_nbytes -
sizeof(lmf_data);
151 offset += lrec.data_nbytes;
202 rbin->
cb_printf(
"version : 0x%xH\n",
bin->lmfh.version);
206 rbin->
cb_printf(
"code_index : 0x%xH\n",
bin->lmfh.code_index);
207 rbin->
cb_printf(
"stack_index : 0x%xH\n",
bin->lmfh.stack_index);
208 rbin->
cb_printf(
"heap_index : 0x%xH\n",
bin->lmfh.heap_index);
209 rbin->
cb_printf(
"argv_index : 0x%xH\n",
bin->lmfh.argv_index);
211 rbin->
cb_printf(
"code_offset : 0x%xH\n",
bin->lmfh.code_offset);
212 rbin->
cb_printf(
"stack_nbytes : 0x%xH\n",
bin->lmfh.stack_nbytes);
213 rbin->
cb_printf(
"heap_nbytes : 0x%xH\n",
bin->lmfh.heap_nbytes);
214 rbin->
cb_printf(
"image_base : 0x%xH\n",
bin->lmfh.image_base);
249 return qo ? qo->kv :
NULL;
259 return qo ? qo->lmfh.image_base : 0;
277 ptr->
paddr = qo->lmfh.code_offset;
278 ptr->
vaddr = qo->lmfh.code_offset +
baddr(bf);
295 pj_n(pj, qo->rwend.signature);
312 .desc =
"QNX executable file support",
318 .author =
"deepakchethan",
331 #ifndef RZ_PLUGIN_INCORE
RZ_API void rz_bin_map_free(RzBinMap *map)
RZ_API void rz_bin_section_free(RzBinSection *bs)
static Sdb * get_sdb(RzBinFile *bf)
static char * signature(RzBinFile *bf, bool json)
static bool check_buffer(RzBuffer *buf)
static bool load_buffer(RzBinFile *bf, RzBinObject *obj, RzBuffer *buf, Sdb *sdb)
static RzList * symbols(RzBinFile *bf)
static void header(RzBinFile *bf)
static void destroy(RzBinFile *bf)
RzBinPlugin rz_bin_plugin_qnx
RZ_API RzLibStruct rizin_plugin
static RzBinInfo * info(RzBinFile *bf)
static ut64 baddr(RzBinFile *bf)
static int lmf_header_load(lmf_header *lmfh, RzBuffer *buf, Sdb *db)
static RzList * entries(RzBinFile *bf)
static RzList * maps(RzBinFile *bf)
static RzList * sections(RzBinFile *bf)
static ut64 get_vaddr(RzBinFile *bf, ut64 baddr, ut64 paddr, ut64 vaddr)
static RzList * relocs(RzBinFile *bf)
size_t map(int syms, int left, int len)
RZ_API char * sdb_fmt(const char *fmt,...)
RZ_API void Ht_() free(HtName_(Ht) *ht)
RZ_API RZ_OWN RzList * rz_list_newf(RzListFree f)
Returns a new initialized RzList pointer and sets the free method.
RZ_API RZ_OWN RzList * rz_list_clone(RZ_NONNULL const RzList *list)
Shallow copies of the list (but doesn't free its elements)
RZ_API RZ_OWN RzList * rz_list_new(void)
Returns a new initialized RzList pointer (free method is not initialized)
RZ_API RZ_BORROW RzListIter * rz_list_append(RZ_NONNULL RzList *list, void *data)
Appends at the end of the list a new element.
RZ_API void rz_list_free(RZ_NONNULL RzList *list)
Empties the list and frees the list pointer.
return strdup("=SP r13\n" "=LR r14\n" "=PC r15\n" "=A0 r0\n" "=A1 r1\n" "=A2 r2\n" "=A3 r3\n" "=ZF zf\n" "=SF nf\n" "=OF vf\n" "=CF cf\n" "=SN or0\n" "gpr lr .32 56 0\n" "gpr pc .32 60 0\n" "gpr cpsr .32 64 0 ____tfiae_________________qvczn\n" "gpr or0 .32 68 0\n" "gpr tf .1 64.5 0 thumb\n" "gpr ef .1 64.9 0 endian\n" "gpr jf .1 64.24 0 java\n" "gpr qf .1 64.27 0 sticky_overflow\n" "gpr vf .1 64.28 0 overflow\n" "gpr cf .1 64.29 0 carry\n" "gpr zf .1 64.30 0 zero\n" "gpr nf .1 64.31 0 negative\n" "gpr itc .4 64.10 0 if_then_count\n" "gpr gef .4 64.16 0 great_or_equal\n" "gpr r0 .32 0 0\n" "gpr r1 .32 4 0\n" "gpr r2 .32 8 0\n" "gpr r3 .32 12 0\n" "gpr r4 .32 16 0\n" "gpr r5 .32 20 0\n" "gpr r6 .32 24 0\n" "gpr r7 .32 28 0\n" "gpr r8 .32 32 0\n" "gpr r9 .32 36 0\n" "gpr r10 .32 40 0\n" "gpr r11 .32 44 0\n" "gpr r12 .32 48 0\n" "gpr r13 .32 52 0\n" "gpr r14 .32 56 0\n" "gpr r15 .32 60 0\n" "gpr r16 .32 64 0\n" "gpr r17 .32 68 0\n")
RZ_API int sdb_ns_set(Sdb *s, const char *name, Sdb *r)
#define rz_return_if_fail(expr)
#define rz_return_val_if_fail(expr, val)
RZ_API st64 rz_buf_read_at(RZ_NONNULL RzBuffer *b, ut64 addr, RZ_NONNULL RZ_OUT ut8 *buf, ut64 len)
Read len bytes of the buffer at the specified address.
RZ_API st64 rz_buf_fread_at(RZ_NONNULL RzBuffer *b, ut64 addr, RZ_NONNULL ut8 *buf, RZ_NONNULL const char *fmt, int n)
...
RZ_API ut64 rz_buf_size(RZ_NONNULL RzBuffer *b)
Return the size of the buffer.
void(* RzListFree)(void *ptr)
RZ_API char * pj_drain(PJ *j)
RZ_API PJ * pj_n(PJ *j, ut64 n)
RZ_API char * rz_str_dup(char *ptr, const char *string)
RZ_API int sdb_set(Sdb *s, const char *key, const char *val, ut32 cas)
RZ_API Sdb * sdb_new0(void)
RZ_API char * sdb_itoa(ut64 n, char *s, int base)
XX curplugin == o->plugin.
Description of a single memory mapping into virtual memory from a binary.
ut64 paddr
the paddr where the value should be patched into
ut64 vaddr
the vaddr where the value should be patched into
ut64(WINAPI *w32_GetEnabledXStateFeatures)()