X-Git-Url: http://git.liburcu.org/?a=blobdiff_plain;f=include%2Fust%2Fprocessor.h;h=2ee7efa68c15dfa470cffe802536200a9ba31174;hb=defa46a7f4207b7f3df4d87a0bc9814642e5e886;hp=6caae6e7a7a5d4e338524f69eb7dc78ca34bdc08;hpb=2288bf6d907330f1ebec824550e10c7b13bf8997;p=ust.git diff --git a/include/ust/processor.h b/include/ust/processor.h index 6caae6e..2ee7efa 100644 --- a/include/ust/processor.h +++ b/include/ust/processor.h @@ -7,9 +7,14 @@ extern __thread long ust_reg_stack[500]; extern volatile __thread long *ust_reg_stack_ptr; +#ifndef CONFIG_UST_GDB_INTEGRATION +static inline save_ip(void) +{ +} +#endif + -#ifdef x86_32 -#error "32-bit support broken" +#ifndef x86_64 struct registers { long eax; @@ -30,15 +35,25 @@ struct registers { int xss; }; -static inline save_registers(struct registers *regs) -{ -} +#ifdef CONFIG_UST_GDB_ITEGRATION + +#error "GDB integration not supported for x86-32 yet." + +#define save_ip() +#define save_registers(a) + +#else /* CONFIG_UST_GDB_ITEGRATION */ + +#define save_ip() +#define save_registers(a) + +#endif /* CONFIG_UST_GDB_ITEGRATION */ #define RELATIVE_ADDRESS(__rel_label__) __rel_label__ #define _ASM_PTR ".long " -#else +#else /* below is code for x86-64 */ struct registers { int padding; /* 4 bytes */ @@ -63,6 +78,14 @@ struct registers { unsigned long rsp; }; +#ifdef CONFIG_UST_GDB_ITEGRATION +#define save_ip() \ + asm (".section __marker_addr,\"aw\",@progbits\n\t" \ + _ASM_PTR "%c[marker_struct], (1f)\n\t" \ + ".previous\n\t" \ + "1:\n\t" \ + :: [marker_struct] "i" (&__mark_##channel##_##name));\ + #define save_registers(regsptr) \ asm volatile ( \ /* save original rsp */ \ @@ -188,6 +211,8 @@ struct registers { memcpy(regsptr, (void *)ust_reg_stack_ptr, sizeof(struct registers)); \ ust_reg_stack_ptr = (void *)(((long)ust_reg_stack_ptr) + sizeof(struct registers)); +#endif /* CONFIG_UST_GDB_ITEGRATION */ + /* Macro to insert the address of a relative jump in an assembly stub, * in a relocatable way. On x86-64, this uses a special (%rip) notation. */ #define RELATIVE_ADDRESS(__rel_label__) __rel_label__(%%rip)