From ff22b1948a1f2ee7f62d915c543d46a379e2082e Mon Sep 17 00:00:00 2001 From: midipix Date: Sun, 11 Dec 2016 19:44:51 -0500 Subject: api headers: added visual studio and hosted environment support. --- include/pemagine/bits/nt32/pe_inline_asm__common.h | 89 ++++++++++++++++++++++ include/pemagine/bits/nt32/pe_inline_asm__gcc.h | 89 ---------------------- include/pemagine/bits/nt64/pe_inline_asm__common.h | 87 +++++++++++++++++++++ include/pemagine/bits/nt64/pe_inline_asm__gcc.h | 87 --------------------- 4 files changed, 176 insertions(+), 176 deletions(-) create mode 100644 include/pemagine/bits/nt32/pe_inline_asm__common.h delete mode 100644 include/pemagine/bits/nt32/pe_inline_asm__gcc.h create mode 100644 include/pemagine/bits/nt64/pe_inline_asm__common.h delete mode 100644 include/pemagine/bits/nt64/pe_inline_asm__gcc.h (limited to 'include/pemagine/bits') diff --git a/include/pemagine/bits/nt32/pe_inline_asm__common.h b/include/pemagine/bits/nt32/pe_inline_asm__common.h new file mode 100644 index 0000000..10473b4 --- /dev/null +++ b/include/pemagine/bits/nt32/pe_inline_asm__common.h @@ -0,0 +1,89 @@ +static __inline__ void * pe_get_teb_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x18, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x18, %0\n\t" + "mov %%ds:0x30(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_address_alt(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x30, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_ldr_data_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x18, %0\n\t" + "mov %%ds:0x30(%0), %0\n\t" + "mov %%ds:0x0C(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_ldr_data_address_alt(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x30, %0\n\t" + "mov %%ds:0x0C(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + +static __inline__ uint32_t pe_get_current_process_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x20, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + +static __inline__ uint32_t pe_get_current_thread_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x24, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + +static __inline__ uint32_t pe_get_current_session_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%fs:0x18, %0\n\t" + "mov %%ds:0x30(%0), %0\n\t" + "mov %%ds:0x1d4(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} diff --git a/include/pemagine/bits/nt32/pe_inline_asm__gcc.h b/include/pemagine/bits/nt32/pe_inline_asm__gcc.h deleted file mode 100644 index 10473b4..0000000 --- a/include/pemagine/bits/nt32/pe_inline_asm__gcc.h +++ /dev/null @@ -1,89 +0,0 @@ -static __inline__ void * pe_get_teb_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x18, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x18, %0\n\t" - "mov %%ds:0x30(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_address_alt(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x30, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_ldr_data_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x18, %0\n\t" - "mov %%ds:0x30(%0), %0\n\t" - "mov %%ds:0x0C(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_ldr_data_address_alt(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x30, %0\n\t" - "mov %%ds:0x0C(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - -static __inline__ uint32_t pe_get_current_process_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x20, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - -static __inline__ uint32_t pe_get_current_thread_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x24, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - -static __inline__ uint32_t pe_get_current_session_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%fs:0x18, %0\n\t" - "mov %%ds:0x30(%0), %0\n\t" - "mov %%ds:0x1d4(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} diff --git a/include/pemagine/bits/nt64/pe_inline_asm__common.h b/include/pemagine/bits/nt64/pe_inline_asm__common.h new file mode 100644 index 0000000..94d4e34 --- /dev/null +++ b/include/pemagine/bits/nt64/pe_inline_asm__common.h @@ -0,0 +1,87 @@ +static __inline__ void * pe_get_teb_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x30, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x60, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_address_alt(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x60, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_ldr_data_address(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x60, %0\n\t" + "mov %%ds:0x18(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ void * pe_get_peb_ldr_data_address_alt(void) +{ + void * ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x60, %0\n\t" + "mov %%ds:0x18(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + + +static __inline__ uint32_t pe_get_current_process_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x40, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + +static __inline__ uint32_t pe_get_current_thread_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x48, %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} + +static __inline__ uint32_t pe_get_current_session_id(void) +{ + uint32_t ptrRet; + __asm__ __volatile__ ( + "mov %%gs:0x60, %0\n\t" + "mov %%ds:0x2c0(%0), %0\n\t" + : "=r" (ptrRet) : : + ); + return ptrRet; +} diff --git a/include/pemagine/bits/nt64/pe_inline_asm__gcc.h b/include/pemagine/bits/nt64/pe_inline_asm__gcc.h deleted file mode 100644 index 94d4e34..0000000 --- a/include/pemagine/bits/nt64/pe_inline_asm__gcc.h +++ /dev/null @@ -1,87 +0,0 @@ -static __inline__ void * pe_get_teb_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x30, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x60, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_address_alt(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x60, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_ldr_data_address(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x60, %0\n\t" - "mov %%ds:0x18(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ void * pe_get_peb_ldr_data_address_alt(void) -{ - void * ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x60, %0\n\t" - "mov %%ds:0x18(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - - -static __inline__ uint32_t pe_get_current_process_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x40, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - -static __inline__ uint32_t pe_get_current_thread_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x48, %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} - -static __inline__ uint32_t pe_get_current_session_id(void) -{ - uint32_t ptrRet; - __asm__ __volatile__ ( - "mov %%gs:0x60, %0\n\t" - "mov %%ds:0x2c0(%0), %0\n\t" - : "=r" (ptrRet) : : - ); - return ptrRet; -} -- cgit v1.2.3