mirror of
https://github.com/kanjitalk755/macemu.git
synced 2025-01-12 16:30:44 +00:00
Hack around over-optimized labels-as-values extension from GCC.
This commit is contained in:
parent
e08bb16edf
commit
a56e4b9be0
@ -2389,18 +2389,30 @@ int main(void)
|
|||||||
|
|
||||||
if (!sigsegv_install_handler(sigsegv_test_handler))
|
if (!sigsegv_install_handler(sigsegv_test_handler))
|
||||||
return 4;
|
return 4;
|
||||||
|
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
b_region = &&L_b_region1;
|
b_region = &&L_b_region1;
|
||||||
e_region = &&L_e_region1;
|
e_region = &&L_e_region1;
|
||||||
#endif
|
#endif
|
||||||
L_b_region1:
|
/* This is a really awful hack but otherwise gcc is smart enough
|
||||||
page[REF_INDEX] = REF_VALUE;
|
* (or bug'ous enough?) to optimize the labels and place them
|
||||||
if (page[REF_INDEX] != REF_VALUE)
|
* e.g. at the "main" entry point, which is wrong.
|
||||||
exit(20);
|
*/
|
||||||
page[REF_INDEX] = REF_VALUE;
|
volatile int label_hack = 1;
|
||||||
BARRIER();
|
switch (label_hack) {
|
||||||
L_e_region1:
|
case 1:
|
||||||
|
L_b_region1:
|
||||||
|
page[REF_INDEX] = REF_VALUE;
|
||||||
|
if (page[REF_INDEX] != REF_VALUE)
|
||||||
|
exit(20);
|
||||||
|
page[REF_INDEX] = REF_VALUE;
|
||||||
|
BARRIER();
|
||||||
|
// fall-through
|
||||||
|
case 2:
|
||||||
|
L_e_region1:
|
||||||
|
BARRIER();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (handler_called != 1)
|
if (handler_called != 1)
|
||||||
return 5;
|
return 5;
|
||||||
@ -2431,18 +2443,24 @@ int main(void)
|
|||||||
b_region = &&L_b_region2;
|
b_region = &&L_b_region2;
|
||||||
e_region = &&L_e_region2;
|
e_region = &&L_e_region2;
|
||||||
#endif
|
#endif
|
||||||
L_b_region2:
|
switch (label_hack) {
|
||||||
TEST_SKIP_INSTRUCTION(unsigned char);
|
case 1:
|
||||||
TEST_SKIP_INSTRUCTION(unsigned short);
|
L_b_region2:
|
||||||
TEST_SKIP_INSTRUCTION(unsigned int);
|
TEST_SKIP_INSTRUCTION(unsigned char);
|
||||||
TEST_SKIP_INSTRUCTION(unsigned long);
|
TEST_SKIP_INSTRUCTION(unsigned short);
|
||||||
TEST_SKIP_INSTRUCTION(signed char);
|
TEST_SKIP_INSTRUCTION(unsigned int);
|
||||||
TEST_SKIP_INSTRUCTION(signed short);
|
TEST_SKIP_INSTRUCTION(unsigned long);
|
||||||
TEST_SKIP_INSTRUCTION(signed int);
|
TEST_SKIP_INSTRUCTION(signed char);
|
||||||
TEST_SKIP_INSTRUCTION(signed long);
|
TEST_SKIP_INSTRUCTION(signed short);
|
||||||
BARRIER();
|
TEST_SKIP_INSTRUCTION(signed int);
|
||||||
L_e_region2:
|
TEST_SKIP_INSTRUCTION(signed long);
|
||||||
|
BARRIER();
|
||||||
|
// fall-through
|
||||||
|
case 2:
|
||||||
|
L_e_region2:
|
||||||
|
BARRIER();
|
||||||
|
break;
|
||||||
|
}
|
||||||
if (!arch_insn_skipper_tests())
|
if (!arch_insn_skipper_tests())
|
||||||
return 20;
|
return 20;
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user