comparison src/os_cpu/linux_x86/vm/os_linux_x86.cpp @ 52:75b0f3cb1943

Merge
author dcubed
date Thu, 13 Mar 2008 14:17:48 -0700
parents e195fe4c40c7 485d403e94e1
children d1605aabd0a1
comparison
equal deleted inserted replaced
46:8b6e49187640 52:75b0f3cb1943
60 #define SPELL_REG_SP "esp" 60 #define SPELL_REG_SP "esp"
61 #define SPELL_REG_FP "ebp" 61 #define SPELL_REG_FP "ebp"
62 #endif // AMD64 62 #endif // AMD64
63 63
64 address os::current_stack_pointer() { 64 address os::current_stack_pointer() {
65 #ifdef SPARC_WORKS
66 register void *esp;
67 __asm__("mov %%"SPELL_REG_SP", %0":"=r"(esp));
68 return (address) ((char*)esp + sizeof(long)*2);
69 #else
65 register void *esp __asm__ (SPELL_REG_SP); 70 register void *esp __asm__ (SPELL_REG_SP);
66 return (address) esp; 71 return (address) esp;
72 #endif
67 } 73 }
68 74
69 char* os::non_memory_address_word() { 75 char* os::non_memory_address_word() {
70 // Must never look like an address returned by reserve_memory, 76 // Must never look like an address returned by reserve_memory,
71 // even in its subfields (as defined by the CPU immediate fields, 77 // even in its subfields (as defined by the CPU immediate fields,
137 frame os::get_sender_for_C_frame(frame* fr) { 143 frame os::get_sender_for_C_frame(frame* fr) {
138 return frame(fr->sender_sp(), fr->link(), fr->sender_pc()); 144 return frame(fr->sender_sp(), fr->link(), fr->sender_pc());
139 } 145 }
140 146
141 intptr_t* _get_previous_fp() { 147 intptr_t* _get_previous_fp() {
148 #ifdef SPARC_WORKS
149 register intptr_t **ebp;
150 __asm__("mov %%"SPELL_REG_FP", %0":"=r"(ebp));
151 #else
142 register intptr_t **ebp __asm__ (SPELL_REG_FP); 152 register intptr_t **ebp __asm__ (SPELL_REG_FP);
153 #endif
143 return (intptr_t*) *ebp; // we want what it points to. 154 return (intptr_t*) *ebp; // we want what it points to.
144 } 155 }
145 156
146 157
147 frame os::current_frame() { 158 frame os::current_frame() {
558 // amd64: pthread on amd64 is always in floating stack mode 569 // amd64: pthread on amd64 is always in floating stack mode
559 bool os::Linux::supports_variable_stack_size() { return true; } 570 bool os::Linux::supports_variable_stack_size() { return true; }
560 #else 571 #else
561 size_t os::Linux::min_stack_allowed = (48 DEBUG_ONLY(+4))*K; 572 size_t os::Linux::min_stack_allowed = (48 DEBUG_ONLY(+4))*K;
562 573
574 #ifdef __GNUC__
563 #define GET_GS() ({int gs; __asm__ volatile("movw %%gs, %w0":"=q"(gs)); gs&0xffff;}) 575 #define GET_GS() ({int gs; __asm__ volatile("movw %%gs, %w0":"=q"(gs)); gs&0xffff;})
576 #endif
564 577
565 // Test if pthread library can support variable thread stack size. LinuxThreads 578 // Test if pthread library can support variable thread stack size. LinuxThreads
566 // in fixed stack mode allocates 2M fixed slot for each thread. LinuxThreads 579 // in fixed stack mode allocates 2M fixed slot for each thread. LinuxThreads
567 // in floating stack mode and NPTL support variable stack size. 580 // in floating stack mode and NPTL support variable stack size.
568 bool os::Linux::supports_variable_stack_size() { 581 bool os::Linux::supports_variable_stack_size() {
589 // a native application that plays with %gs, we might see non-zero %gs 602 // a native application that plays with %gs, we might see non-zero %gs
590 // even LinuxThreads is running in fixed stack mode. As the result, we'll 603 // even LinuxThreads is running in fixed stack mode. As the result, we'll
591 // return true and skip _thread_safety_check(), so we may not be able to 604 // return true and skip _thread_safety_check(), so we may not be able to
592 // detect stack-heap collisions. But otherwise it's harmless. 605 // detect stack-heap collisions. But otherwise it's harmless.
593 // 606 //
607 #ifdef __GNUC__
594 return (GET_GS() != 0); 608 return (GET_GS() != 0);
609 #else
610 return false;
611 #endif
595 } 612 }
596 } 613 }
597 #endif // AMD64 614 #endif // AMD64
598 615
599 // return default stack size for thr_type 616 // return default stack size for thr_type