mirror of
				https://github.com/jart/cosmopolitan.git
				synced 2025-10-25 18:50:57 +00:00 
			
		
		
		
	- Document sigaction() - Simplify New Technology fork() code - Testing and many bug fixes for mprotect() - Distribute Intel Xed ILD in the amalgamation - Turn Xed enums into defines to avoid DWARF bloat - Improve polyfilling of SA_SIGINFO on BSDs and fix bugs - setpgid(getpid(), getpid()) on Windows will ignore CTRL-C - Work around issues relating to NT mappings being executable - Permit automatic executable stack override via `ape_stack_pf`
		
			
				
	
	
		
			89 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
	
		
			2.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #if 0
 | |
| /*─────────────────────────────────────────────────────────────────╗
 | |
| │ To the extent possible under law, Justine Tunney has waived      │
 | |
| │ all copyright and related or neighboring rights to this file,    │
 | |
| │ as it is written in the following disclaimers:                   │
 | |
| │   • http://unlicense.org/                                        │
 | |
| │   • http://creativecommons.org/publicdomain/zero/1.0/            │
 | |
| ╚─────────────────────────────────────────────────────────────────*/
 | |
| #endif
 | |
| #include "libc/errno.h"
 | |
| #include "libc/runtime/runtime.h"
 | |
| #include "libc/stdio/stdio.h"
 | |
| #include "libc/str/str.h"
 | |
| #include "libc/sysv/errfuns.h"
 | |
| #include "third_party/xed/x86.h"
 | |
| 
 | |
| /**
 | |
|  * @fileoverview x86 instruction length decoder by way of hex pipe.
 | |
|  *
 | |
|  * Here's an example of how you can use it to decode a NOP stream:
 | |
|  *
 | |
|  *     $ make -j8 o//examples/x86split.com
 | |
|  *     $ echo 909090 | o//examples/x86split.com
 | |
|  *     90
 | |
|  *     90
 | |
|  *     90
 | |
|  *
 | |
|  * If there was a XOR instruction in there, it'd do this:
 | |
|  *
 | |
|  *     $ make -j8 o//examples/x86split.com
 | |
|  *     $ echo 904531FF90 | o//examples/x86split.com
 | |
|  *     90                     # NOP
 | |
|  *     4531FF                 # XOR R15D,R15D
 | |
|  *     90                     # NOP
 | |
|  *
 | |
|  * Now that you're able to split x86 instructions the rest is easy.
 | |
|  */
 | |
| 
 | |
| int fgethex(FILE *f) {
 | |
|   int o, t = -1;
 | |
|   while (!((o = fgetc(f)) & ~0xFF)) {
 | |
|     switch (t) {
 | |
|       case -1:
 | |
|         t = isxdigit(o) ? hextoint(o) : -1;
 | |
|         break;
 | |
|       default:
 | |
|         if (isxdigit(o)) {
 | |
|           return t * 16 + hextoint(o);
 | |
|         }
 | |
|         break;
 | |
|     }
 | |
|   }
 | |
|   if (t >= 0) return einval();
 | |
|   return -1;
 | |
| }
 | |
| 
 | |
| int main(int argc, char *argv[argc]) {
 | |
|   int err;
 | |
|   unsigned c, i, j, l;
 | |
|   struct XedDecodedInst xedd;
 | |
|   unsigned char buf[XED_MAX_INSTRUCTION_BYTES];
 | |
|   memset(buf, 0, sizeof(buf));
 | |
|   for (i = 0;;) {
 | |
|     if (i < XED_MAX_INSTRUCTION_BYTES) {
 | |
|       c = fgethex(stdin);
 | |
|       if (c != -1) {
 | |
|         buf[i++] = c;
 | |
|         continue;
 | |
|       } else if (i == 0) {
 | |
|         break;
 | |
|       }
 | |
|     }
 | |
|     if ((err = xed_instruction_length_decode(
 | |
|              xed_decoded_inst_zero_set_mode(&xedd, XED_MACHINE_MODE_LONG_64),
 | |
|              buf, i))) {
 | |
|       errno = err;
 | |
|       break;
 | |
|     }
 | |
|     l = xedd.length;
 | |
|     if (l <= 0 || l > i) abort();
 | |
|     for (j = 0; j < l; ++j) {
 | |
|       fputc("0123456789ABCDEF"[(buf[j] & 0xf0) >> 4], stdout);
 | |
|       fputc("0123456789ABCDEF"[(buf[j] & 0x0f) >> 0], stdout);
 | |
|     }
 | |
|     putchar('\n');
 | |
|     memcpy(&buf[0], &buf[l], i -= l);
 | |
|   }
 | |
|   return errno;
 | |
| }
 |