Print this page
3544 save-args matcher could be considerably more robust
3545 save-args matcher should accept saves may be out-of-order
Reviewed by: Joshua M. Clulow <josh@sysmgr.org>
Reviewed by: Robert Mustacchi <rm@joyent.com>
*** 22,64 ****
extern int name##_end
#define SIZE_OF(name) ((caddr_t)&name##_end - (caddr_t)&name)
#define TEST_GOOD(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 0) != 0) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_GOOD_STRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) != 0) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_BAD(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 0) == 0) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_BAD_STRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) == 0) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
DEF_TEST(gcc_mov_align);
DEF_TEST(gcc_mov_basic);
DEF_TEST(gcc_mov_big_struct_ret);
DEF_TEST(gcc_mov_big_struct_ret_and_spill);
DEF_TEST(gcc_mov_small_struct_ret);
DEF_TEST(gcc_mov_small_struct_ret_and_spill);
DEF_TEST(gcc_mov_stack_spill);
DEF_TEST(gcc_push_align);
DEF_TEST(gcc_push_basic);
DEF_TEST(gcc_push_big_struct_ret);
DEF_TEST(gcc_push_big_struct_ret_and_spill);
DEF_TEST(gcc_push_small_struct_ret);
DEF_TEST(gcc_push_small_struct_ret_and_spill);
DEF_TEST(gcc_push_stack_spill);
--- 22,90 ----
extern int name##_end
#define SIZE_OF(name) ((caddr_t)&name##_end - (caddr_t)&name)
#define TEST_GOOD(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 0) == \
! SAVEARGS_TRAD_ARGS) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_GOOD_STRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) == \
! SAVEARGS_STRUCT_ARGS) \
! printf("Pass: %s\n", #name); \
! else \
! printf("FAIL: %s\n", #name);
!
! /*
! * GCC deals with structures differently, so TRAD args is actually correct for
! * this
! */
! #define TEST_GOOD_GSTRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) == \
! SAVEARGS_TRAD_ARGS) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_BAD(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 0) == \
! SAVEARGS_NO_ARGS) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
#define TEST_BAD_STRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) == \
! SAVEARGS_NO_ARGS) \
! printf("Pass: %s\n", #name); \
! else \
! printf("FAIL: %s\n", #name);
!
! #define TEST_BAD_GSTRUCT(name, argc) \
! if (saveargs_has_args(name, SIZE_OF(name), argc, 1) == \
! SAVEARGS_NO_ARGS) \
printf("Pass: %s\n", #name); \
else \
printf("FAIL: %s\n", #name);
DEF_TEST(gcc_mov_align);
DEF_TEST(gcc_mov_basic);
+ DEF_TEST(gcc_mov_noorder);
+ DEF_TEST(gcc_mov_struct_noorder);
DEF_TEST(gcc_mov_big_struct_ret);
DEF_TEST(gcc_mov_big_struct_ret_and_spill);
DEF_TEST(gcc_mov_small_struct_ret);
DEF_TEST(gcc_mov_small_struct_ret_and_spill);
DEF_TEST(gcc_mov_stack_spill);
DEF_TEST(gcc_push_align);
DEF_TEST(gcc_push_basic);
+ DEF_TEST(gcc_push_noorder);
+ DEF_TEST(gcc_push_struct_noorder);
DEF_TEST(gcc_push_big_struct_ret);
DEF_TEST(gcc_push_big_struct_ret_and_spill);
DEF_TEST(gcc_push_small_struct_ret);
DEF_TEST(gcc_push_small_struct_ret_and_spill);
DEF_TEST(gcc_push_stack_spill);
*** 77,86 ****
--- 103,114 ----
DEF_TEST(av1394_ic_bitreverse);
DEF_TEST(small_struct_ret_w_float);
DEF_TEST(big_struct_ret_w_float);
+ DEF_TEST(interleaved_argument_saves);
+
/*
* Functions which should not match
*
* no_fp -- valid save-args sequence with no saved FP
* big_struct_arg_by_value -- function with big struct passed by value
*** 95,121 ****
{
TEST_GOOD(kmem_alloc, 2);
TEST_GOOD(uts_kill, 2);
TEST_GOOD(av1394_ic_bitreverse, 1);
TEST_GOOD(dtrace_instrumented, 4);
! TEST_GOOD_STRUCT(big_struct_ret_w_float, 1);
TEST_BAD(no_fp, 5);
TEST_GOOD(gcc_mov_align, 5);
TEST_GOOD(gcc_push_align, 5);
TEST_GOOD(ss_mov_align, 5);
TEST_GOOD(gcc_mov_basic, 4);
TEST_GOOD(gcc_push_basic, 4);
TEST_GOOD(ss_mov_basic, 4);
! TEST_GOOD_STRUCT(gcc_mov_big_struct_ret, 4);
! TEST_GOOD_STRUCT(gcc_push_big_struct_ret, 4);
TEST_GOOD_STRUCT(ss_mov_big_struct_ret, 4);
! TEST_GOOD_STRUCT(gcc_mov_big_struct_ret_and_spill, 8);
! TEST_GOOD_STRUCT(gcc_push_big_struct_ret_and_spill, 8);
TEST_GOOD_STRUCT(ss_mov_big_struct_ret_and_spill, 8);
TEST_GOOD(gcc_mov_small_struct_ret, 4);
TEST_GOOD(gcc_push_small_struct_ret, 4);
TEST_GOOD(ss_mov_small_struct_ret, 4);
--- 123,155 ----
{
TEST_GOOD(kmem_alloc, 2);
TEST_GOOD(uts_kill, 2);
TEST_GOOD(av1394_ic_bitreverse, 1);
TEST_GOOD(dtrace_instrumented, 4);
! TEST_GOOD_GSTRUCT(big_struct_ret_w_float, 1);
TEST_BAD(no_fp, 5);
TEST_GOOD(gcc_mov_align, 5);
TEST_GOOD(gcc_push_align, 5);
TEST_GOOD(ss_mov_align, 5);
TEST_GOOD(gcc_mov_basic, 4);
TEST_GOOD(gcc_push_basic, 4);
TEST_GOOD(ss_mov_basic, 4);
! TEST_GOOD(gcc_mov_noorder, 4);
! TEST_GOOD(gcc_push_noorder, 4);
!
! TEST_GOOD_GSTRUCT(gcc_mov_big_struct_ret, 4);
! TEST_GOOD_GSTRUCT(gcc_push_big_struct_ret, 4);
TEST_GOOD_STRUCT(ss_mov_big_struct_ret, 4);
! TEST_GOOD_GSTRUCT(gcc_mov_struct_noorder, 4);
! TEST_GOOD_GSTRUCT(gcc_push_struct_noorder, 4);
!
! TEST_GOOD_GSTRUCT(gcc_mov_big_struct_ret_and_spill, 8);
! TEST_GOOD_GSTRUCT(gcc_push_big_struct_ret_and_spill, 8);
TEST_GOOD_STRUCT(ss_mov_big_struct_ret_and_spill, 8);
TEST_GOOD(gcc_mov_small_struct_ret, 4);
TEST_GOOD(gcc_push_small_struct_ret, 4);
TEST_GOOD(ss_mov_small_struct_ret, 4);
*** 131,137 ****
--- 165,173 ----
TEST_BAD(big_struct_arg_by_value, 2);
TEST_BAD(small_struct_arg_by_value, 2);
TEST_BAD(small_struct_ret_w_float, 1);
+ TEST_GOOD(interleaved_argument_saves, 4);
+
return (0);
}