summaryrefslogtreecommitdiffhomepage
path: root/include/pemagine/bits
diff options
context:
space:
mode:
authormidipix <writeonce@midipix.org>2015-05-08 23:22:07 -0400
committermidipix <writeonce@midipix.org>2015-05-08 23:22:07 -0400
commitfeffc7263bb2fd33ae467de2dd51f1ddbbb1b895 (patch)
tree983daec02a2d1833796ad8bd04d43d9b3ec42765 /include/pemagine/bits
parent23329916dde5e0ffa056f74a81aeda1bfb7e54cc (diff)
downloadpemagine-feffc7263bb2fd33ae467de2dd51f1ddbbb1b895.tar.bz2
pemagine-feffc7263bb2fd33ae467de2dd51f1ddbbb1b895.tar.xz
initial commit.
Diffstat (limited to 'include/pemagine/bits')
-rw-r--r--include/pemagine/bits/nt32/pe_inline_asm__gcc.h89
-rw-r--r--include/pemagine/bits/nt32/pe_inline_asm__msvc.h67
-rw-r--r--include/pemagine/bits/nt64/pe_inline_asm__gcc.h87
-rw-r--r--include/pemagine/bits/nt64/pe_inline_asm__msvc.h58
4 files changed, 301 insertions, 0 deletions
diff --git a/include/pemagine/bits/nt32/pe_inline_asm__gcc.h b/include/pemagine/bits/nt32/pe_inline_asm__gcc.h
new file mode 100644
index 0000000..10473b4
--- /dev/null
+++ b/include/pemagine/bits/nt32/pe_inline_asm__gcc.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__msvc.h b/include/pemagine/bits/nt32/pe_inline_asm__msvc.h
new file mode 100644
index 0000000..161a846
--- /dev/null
+++ b/include/pemagine/bits/nt32/pe_inline_asm__msvc.h
@@ -0,0 +1,67 @@
+/* optimize: use __readfsdword rather than explicit eax */
+
+static __inline__ void * pe_get_teb_address(void)
+{
+ __asm {
+ mov eax, fs:0x18
+ };
+}
+
+
+static __inline__ void * pe_get_peb_address(void)
+{
+ __asm {
+ mov eax, fs:0x18
+ mov eax, ds:[eax+0x30]
+ };
+}
+
+
+static __inline__ void * pe_get_peb_address_alt(void)
+{
+ __asm {
+ mov eax, fs:0x30
+ };
+}
+
+
+static __inline__ void * pe_get_peb_ldr_data_address(void)
+{
+ __asm {
+ mov eax, fs:0x18
+ mov eax, ds:[eax+0x30]
+ mov eax, ds:[eax+0x0C]
+ };
+}
+
+
+static __inline__ void * pe_get_peb_ldr_data_address_alt(void)
+{
+ __asm {
+ mov eax, fs:0x30
+ mov eax, ds:[eax+0x0C]
+ };
+}
+
+static __inline__ uint32_t pe_get_current_process_id(void)
+{
+ __asm {
+ mov eax, fs:0x20
+ };
+}
+
+static __inline__ uint32_t pe_get_current_thread_id(void)
+{
+ __asm {
+ mov eax, fs:0x24
+ };
+}
+
+static __inline__ uint32_t pe_get_current_session_id(void)
+{
+ __asm {
+ mov eax, fs:0x18
+ mov eax, ds:[eax+0x30]
+ mov eax, ds:[eax+0x1d4]
+ };
+}
diff --git a/include/pemagine/bits/nt64/pe_inline_asm__gcc.h b/include/pemagine/bits/nt64/pe_inline_asm__gcc.h
new file mode 100644
index 0000000..94d4e34
--- /dev/null
+++ b/include/pemagine/bits/nt64/pe_inline_asm__gcc.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__msvc.h b/include/pemagine/bits/nt64/pe_inline_asm__msvc.h
new file mode 100644
index 0000000..e83d587
--- /dev/null
+++ b/include/pemagine/bits/nt64/pe_inline_asm__msvc.h
@@ -0,0 +1,58 @@
+#include <psxtypes/psxtypes.h>
+
+unsigned __int64 __readgsqword(unsigned long);
+
+static __inline__ void * pe_get_teb_address(void)
+{
+ return (void *)__readgsqword(0x30);
+}
+
+
+static __inline__ void * pe_get_peb_address(void)
+{
+ return (void *)__readgsqword(0x60);
+}
+
+
+static __inline__ void * pe_get_peb_address_alt(void)
+{
+ return (void *)__readgsqword(0x60);
+}
+
+
+static __inline__ void * pe_get_peb_ldr_data_address(void)
+{
+ char * rsi;
+
+ rsi = (char *)__readgsqword(0x60);
+ rsi += 0x18;
+
+ return *(void **)rsi;
+}
+
+
+static __inline__ void * pe_get_peb_ldr_data_address_alt(void)
+{
+ return pe_get_peb_ldr_data_address();
+}
+
+
+static __inline__ uint32_t pe_get_current_process_id(void)
+{
+ return (uint32_t)__readgsqword(0x40);
+}
+
+static __inline__ uint32_t pe_get_current_thread_id(void)
+{
+ return (uint32_t)__readgsqword(0x48);
+}
+
+static __inline__ uint32_t pe_get_current_session_id(void)
+{
+ char * rsi;
+
+ rsi = (char *)__readgsqword(0x60);
+ rsi += 0x2c0;
+
+ return *(uint32_t *)rsi;
+}