Changeset 87212 in vbox for trunk/src/VBox
- Timestamp:
- Jan 11, 2021 1:15:45 PM (4 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Runtime/testcase/tstRTInlineAsm.cpp
r86586 r87212 79 79 } \ 80 80 } while (0) 81 82 #define CHECK_OP_AND_VAL(a_Type, a_Fmt, a_pVar, a_Operation, a_ExpectRetVal, a_ExpectVarVal) \ 83 do { \ 84 CHECKOP(a_Operation, a_ExpectRetVal, a_Fmt, a_Type); \ 85 CHECKVAL(*a_pVar, a_ExpectVarVal, a_Fmt); \ 86 } while (0) 87 88 #define CHECK_OP_AND_VAL_EX(a_TypeRet, a_FmtRet, a_FmtVar, a_pVar, a_Operation, a_ExpectRetVal, a_ExpectVarVal) \ 89 do { \ 90 CHECKOP(a_Operation, a_ExpectRetVal, a_FmtRet, a_TypeRet); \ 91 CHECKVAL(*a_pVar, a_ExpectVarVal, a_FmtVar); \ 92 } while (0) 93 94 #define CHECK_OP_AND_VAL_EX2(a_TypeRet, a_FmtRet, a_FmtVar, a_pVar, a_uVar2, a_Operation, a_ExpectRetVal, a_ExpectVarVal, a_ExpectVarVal2) \ 95 do { \ 96 CHECKOP(a_Operation, a_ExpectRetVal, a_FmtRet, a_TypeRet); \ 97 CHECKVAL(*a_pVar, a_ExpectVarVal, a_FmtVar); \ 98 CHECKVAL(a_uVar2, a_ExpectVarVal2, a_FmtVar); \ 99 } while (0) 100 81 101 82 102 /** … … 697 717 #endif /* AMD64 || X86 */ 698 718 719 #define TEST_READ(a_pVar, a_Type, a_Fmt, a_Function, a_Val) \ 720 do { *a_pVar = a_Val; CHECKOP(a_Function(a_pVar), a_Val, a_Fmt, a_Type); CHECKVAL(*a_pVar, a_Val, a_Fmt); } while (0) 721 722 DECLINLINE(void) tstASMAtomicReadU8Worker(uint8_t volatile *pu8) 723 { 724 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 0); 725 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 1); 726 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 2); 727 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 16); 728 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 32); 729 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 32); 730 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 127); 731 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 128); 732 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 169); 733 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 239); 734 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 254); 735 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicReadU8, 255); 736 737 int8_t volatile *pi8 = (int8_t volatile *)pu8; 738 TEST_READ(pi8, uint8_t, "%d", ASMAtomicReadS8, INT8_MAX); 739 TEST_READ(pi8, uint8_t, "%d", ASMAtomicReadS8, INT8_MIN); 740 TEST_READ(pi8, uint8_t, "%d", ASMAtomicReadS8, 42); 741 TEST_READ(pi8, uint8_t, "%d", ASMAtomicReadS8, -21); 742 743 bool volatile *pf = (bool volatile *)pu8; 744 TEST_READ(pf, bool, "%d", ASMAtomicReadBool, true); 745 TEST_READ(pf, bool, "%d", ASMAtomicReadBool, false); 746 } 747 748 749 DECLINLINE(void) tstASMAtomicUoReadU8Worker(uint8_t volatile *pu8) 750 { 751 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 0); 752 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 1); 753 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 2); 754 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 16); 755 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 32); 756 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 32); 757 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 127); 758 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 128); 759 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 169); 760 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 239); 761 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 254); 762 TEST_READ(pu8, uint8_t, "%#x", ASMAtomicUoReadU8, 255); 763 764 int8_t volatile *pi8 = (int8_t volatile *)pu8; 765 TEST_READ(pi8, uint8_t, "%d", ASMAtomicUoReadS8, INT8_MAX); 766 TEST_READ(pi8, uint8_t, "%d", ASMAtomicUoReadS8, INT8_MIN); 767 TEST_READ(pi8, uint8_t, "%d", ASMAtomicUoReadS8, 42); 768 TEST_READ(pi8, uint8_t, "%d", ASMAtomicUoReadS8, -21); 769 770 bool volatile *pf = (bool volatile *)pu8; 771 TEST_READ(pf, bool, "%d", ASMAtomicUoReadBool, true); 772 TEST_READ(pf, bool, "%d", ASMAtomicUoReadBool, false); 773 } 774 775 776 DECLINLINE(void) tstASMAtomicReadU16Worker(uint16_t volatile *pu16) 777 { 778 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicReadU16, 0); 779 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicReadU16, 19983); 780 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicReadU16, INT16_MAX); 781 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicReadU16, UINT16_MAX); 782 783 int16_t volatile *pi16 = (int16_t volatile *)pu16; 784 TEST_READ(pi16, uint16_t, "%d", ASMAtomicReadS16, INT16_MAX); 785 TEST_READ(pi16, uint16_t, "%d", ASMAtomicReadS16, INT16_MIN); 786 TEST_READ(pi16, uint16_t, "%d", ASMAtomicReadS16, 42); 787 TEST_READ(pi16, uint16_t, "%d", ASMAtomicReadS16, -21); 788 } 789 790 791 DECLINLINE(void) tstASMAtomicUoReadU16Worker(uint16_t volatile *pu16) 792 { 793 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicUoReadU16, 0); 794 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicUoReadU16, 19983); 795 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicUoReadU16, INT16_MAX); 796 TEST_READ(pu16, uint16_t, "%#x", ASMAtomicUoReadU16, UINT16_MAX); 797 798 int16_t volatile *pi16 = (int16_t volatile *)pu16; 799 TEST_READ(pi16, uint16_t, "%d", ASMAtomicUoReadS16, INT16_MAX); 800 TEST_READ(pi16, uint16_t, "%d", ASMAtomicUoReadS16, INT16_MIN); 801 TEST_READ(pi16, uint16_t, "%d", ASMAtomicUoReadS16, 42); 802 TEST_READ(pi16, uint16_t, "%d", ASMAtomicUoReadS16, -21); 803 } 804 805 806 DECLINLINE(void) tstASMAtomicReadU32Worker(uint32_t volatile *pu32) 807 { 808 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, 0); 809 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, 19983); 810 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, INT16_MAX); 811 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, UINT16_MAX); 812 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, _1M-1); 813 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, _1M+1); 814 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, _1G-1); 815 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, _1G+1); 816 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, INT32_MAX); 817 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicReadU32, UINT32_MAX); 818 819 int32_t volatile *pi32 = (int32_t volatile *)pu32; 820 TEST_READ(pi32, uint32_t, "%d", ASMAtomicReadS32, INT32_MAX); 821 TEST_READ(pi32, uint32_t, "%d", ASMAtomicReadS32, INT32_MIN); 822 TEST_READ(pi32, uint32_t, "%d", ASMAtomicReadS32, 42); 823 TEST_READ(pi32, uint32_t, "%d", ASMAtomicReadS32, -21); 824 825 #if ARCH_BITS == 32 826 size_t volatile *pcb = (size_t volatile *)pu32; 827 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, 0); 828 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, ~(size_t)2); 829 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, ~(size_t)0 / 4); 830 831 void * volatile *ppv = (void * volatile *)pu32; 832 TEST_READ(ppv, void *, "%p", ASMAtomicReadPtr, NULL); 833 TEST_READ(ppv, void *, "%p", ASMAtomicReadPtr, (void *)~(uintptr_t)42); 834 835 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu32; 836 RTSEMEVENT hEvt = ASMAtomicReadPtrT(phEvt, RTSEMEVENT); 837 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 838 839 ASMAtomicReadHandle(phEvt, &hEvt); 840 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 841 #endif 842 } 843 844 845 DECLINLINE(void) tstASMAtomicUoReadU32Worker(uint32_t volatile *pu32) 846 { 847 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, 0); 848 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, 19983); 849 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, INT16_MAX); 850 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, UINT16_MAX); 851 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, _1M-1); 852 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, _1M+1); 853 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, _1G-1); 854 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, _1G+1); 855 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, INT32_MAX); 856 TEST_READ(pu32, uint32_t, "%#x", ASMAtomicUoReadU32, UINT32_MAX); 857 858 int32_t volatile *pi32 = (int32_t volatile *)pu32; 859 TEST_READ(pi32, uint32_t, "%d", ASMAtomicUoReadS32, INT32_MAX); 860 TEST_READ(pi32, uint32_t, "%d", ASMAtomicUoReadS32, INT32_MIN); 861 TEST_READ(pi32, uint32_t, "%d", ASMAtomicUoReadS32, 42); 862 TEST_READ(pi32, uint32_t, "%d", ASMAtomicUoReadS32, -21); 863 864 #if ARCH_BITS == 32 865 size_t volatile *pcb = (size_t volatile *)pu32; 866 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, 0); 867 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, ~(size_t)2); 868 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, ~(size_t)0 / 4); 869 870 void * volatile *ppv = (void * volatile *)pu32; 871 TEST_READ(ppv, void *, "%p", ASMAtomicUoReadPtr, NULL); 872 TEST_READ(ppv, void *, "%p", ASMAtomicUoReadPtr, (void *)~(uintptr_t)42); 873 874 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu32; 875 RTSEMEVENT hEvt = ASMAtomicUoReadPtrT(phEvt, RTSEMEVENT); 876 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 877 878 ASMAtomicUoReadHandle(phEvt, &hEvt); 879 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 880 #endif 881 } 882 883 884 DECLINLINE(void) tstASMAtomicReadU64Worker(uint64_t volatile *pu64) 885 { 886 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, 0); 887 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, 19983); 888 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, INT16_MAX); 889 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, UINT16_MAX); 890 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, _1M-1); 891 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, _1M+1); 892 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, _1G-1); 893 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, _1G+1); 894 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, INT32_MAX); 895 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, UINT32_MAX); 896 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, INT64_MAX); 897 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, UINT64_MAX); 898 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicReadU64, UINT64_C(0x450872549687134)); 899 900 int64_t volatile *pi64 = (int64_t volatile *)pu64; 901 TEST_READ(pi64, uint64_t, "%d", ASMAtomicReadS64, INT64_MAX); 902 TEST_READ(pi64, uint64_t, "%d", ASMAtomicReadS64, INT64_MIN); 903 TEST_READ(pi64, uint64_t, "%d", ASMAtomicReadS64, 42); 904 TEST_READ(pi64, uint64_t, "%d", ASMAtomicReadS64, -21); 905 906 #if ARCH_BITS == 64 907 size_t volatile *pcb = (size_t volatile *)pu64; 908 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, 0); 909 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, ~(size_t)2); 910 TEST_READ(pcb, size_t, "%#llz", ASMAtomicReadZ, ~(size_t)0 / 4); 911 912 void * volatile *ppv = (void * volatile *)pu64; 913 TEST_READ(ppv, void *, "%p", ASMAtomicReadPtr, NULL); 914 TEST_READ(ppv, void *, "%p", ASMAtomicReadPtr, (void *)~(uintptr_t)42); 915 916 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 917 RTSEMEVENT hEvt = ASMAtomicReadPtrT(phEvt, RTSEMEVENT); 918 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 919 920 ASMAtomicReadHandle(phEvt, &hEvt); 921 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 922 #endif 923 } 924 925 926 DECLINLINE(void) tstASMAtomicUoReadU64Worker(uint64_t volatile *pu64) 927 { 928 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, 0); 929 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, 19983); 930 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, INT16_MAX); 931 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, UINT16_MAX); 932 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, _1M-1); 933 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, _1M+1); 934 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, _1G-1); 935 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, _1G+1); 936 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, INT32_MAX); 937 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, UINT32_MAX); 938 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, INT64_MAX); 939 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, UINT64_MAX); 940 TEST_READ(pu64, uint64_t, "%#llx", ASMAtomicUoReadU64, UINT64_C(0x450872549687134)); 941 942 int64_t volatile *pi64 = (int64_t volatile *)pu64; 943 TEST_READ(pi64, uint64_t, "%d", ASMAtomicUoReadS64, INT64_MAX); 944 TEST_READ(pi64, uint64_t, "%d", ASMAtomicUoReadS64, INT64_MIN); 945 TEST_READ(pi64, uint64_t, "%d", ASMAtomicUoReadS64, 42); 946 TEST_READ(pi64, uint64_t, "%d", ASMAtomicUoReadS64, -21); 947 948 #if ARCH_BITS == 64 949 size_t volatile *pcb = (size_t volatile *)pu64; 950 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, 0); 951 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, ~(size_t)2); 952 TEST_READ(pcb, size_t, "%#llz", ASMAtomicUoReadZ, ~(size_t)0 / 4); 953 954 void * volatile *ppv = (void * volatile *)pu64; 955 TEST_READ(ppv, void *, "%p", ASMAtomicUoReadPtr, NULL); 956 TEST_READ(ppv, void *, "%p", ASMAtomicUoReadPtr, (void *)~(uintptr_t)42); 957 958 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 959 RTSEMEVENT hEvt = ASMAtomicUoReadPtrT(phEvt, RTSEMEVENT); 960 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 961 962 ASMAtomicUoReadHandle(phEvt, &hEvt); 963 CHECKVAL(hEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 964 #endif 965 } 966 967 968 static void tstASMAtomicRead(void) 969 { 970 DO_SIMPLE_TEST(ASMAtomicReadU8, uint8_t); 971 DO_SIMPLE_TEST(ASMAtomicUoReadU8, uint8_t); 972 973 DO_SIMPLE_TEST(ASMAtomicReadU16, uint16_t); 974 DO_SIMPLE_TEST(ASMAtomicUoReadU16, uint16_t); 975 976 DO_SIMPLE_TEST(ASMAtomicReadU32, uint32_t); 977 DO_SIMPLE_TEST(ASMAtomicUoReadU32, uint32_t); 978 979 DO_SIMPLE_TEST(ASMAtomicReadU64, uint64_t); 980 DO_SIMPLE_TEST(ASMAtomicUoReadU64, uint64_t); 981 } 982 983 984 #define TEST_WRITE(a_pVar, a_Type, a_Fmt, a_Function, a_Val) \ 985 do { a_Function(a_pVar, a_Val); CHECKVAL(*a_pVar, a_Val, a_Fmt); } while (0) 986 987 DECLINLINE(void) tstASMAtomicWriteU8Worker(uint8_t volatile *pu8) 988 { 989 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 0); 990 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 1); 991 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 2); 992 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 16); 993 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 32); 994 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 32); 995 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 127); 996 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 128); 997 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 169); 998 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 239); 999 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 254); 1000 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicWriteU8, 255); 1001 1002 volatile int8_t *pi8 = (volatile int8_t *)pu8; 1003 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicWriteS8, INT8_MIN); 1004 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicWriteS8, INT8_MAX); 1005 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicWriteS8, 42); 1006 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicWriteS8, -41); 1007 1008 volatile bool *pf = (volatile bool *)pu8; 1009 TEST_WRITE(pf, bool, "%d", ASMAtomicWriteBool, true); 1010 TEST_WRITE(pf, bool, "%d", ASMAtomicWriteBool, false); 1011 } 1012 1013 1014 DECLINLINE(void) tstASMAtomicUoWriteU8Worker(uint8_t volatile *pu8) 1015 { 1016 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 0); 1017 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 1); 1018 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 2); 1019 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 16); 1020 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 32); 1021 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 32); 1022 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 127); 1023 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 128); 1024 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 169); 1025 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 239); 1026 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 254); 1027 TEST_WRITE(pu8, uint8_t, "%#x", ASMAtomicUoWriteU8, 255); 1028 1029 volatile int8_t *pi8 = (volatile int8_t *)pu8; 1030 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicUoWriteS8, INT8_MIN); 1031 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicUoWriteS8, INT8_MAX); 1032 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicUoWriteS8, 42); 1033 TEST_WRITE(pi8, int8_t, "%d", ASMAtomicUoWriteS8, -41); 1034 1035 volatile bool *pf = (volatile bool *)pu8; 1036 TEST_WRITE(pf, bool, "%d", ASMAtomicUoWriteBool, true); 1037 TEST_WRITE(pf, bool, "%d", ASMAtomicUoWriteBool, false); 1038 } 1039 1040 1041 DECLINLINE(void) tstASMAtomicWriteU16Worker(uint16_t volatile *pu16) 1042 { 1043 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicWriteU16, 0); 1044 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicWriteU16, 19983); 1045 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicWriteU16, INT16_MAX); 1046 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicWriteU16, UINT16_MAX); 1047 1048 volatile int16_t *pi16 = (volatile int16_t *)pu16; 1049 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicWriteS16, INT16_MIN); 1050 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicWriteS16, INT16_MAX); 1051 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicWriteS16, 42); 1052 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicWriteS16, -41); 1053 } 1054 1055 1056 DECLINLINE(void) tstASMAtomicUoWriteU16Worker(uint16_t volatile *pu16) 1057 { 1058 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicUoWriteU16, 0); 1059 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicUoWriteU16, 19983); 1060 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicUoWriteU16, INT16_MAX); 1061 TEST_WRITE(pu16, uint16_t, "%#x", ASMAtomicUoWriteU16, UINT16_MAX); 1062 1063 volatile int16_t *pi16 = (volatile int16_t *)pu16; 1064 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicUoWriteS16, INT16_MIN); 1065 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicUoWriteS16, INT16_MAX); 1066 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicUoWriteS16, 42); 1067 TEST_WRITE(pi16, int16_t, "%d", ASMAtomicUoWriteS16, -41); 1068 } 1069 1070 1071 DECLINLINE(void) tstASMAtomicWriteU32Worker(uint32_t volatile *pu32) 1072 { 1073 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, 0); 1074 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, 19983); 1075 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, INT16_MAX); 1076 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, UINT16_MAX); 1077 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, _1M-1); 1078 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, _1M+1); 1079 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, _1G-1); 1080 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, _1G+1); 1081 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, INT32_MAX); 1082 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicWriteU32, UINT32_MAX); 1083 1084 volatile int32_t *pi32 = (volatile int32_t *)pu32; 1085 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicWriteS32, INT32_MIN); 1086 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicWriteS32, INT32_MAX); 1087 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicWriteS32, 42); 1088 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicWriteS32, -41); 1089 1090 #if ARCH_BITS == 32 1091 size_t volatile *pcb = (size_t volatile *)pu32; 1092 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicWriteZ, ~(size_t)42); 1093 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicWriteZ, 42); 1094 1095 void * volatile *ppv = (void * volatile *)pu32; 1096 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicWritePtrVoid, NULL); 1097 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicWritePtrVoid, (void *)~(uintptr_t)12938754); 1098 1099 ASMAtomicWriteNullPtr(ppv); CHECKVAL(*ppv, NULL, "%p"); 1100 ASMAtomicWritePtr(ppv, (void *)~(intptr_t)2322434); CHECKVAL(*ppv, (void *)~(intptr_t)2322434, "%p"); 1101 1102 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu32; 1103 ASMAtomicWriteHandle(phEvt, (RTSEMEVENT)(uintptr_t)99753456); CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)99753456, "%p"); 1104 #endif 1105 } 1106 1107 1108 DECLINLINE(void) tstASMAtomicUoWriteU32Worker(uint32_t volatile *pu32) 1109 { 1110 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, 0); 1111 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, 19983); 1112 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, INT16_MAX); 1113 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, UINT16_MAX); 1114 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, _1M-1); 1115 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, _1M+1); 1116 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, _1G-1); 1117 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, _1G+1); 1118 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, INT32_MAX); 1119 TEST_WRITE(pu32, uint32_t, "%#x", ASMAtomicUoWriteU32, UINT32_MAX); 1120 1121 volatile int32_t *pi32 = (volatile int32_t *)pu32; 1122 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicUoWriteS32, INT32_MIN); 1123 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicUoWriteS32, INT32_MAX); 1124 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicUoWriteS32, 42); 1125 TEST_WRITE(pi32, int32_t, "%d", ASMAtomicUoWriteS32, -41); 1126 1127 #if ARCH_BITS == 32 1128 size_t volatile *pcb = (size_t volatile *)pu32; 1129 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicUoWriteZ, ~(size_t)42); 1130 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicUoWriteZ, 42); 1131 1132 void * volatile *ppv = (void * volatile *)pu32; 1133 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicUoWritePtrVoid, NULL); 1134 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicUoWritePtrVoid, (void *)~(uintptr_t)12938754); 1135 1136 ASMAtomicUoWriteNullPtr(ppv); CHECKVAL(*ppv, NULL, "%p"); 1137 ASMAtomicUoWritePtr(ppv, (void *)~(intptr_t)2322434); CHECKVAL(*ppv, (void *)~(intptr_t)2322434, "%p"); 1138 1139 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu32; 1140 ASMAtomicUoWriteHandle(phEvt, (RTSEMEVENT)(uintptr_t)99753456); CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)99753456, "%p"); 1141 #endif 1142 } 1143 1144 1145 DECLINLINE(void) tstASMAtomicWriteU64Worker(uint64_t volatile *pu64) 1146 { 1147 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, 0); 1148 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, 19983); 1149 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, INT16_MAX); 1150 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, UINT16_MAX); 1151 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, _1M-1); 1152 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, _1M+1); 1153 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, _1G-1); 1154 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, _1G+1); 1155 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, INT32_MAX); 1156 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, UINT32_MAX); 1157 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, INT64_MAX); 1158 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, UINT64_MAX); 1159 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicWriteU64, UINT64_C(0x450872549687134)); 1160 1161 volatile int64_t *pi64 = (volatile int64_t *)pu64; 1162 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicWriteS64, INT64_MIN); 1163 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicWriteS64, INT64_MAX); 1164 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicWriteS64, 42); 1165 1166 #if ARCH_BITS == 64 1167 size_t volatile *pcb = (size_t volatile *)pu64; 1168 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicWriteZ, ~(size_t)42); 1169 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicWriteZ, 42); 1170 1171 void * volatile *ppv = (void * volatile *)pu64; 1172 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicWritePtrVoid, NULL); 1173 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicWritePtrVoid, (void *)~(uintptr_t)12938754); 1174 1175 ASMAtomicWriteNullPtr(ppv); CHECKVAL(*ppv, NULL, "%p"); 1176 ASMAtomicWritePtr(ppv, (void *)~(intptr_t)2322434); CHECKVAL(*ppv, (void *)~(intptr_t)2322434, "%p"); 1177 1178 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 1179 ASMAtomicWriteHandle(phEvt, (RTSEMEVENT)(uintptr_t)99753456); CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)99753456, "%p"); 1180 #endif 1181 } 1182 1183 1184 DECLINLINE(void) tstASMAtomicUoWriteU64Worker(uint64_t volatile *pu64) 1185 { 1186 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, 0); 1187 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, 19983); 1188 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, INT16_MAX); 1189 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, UINT16_MAX); 1190 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, _1M-1); 1191 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, _1M+1); 1192 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, _1G-1); 1193 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, _1G+1); 1194 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, INT32_MAX); 1195 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, UINT32_MAX); 1196 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, INT64_MAX); 1197 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, UINT64_MAX); 1198 TEST_WRITE(pu64, uint64_t, "%#llx", ASMAtomicUoWriteU64, UINT64_C(0x450872549687134)); 1199 1200 volatile int64_t *pi64 = (volatile int64_t *)pu64; 1201 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicUoWriteS64, INT64_MIN); 1202 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicUoWriteS64, INT64_MAX); 1203 TEST_WRITE(pi64, int64_t, "%d", ASMAtomicUoWriteS64, 42); 1204 1205 #if ARCH_BITS == 64 1206 size_t volatile *pcb = (size_t volatile *)pu64; 1207 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicUoWriteZ, ~(size_t)42); 1208 TEST_WRITE(pcb, size_t, "%#zx", ASMAtomicUoWriteZ, 42); 1209 1210 void * volatile *ppv = (void * volatile *)pu64; 1211 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicUoWritePtrVoid, NULL); 1212 TEST_WRITE(ppv, void *, "%#zx", ASMAtomicUoWritePtrVoid, (void *)~(uintptr_t)12938754); 1213 1214 ASMAtomicUoWriteNullPtr(ppv); CHECKVAL(*ppv, NULL, "%p"); 1215 ASMAtomicUoWritePtr(ppv, (void *)~(intptr_t)2322434); CHECKVAL(*ppv, (void *)~(intptr_t)2322434, "%p"); 1216 1217 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 1218 ASMAtomicUoWriteHandle(phEvt, (RTSEMEVENT)(uintptr_t)99753456); CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)99753456, "%p"); 1219 #endif 1220 } 1221 1222 static void tstASMAtomicWrite(void) 1223 { 1224 DO_SIMPLE_TEST(ASMAtomicWriteU8, uint8_t); 1225 DO_SIMPLE_TEST(ASMAtomicUoWriteU8, uint8_t); 1226 1227 DO_SIMPLE_TEST(ASMAtomicWriteU16, uint16_t); 1228 DO_SIMPLE_TEST(ASMAtomicUoWriteU16, uint16_t); 1229 1230 DO_SIMPLE_TEST(ASMAtomicWriteU32, uint32_t); 1231 DO_SIMPLE_TEST(ASMAtomicUoWriteU32, uint32_t); 1232 1233 DO_SIMPLE_TEST(ASMAtomicWriteU64, uint64_t); 1234 DO_SIMPLE_TEST(ASMAtomicUoWriteU64, uint64_t); 1235 } 1236 1237 699 1238 DECLINLINE(void) tstASMAtomicXchgU8Worker(uint8_t volatile *pu8) 700 1239 { 701 1240 *pu8 = 0; 702 CHECKOP(ASMAtomicXchgU8(pu8, 1), 0, "%#x", uint8_t); 703 CHECKVAL(*pu8, 1, "%#x"); 704 705 CHECKOP(ASMAtomicXchgU8(pu8, 0), 1, "%#x", uint8_t); 706 CHECKVAL(*pu8, 0, "%#x"); 707 708 CHECKOP(ASMAtomicXchgU8(pu8, UINT8_C(0xff)), 0, "%#x", uint8_t); 709 CHECKVAL(*pu8, 0xff, "%#x"); 710 711 CHECKOP(ASMAtomicXchgU8(pu8, UINT8_C(0x87)), UINT8_C(0xff), "%#x", uint8_t); 712 CHECKVAL(*pu8, 0x87, "%#x"); 713 } 714 715 716 static void tstASMAtomicXchgU8(void) 1241 CHECK_OP_AND_VAL(uint8_t, "%#x", pu8, ASMAtomicXchgU8(pu8, 1), 0, 1); 1242 CHECK_OP_AND_VAL(uint8_t, "%#x", pu8, ASMAtomicXchgU8(pu8, UINT8_C(0xff)), 1, UINT8_C(0xff)); 1243 CHECK_OP_AND_VAL(uint8_t, "%#x", pu8, ASMAtomicXchgU8(pu8, UINT8_C(0x87)), UINT8_C(0xff), UINT8_C(0x87)); 1244 CHECK_OP_AND_VAL(uint8_t, "%#x", pu8, ASMAtomicXchgU8(pu8, UINT8_C(0xfe)), UINT8_C(0x87), UINT8_C(0xfe)); 1245 1246 int8_t volatile *pi8 = (int8_t volatile *)pu8; 1247 CHECK_OP_AND_VAL(int8_t, "%d", pi8, ASMAtomicXchgS8(pi8, INT8_C(-4)), UINT8_C(-2), UINT8_C(-4)); 1248 CHECK_OP_AND_VAL(int8_t, "%d", pi8, ASMAtomicXchgS8(pi8, INT8_C(4)), UINT8_C(-4), UINT8_C(4)); 1249 CHECK_OP_AND_VAL(int8_t, "%d", pi8, ASMAtomicXchgS8(pi8, INT8_MAX), UINT8_C(4), INT8_MAX); 1250 CHECK_OP_AND_VAL(int8_t, "%d", pi8, ASMAtomicXchgS8(pi8, INT8_MIN), INT8_MAX, INT8_MIN); 1251 CHECK_OP_AND_VAL(int8_t, "%d", pi8, ASMAtomicXchgS8(pi8, 1), INT8_MIN, 1); 1252 1253 bool volatile *pf = (bool volatile *)pu8; 1254 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicXchgBool(pf, false), true, false); 1255 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicXchgBool(pf, false), false, false); 1256 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicXchgBool(pf, true), false, true); 1257 } 1258 1259 1260 DECLINLINE(void) tstASMAtomicXchgU16Worker(uint16_t volatile *pu16) 1261 { 1262 *pu16 = 0; 1263 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, 1), 0, 1); 1264 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, 0), 1, 0); 1265 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, UINT16_MAX), 0, UINT16_MAX); 1266 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, UINT16_C(0x7fff)), UINT16_MAX, UINT16_C(0x7fff)); 1267 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, UINT16_C(0x8765)), UINT16_C(0x7fff), UINT16_C(0x8765)); 1268 CHECK_OP_AND_VAL(uint16_t, "%#x", pu16, ASMAtomicXchgU16(pu16, UINT16_C(0xfffe)), UINT16_C(0x8765), UINT16_C(0xfffe)); 1269 1270 int16_t volatile *pi16 = (int16_t volatile *)pu16; 1271 CHECK_OP_AND_VAL(int16_t, "%d", pi16, ASMAtomicXchgS16(pi16, INT16_MIN), INT16_C(-2), INT16_MIN); 1272 CHECK_OP_AND_VAL(int16_t, "%d", pi16, ASMAtomicXchgS16(pi16, INT16_MAX), INT16_MIN, INT16_MAX); 1273 CHECK_OP_AND_VAL(int16_t, "%d", pi16, ASMAtomicXchgS16(pi16, -8), INT16_MAX, -8); 1274 CHECK_OP_AND_VAL(int16_t, "%d", pi16, ASMAtomicXchgS16(pi16, 8), -8, 8); 1275 } 1276 1277 1278 DECLINLINE(void) tstASMAtomicXchgU32Worker(uint32_t volatile *pu32) 1279 { 1280 *pu32 = 0; 1281 CHECK_OP_AND_VAL(uint32_t, "%#x", pu32, ASMAtomicXchgU32(pu32, 1), 0, 1); 1282 CHECK_OP_AND_VAL(uint32_t, "%#x", pu32, ASMAtomicXchgU32(pu32, 0), 1, 0); 1283 CHECK_OP_AND_VAL(uint32_t, "%#x", pu32, ASMAtomicXchgU32(pu32, UINT32_MAX), 0, UINT32_MAX); 1284 CHECK_OP_AND_VAL(uint32_t, "%#x", pu32, ASMAtomicXchgU32(pu32, UINT32_C(0x87654321)), UINT32_MAX, UINT32_C(0x87654321)); 1285 CHECK_OP_AND_VAL(uint32_t, "%#x", pu32, ASMAtomicXchgU32(pu32, UINT32_C(0xfffffffe)), UINT32_C(0x87654321), UINT32_C(0xfffffffe)); 1286 1287 int32_t volatile *pi32 = (int32_t volatile *)pu32; 1288 CHECK_OP_AND_VAL(int32_t, "%d", pi32, ASMAtomicXchgS32(pi32, INT32_MIN), INT32_C(-2), INT32_MIN); 1289 CHECK_OP_AND_VAL(int32_t, "%d", pi32, ASMAtomicXchgS32(pi32, INT32_MAX), INT32_MIN, INT32_MAX); 1290 CHECK_OP_AND_VAL(int32_t, "%d", pi32, ASMAtomicXchgS32(pi32, -16), INT32_MAX, -16); 1291 CHECK_OP_AND_VAL(int32_t, "%d", pi32, ASMAtomicXchgS32(pi32, 16), -16, 16); 1292 1293 #if ARCH_BITS == 32 1294 size_t volatile *pcb = (size_t volatile *)pu32; 1295 CHECK_OP_AND_VAL(size_t, "%#zx", pcb, ASMAtomicXchgZ(pcb, UINT32_C(0x9481239b)), 0x10, UINT32_C(0x9481239b)); 1296 CHECK_OP_AND_VAL(size_t, "%#zx", pcb, ASMAtomicXchgZ(pcb, UINT32_C(0xcdef1234)), UINT32_C(0x9481239b), UINT32_C(0xcdef1234)); 1297 #endif 1298 1299 #if R0_ARCH_BITS == 32 1300 RTR0PTR volatile *pR0Ptr = (RTR0PTR volatile *)pu32; 1301 CHECK_OP_AND_VAL(size_t, "%#llx", pcb, ASMAtomicXchgR0Ptr(pR0Ptr, UINT32_C(0x80341237)), UINT32_C(0xcdef1234), UINT32_C(0x80341237)); 1302 #endif 1303 } 1304 1305 1306 DECLINLINE(void) tstASMAtomicXchgU64Worker(uint64_t volatile *pu64) 1307 { 1308 *pu64 = 0; 1309 CHECK_OP_AND_VAL(uint64_t, "%#llx", pu64, ASMAtomicXchgU64(pu64, 1), 0, 1); 1310 CHECK_OP_AND_VAL(uint64_t, "%#llx", pu64, ASMAtomicXchgU64(pu64, 0), 1, 0); 1311 CHECK_OP_AND_VAL(uint64_t, "%#llx", pu64, ASMAtomicXchgU64(pu64, UINT64_MAX), 0, UINT64_MAX); 1312 CHECK_OP_AND_VAL(uint64_t, "%#llx", pu64, ASMAtomicXchgU64(pu64, UINT64_C(0xfedcba0987654321)), UINT64_MAX, UINT64_C(0xfedcba0987654321)); 1313 CHECK_OP_AND_VAL(uint64_t, "%#llx", pu64, ASMAtomicXchgU64(pu64, UINT64_C(0xfffffffffffffffe)), UINT64_C(0xfedcba0987654321), UINT64_C(0xfffffffffffffffe)); 1314 1315 int64_t volatile *pi64 = (int64_t volatile *)pu64; 1316 CHECK_OP_AND_VAL(int64_t, "%lld", pi64, ASMAtomicXchgS64(pi64, INT64_MAX), -2, INT64_MAX); 1317 CHECK_OP_AND_VAL(int64_t, "%lld", pi64, ASMAtomicXchgS64(pi64, INT64_MIN), INT64_MAX, INT64_MIN); 1318 CHECK_OP_AND_VAL(int64_t, "%lld", pi64, ASMAtomicXchgS64(pi64, -32), INT64_MIN, -32); 1319 CHECK_OP_AND_VAL(int64_t, "%lld", pi64, ASMAtomicXchgS64(pi64, 32), -32, 32); 1320 1321 #if ARCH_BITS == 64 1322 size_t volatile *pcb = (size_t volatile *)pu64; 1323 CHECK_OP_AND_VAL(size_t, "%#zx", pcb, ASMAtomicXchgZ(pcb, UINT64_C(0x94812396759)), 0x20, UINT64_C(0x94812396759)); 1324 CHECK_OP_AND_VAL(size_t, "%#zx", pcb, ASMAtomicXchgZ(pcb, UINT64_C(0xcdef1234abdf7896)), UINT64_C(0x94812396759), UINT64_C(0xcdef1234abdf7896)); 1325 #endif 1326 1327 #if R0_ARCH_BITS == 64 1328 RTR0PTR volatile *pR0Ptr = (RTR0PTR volatile *)pu64; 1329 CHECK_OP_AND_VAL(size_t, "%#llx", pcb, ASMAtomicXchgR0Ptr(pR0Ptr, UINT64_C(0xfedc1234567890ab)), UINT64_C(0xcdef1234abdf7896), UINT64_C(0xfedc1234567890ab)); 1330 #endif 1331 } 1332 1333 1334 DECLINLINE(void) tstASMAtomicXchgPtrWorker(void * volatile *ppv) 1335 { 1336 *ppv = NULL; 1337 CHECK_OP_AND_VAL(void *, "%p", ppv, ASMAtomicXchgPtr(ppv, (void *)(~(uintptr_t)0)), NULL, (void *)(~(uintptr_t)0)); 1338 CHECK_OP_AND_VAL(void *, "%p", ppv, ASMAtomicXchgPtr(ppv, (void *)(~(uintptr_t)0x87654321)), (void *)(~(uintptr_t)0), (void *)(~(uintptr_t)0x87654321)); 1339 CHECK_OP_AND_VAL(void *, "%p", ppv, ASMAtomicXchgPtr(ppv, NULL), (void *)(~(uintptr_t)0x87654321), NULL); 1340 1341 CHECK_OP_AND_VAL(void *, "%p", ppv, ASMAtomicXchgR3Ptr(ppv, (void *)ppv), NULL, (void *)ppv); 1342 1343 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)ppv; 1344 RTSEMEVENT hRet; 1345 ASMAtomicXchgHandle(phEvt, (RTSEMEVENT)(~(uintptr_t)12345), &hRet); 1346 CHECKVAL(hRet, (RTSEMEVENT)ppv, "%p"); 1347 CHECKVAL(*phEvt, (RTSEMEVENT)(~(uintptr_t)12345), "%p"); 1348 } 1349 1350 1351 static void tstASMAtomicXchg(void) 717 1352 { 718 1353 DO_SIMPLE_TEST(ASMAtomicXchgU8, uint8_t); 719 }720 721 722 DECLINLINE(void) tstASMAtomicXchgU16Worker(uint16_t volatile *pu16)723 {724 *pu16 = 0;725 726 CHECKOP(ASMAtomicXchgU16(pu16, 1), 0, "%#x", uint16_t);727 CHECKVAL(*pu16, 1, "%#x");728 729 CHECKOP(ASMAtomicXchgU16(pu16, 0), 1, "%#x", uint16_t);730 CHECKVAL(*pu16, 0, "%#x");731 732 CHECKOP(ASMAtomicXchgU16(pu16, 0xffff), 0, "%#x", uint16_t);733 CHECKVAL(*pu16, 0xffff, "%#x");734 735 CHECKOP(ASMAtomicXchgU16(pu16, 0x8765), 0xffff, "%#x", uint16_t);736 CHECKVAL(*pu16, 0x8765, "%#x");737 }738 739 740 static void tstASMAtomicXchgU16(void)741 {742 1354 DO_SIMPLE_TEST(ASMAtomicXchgU16, uint16_t); 743 }744 745 746 DECLINLINE(void) tstASMAtomicXchgU32Worker(uint32_t volatile *pu32)747 {748 *pu32 = 0;749 750 CHECKOP(ASMAtomicXchgU32(pu32, 1), 0, "%#x", uint32_t);751 CHECKVAL(*pu32, 1, "%#x");752 753 CHECKOP(ASMAtomicXchgU32(pu32, 0), 1, "%#x", uint32_t);754 CHECKVAL(*pu32, 0, "%#x");755 756 CHECKOP(ASMAtomicXchgU32(pu32, ~UINT32_C(0)), 0, "%#x", uint32_t);757 CHECKVAL(*pu32, ~UINT32_C(0), "%#x");758 759 CHECKOP(ASMAtomicXchgU32(pu32, 0x87654321), ~UINT32_C(0), "%#x", uint32_t);760 CHECKVAL(*pu32, 0x87654321, "%#x");761 }762 763 764 static void tstASMAtomicXchgU32(void)765 {766 1355 DO_SIMPLE_TEST(ASMAtomicXchgU32, uint32_t); 767 }768 769 770 DECLINLINE(void) tstASMAtomicXchgU64Worker(uint64_t volatile *pu64)771 {772 *pu64 = 0;773 774 CHECKOP(ASMAtomicXchgU64(pu64, 1), UINT64_C(0), "%#llx", uint64_t);775 CHECKVAL(*pu64, UINT64_C(1), "%#llx");776 777 CHECKOP(ASMAtomicXchgU64(pu64, 0), UINT64_C(1), "%#llx", uint64_t);778 CHECKVAL(*pu64, UINT64_C(0), "%#llx");779 780 CHECKOP(ASMAtomicXchgU64(pu64, ~UINT64_C(0)), UINT64_C(0), "%#llx", uint64_t);781 CHECKVAL(*pu64, ~UINT64_C(0), "%#llx");782 783 CHECKOP(ASMAtomicXchgU64(pu64, UINT64_C(0xfedcba0987654321)), ~UINT64_C(0), "%#llx", uint64_t);784 CHECKVAL(*pu64, UINT64_C(0xfedcba0987654321), "%#llx");785 }786 787 788 static void tstASMAtomicXchgU64(void)789 {790 1356 DO_SIMPLE_TEST(ASMAtomicXchgU64, uint64_t); 791 }792 793 794 DECLINLINE(void) tstASMAtomicXchgPtrWorker(void * volatile *ppv)795 {796 *ppv = NULL;797 798 CHECKOP(ASMAtomicXchgPtr(ppv, (void *)(~(uintptr_t)0)), NULL, "%p", void *);799 CHECKVAL(*ppv, (void *)(~(uintptr_t)0), "%p");800 801 CHECKOP(ASMAtomicXchgPtr(ppv, (void *)(uintptr_t)0x87654321), (void *)(~(uintptr_t)0), "%p", void *);802 CHECKVAL(*ppv, (void *)(uintptr_t)0x87654321, "%p");803 804 CHECKOP(ASMAtomicXchgPtr(ppv, NULL), (void *)(uintptr_t)0x87654321, "%p", void *);805 CHECKVAL(*ppv, NULL, "%p");806 }807 808 809 static void tstASMAtomicXchgPtr(void)810 {811 1357 DO_SIMPLE_TEST(ASMAtomicXchgPtr, void *); 812 1358 } … … 816 1362 { 817 1363 *pu8 = 0xff; 818 819 CHECKOP(ASMAtomicCmpXchgU8(pu8, 0, 0), false, "%d", bool); 820 CHECKVAL(*pu8, 0xff, "%x"); 821 822 CHECKOP(ASMAtomicCmpXchgU8(pu8, 0, 0xff), true, "%d", bool); 823 CHECKVAL(*pu8, 0, "%x"); 824 825 CHECKOP(ASMAtomicCmpXchgU8(pu8, 0x79, 0xff), false, "%d", bool); 826 CHECKVAL(*pu8, 0, "%x"); 827 828 CHECKOP(ASMAtomicCmpXchgU8(pu8, 0x97, 0), true, "%d", bool); 829 CHECKVAL(*pu8, 0x97, "%x"); 830 } 831 832 833 static void tstASMAtomicCmpXchgU8(void) 1364 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu8, ASMAtomicCmpXchgU8(pu8, 0, 0), false, 0xff); 1365 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu8, ASMAtomicCmpXchgU8(pu8, 0, 0xff), true, 0); 1366 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu8, ASMAtomicCmpXchgU8(pu8, 0x97, 0), true, 0x97); 1367 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu8, ASMAtomicCmpXchgU8(pu8, 0x97, 0), false, 0x97); 1368 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu8, ASMAtomicCmpXchgU8(pu8, 0x7f, 0x97), true, 0x7f); 1369 1370 int8_t volatile *pi8 = (int8_t volatile *)pu8; 1371 CHECK_OP_AND_VAL(bool, "%d", pi8, ASMAtomicCmpXchgS8(pi8, -2, 0x7f), true, -2); 1372 CHECK_OP_AND_VAL(bool, "%d", pi8, ASMAtomicCmpXchgS8(pi8, INT8_MAX, -2), true, INT8_MAX); 1373 CHECK_OP_AND_VAL(bool, "%d", pi8, ASMAtomicCmpXchgS8(pi8, INT8_MAX, INT8_MIN), false, INT8_MAX); 1374 CHECK_OP_AND_VAL(bool, "%d", pi8, ASMAtomicCmpXchgS8(pi8, INT8_MIN, INT8_MAX), true, INT8_MIN); 1375 CHECK_OP_AND_VAL(bool, "%d", pi8, ASMAtomicCmpXchgS8(pi8, 1, INT8_MIN), true, 1); 1376 1377 bool volatile *pf = (bool volatile *)pu8; 1378 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicCmpXchgBool(pf, true, true), true, true); 1379 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicCmpXchgBool(pf, false, true), true, false); 1380 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicCmpXchgBool(pf, false, true), false, false); 1381 CHECK_OP_AND_VAL(bool, "%d", pf, ASMAtomicCmpXchgBool(pf, false, false), true, false); 1382 } 1383 1384 1385 DECLINLINE(void) tstASMAtomicCmpXchgU32Worker(uint32_t volatile *pu32) 1386 { 1387 *pu32 = UINT32_C(0xffffffff); 1388 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu32, ASMAtomicCmpXchgU32(pu32, 0, 0), false, UINT32_C(0xffffffff)); 1389 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu32, ASMAtomicCmpXchgU32(pu32, 0, UINT32_C(0xffffffff)), true, 0); 1390 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu32, ASMAtomicCmpXchgU32(pu32, UINT32_C(0x80088efd), UINT32_C(0x12345678)), false, 0); 1391 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu32, ASMAtomicCmpXchgU32(pu32, UINT32_C(0x80088efd), 0), true, UINT32_C(0x80088efd)); 1392 CHECK_OP_AND_VAL_EX(bool, "%d", "%#x", pu32, ASMAtomicCmpXchgU32(pu32, UINT32_C(0xfffffffe), UINT32_C(0x80088efd)), true, UINT32_C(0xfffffffe)); 1393 1394 int32_t volatile *pi32 = (int32_t volatile *)pu32; 1395 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, INT32_MIN, 2), false, -2); 1396 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, INT32_MIN, -2), true, INT32_MIN); 1397 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, -19, -2), false, INT32_MIN); 1398 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, -19, INT32_MIN), true, -19); 1399 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, -19, INT32_MIN), false, -19); 1400 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, 19, -19), true, 19); 1401 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, INT32_MAX, -234), false, 19); 1402 CHECK_OP_AND_VAL_EX(bool, "%d", "%d", pi32, ASMAtomicCmpXchgS32(pi32, INT32_MAX, 19), true, INT32_MAX); 1403 1404 #if ARCH_BITS == 32 1405 void * volatile *ppv = (void * volatile *)pu64; 1406 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)-29), false, (void *)(intptr_t)29); 1407 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)29), true, NULL); 1408 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)29), false, NULL); 1409 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, (void *)~(uintptr_t)42, NULL), true, (void *)~(uintptr_t)42); 1410 1411 bool fRc; 1412 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 1413 ASMAtomicCmpXchgHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, (RTSEMEVENT)NULL, fRc); 1414 CHECKVAL(fRc, false, "%d"); 1415 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 1416 1417 ASMAtomicCmpXchgHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, (RTSEMEVENT)~(uintptr_t)42, fRc); 1418 CHECKVAL(fRc, true, "%d"); 1419 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, "%p"); 1420 #endif 1421 } 1422 1423 1424 DECLINLINE(void) tstASMAtomicCmpXchgU64Worker(uint64_t volatile *pu64) 1425 { 1426 *pu64 = UINT64_C(0xffffffffffffff); 1427 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, 0, 0), false, UINT64_C(0xffffffffffffff)); 1428 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, 0, UINT64_C(0xffffffffffffff)), true, 0); 1429 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), 1), false, 0); 1430 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), 0), true, UINT64_C(0x80040008008efd)); 1431 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), 0), false, UINT64_C(0x80040008008efd)); 1432 CHECK_OP_AND_VAL_EX(bool, "%d", "%#llx", pu64, ASMAtomicCmpXchgU64(pu64, UINT64_C(0xfffffffffffffffd), UINT64_C(0x80040008008efd)), true, UINT64_C(0xfffffffffffffffd)); 1433 1434 int64_t volatile *pi64 = (int64_t volatile *)pu64; 1435 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, INT64_MAX, 0), false, -3); 1436 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, INT64_MAX, -3), true, INT64_MAX); 1437 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, INT64_MIN, INT64_MIN), false, INT64_MAX); 1438 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, INT64_MIN, INT64_MAX), true, INT64_MIN); 1439 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, -29, -29), false, INT64_MIN); 1440 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, -29, INT64_MIN), true, -29); 1441 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, -29, INT64_MIN), false, -29); 1442 CHECK_OP_AND_VAL_EX(bool, "%d", "%#lld", pi64, ASMAtomicCmpXchgS64(pi64, 29, -29), true, 29); 1443 1444 #if ARCH_BITS == 64 1445 void * volatile *ppv = (void * volatile *)pu64; 1446 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)-29), false, (void *)(intptr_t)29); 1447 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)29), true, NULL); 1448 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, NULL, (void *)(intptr_t)29), false, NULL); 1449 CHECK_OP_AND_VAL_EX(bool, "%d", "%p", ppv, ASMAtomicCmpXchgPtrVoid(ppv, (void *)~(uintptr_t)42, NULL), true, (void *)~(uintptr_t)42); 1450 1451 bool fRc; 1452 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 1453 ASMAtomicCmpXchgHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, (RTSEMEVENT)NULL, fRc); 1454 CHECKVAL(fRc, false, "%d"); 1455 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)42, "%p"); 1456 1457 ASMAtomicCmpXchgHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, (RTSEMEVENT)~(uintptr_t)42, fRc); 1458 CHECKVAL(fRc, true, "%d"); 1459 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)0x12356389, "%p"); 1460 #endif 1461 } 1462 1463 1464 static void tstASMAtomicCmpXchg(void) 834 1465 { 835 1466 DO_SIMPLE_TEST(ASMAtomicCmpXchgU8, uint8_t); 836 }837 838 839 DECLINLINE(void) tstASMAtomicCmpXchgU32Worker(uint32_t volatile *pu32)840 {841 *pu32 = UINT32_C(0xffffffff);842 843 CHECKOP(ASMAtomicCmpXchgU32(pu32, 0, 0), false, "%d", bool);844 CHECKVAL(*pu32, UINT32_C(0xffffffff), "%x");845 846 CHECKOP(ASMAtomicCmpXchgU32(pu32, 0, UINT32_C(0xffffffff)), true, "%d", bool);847 CHECKVAL(*pu32, 0, "%x");848 849 CHECKOP(ASMAtomicCmpXchgU32(pu32, UINT32_C(0x8008efd), UINT32_C(0xffffffff)), false, "%d", bool);850 CHECKVAL(*pu32, 0, "%x");851 852 CHECKOP(ASMAtomicCmpXchgU32(pu32, UINT32_C(0x8008efd), 0), true, "%d", bool);853 CHECKVAL(*pu32, UINT32_C(0x8008efd), "%x");854 }855 856 857 static void tstASMAtomicCmpXchgU32(void)858 {859 1467 DO_SIMPLE_TEST(ASMAtomicCmpXchgU32, uint32_t); 860 }861 862 863 864 DECLINLINE(void) tstASMAtomicCmpXchgU64Worker(uint64_t volatile *pu64)865 {866 *pu64 = UINT64_C(0xffffffffffffff);867 868 CHECKOP(ASMAtomicCmpXchgU64(pu64, 0, 0), false, "%d", bool);869 CHECKVAL(*pu64, UINT64_C(0xffffffffffffff), "%#llx");870 871 CHECKOP(ASMAtomicCmpXchgU64(pu64, 0, UINT64_C(0xffffffffffffff)), true, "%d", bool);872 CHECKVAL(*pu64, 0, "%x");873 874 CHECKOP(ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), UINT64_C(0xffffffff)), false, "%d", bool);875 CHECKVAL(*pu64, 0, "%x");876 877 CHECKOP(ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), UINT64_C(0xffffffff00000000)), false, "%d", bool);878 CHECKVAL(*pu64, 0, "%x");879 880 CHECKOP(ASMAtomicCmpXchgU64(pu64, UINT64_C(0x80040008008efd), 0), true, "%d", bool);881 CHECKVAL(*pu64, UINT64_C(0x80040008008efd), "%#llx");882 }883 884 885 static void tstASMAtomicCmpXchgU64(void)886 {887 1468 DO_SIMPLE_TEST(ASMAtomicCmpXchgU64, uint64_t); 888 1469 } … … 893 1474 *pu32 = UINT32_C(0xffffffff); 894 1475 uint32_t u32Old = UINT32_C(0x80005111); 895 896 CHECKOP(ASMAtomicCmpXchgExU32(pu32, 0, 0, &u32Old), false, "%d", bool); 897 CHECKVAL(*pu32, UINT32_C(0xffffffff), "%x"); 898 CHECKVAL(u32Old, UINT32_C(0xffffffff), "%x"); 899 900 CHECKOP(ASMAtomicCmpXchgExU32(pu32, 0, UINT32_C(0xffffffff), &u32Old), true, "%d", bool); 901 CHECKVAL(*pu32, 0, "%x"); 902 CHECKVAL(u32Old, UINT32_C(0xffffffff), "%x"); 903 904 CHECKOP(ASMAtomicCmpXchgExU32(pu32, UINT32_C(0x8008efd), UINT32_C(0xffffffff), &u32Old), false, "%d", bool); 905 CHECKVAL(*pu32, 0, "%x"); 906 CHECKVAL(u32Old, 0, "%x"); 907 908 CHECKOP(ASMAtomicCmpXchgExU32(pu32, UINT32_C(0x8008efd), 0, &u32Old), true, "%d", bool); 909 CHECKVAL(*pu32, UINT32_C(0x8008efd), "%x"); 910 CHECKVAL(u32Old, 0, "%x"); 911 912 CHECKOP(ASMAtomicCmpXchgExU32(pu32, 0, UINT32_C(0x8008efd), &u32Old), true, "%d", bool); 913 CHECKVAL(*pu32, 0, "%x"); 914 CHECKVAL(u32Old, UINT32_C(0x8008efd), "%x"); 915 } 916 917 918 static void tstASMAtomicCmpXchgExU32(void) 919 { 920 DO_SIMPLE_TEST(ASMAtomicCmpXchgExU32, uint32_t); 1476 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, 0, 0, &u32Old), false, UINT32_C(0xffffffff), UINT32_C(0xffffffff)); 1477 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, 0, UINT32_C(0xffffffff), &u32Old), true, 0, UINT32_C(0xffffffff)); 1478 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, 0, UINT32_C(0xffffffff), &u32Old), false, 0, UINT32_C(0x00000000)); 1479 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, UINT32_C(0x80088efd), 0, &u32Old), true, UINT32_C(0x80088efd), 0); 1480 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, UINT32_C(0x80088efd), 0, &u32Old), false, UINT32_C(0x80088efd), UINT32_C(0x80088efd)); 1481 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#x", pu32, u32Old, ASMAtomicCmpXchgExU32(pu32, UINT32_C(0xffffffe0), UINT32_C(0x80088efd), &u32Old), true, UINT32_C(0xffffffe0), UINT32_C(0x80088efd)); 1482 1483 int32_t volatile *pi32 = (int32_t volatile *)pu32; 1484 int32_t i32Old = 0; 1485 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, 32, 32, &i32Old), false, -32, -32); 1486 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, 32, -32, &i32Old), true, 32, -32); 1487 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, INT32_MIN, 32, &i32Old), true, INT32_MIN, 32); 1488 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, INT32_MIN, 32, &i32Old), false, INT32_MIN, INT32_MIN); 1489 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, INT32_MAX, INT32_MAX, &i32Old), false, INT32_MIN, INT32_MIN); 1490 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, INT32_MAX, INT32_MIN, &i32Old), true, INT32_MAX, INT32_MIN); 1491 CHECK_OP_AND_VAL_EX2(bool, "%d", "%d", pi32, i32Old, ASMAtomicCmpXchgExS32(pi32, 42, INT32_MAX, &i32Old), true, 42, INT32_MAX); 1492 1493 #if ARCH_BITS == 32 1494 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu32; 1495 RTSEMEVENT hEvtOld = (RTSEMEVENT)~(uintptr_t)31; 1496 bool fRc = true; 1497 ASMAtomicCmpXchgExHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, (RTSEMEVENT)~(uintptr_t)0, fRc, &hEvtOld); 1498 CHECKVAL(fRc, false, "%d"); 1499 CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)42, "%p"); 1500 CHECKVAL(hEvtOld, (RTSEMEVENT)(uintptr_t)42, "%p"); 1501 1502 ASMAtomicCmpXchgExHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, (RTSEMEVENT)(uintptr_t)42, fRc, &hEvtOld); 1503 CHECKVAL(fRc, true, "%d"); 1504 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, "%p"); 1505 CHECKVAL(hEvtOld, (RTSEMEVENT)(uintptr_t)42, "%p"); 1506 #endif 921 1507 } 922 1508 … … 926 1512 *pu64 = UINT64_C(0xffffffffffffffff); 927 1513 uint64_t u64Old = UINT64_C(0x8000000051111111); 928 929 CHECKOP(ASMAtomicCmpXchgExU64(pu64, 0, 0, &u64Old), false, "%d", bool); 930 CHECKVAL(*pu64, UINT64_C(0xffffffffffffffff), "%llx"); 931 CHECKVAL(u64Old, UINT64_C(0xffffffffffffffff), "%llx"); 932 933 CHECKOP(ASMAtomicCmpXchgExU64(pu64, 0, UINT64_C(0xffffffffffffffff), &u64Old), true, "%d", bool); 934 CHECKVAL(*pu64, UINT64_C(0), "%llx"); 935 CHECKVAL(u64Old, UINT64_C(0xffffffffffffffff), "%llx"); 936 937 CHECKOP(ASMAtomicCmpXchgExU64(pu64, UINT64_C(0x80040008008efd), 0xffffffff, &u64Old), false, "%d", bool); 938 CHECKVAL(*pu64, UINT64_C(0), "%llx"); 939 CHECKVAL(u64Old, UINT64_C(0), "%llx"); 940 941 CHECKOP(ASMAtomicCmpXchgExU64(pu64, UINT64_C(0x80040008008efd), UINT64_C(0xffffffff00000000), &u64Old), false, "%d", bool); 942 CHECKVAL(*pu64, UINT64_C(0), "%llx"); 943 CHECKVAL(u64Old, UINT64_C(0), "%llx"); 944 945 CHECKOP(ASMAtomicCmpXchgExU64(pu64, UINT64_C(0x80040008008efd), 0, &u64Old), true, "%d", bool); 946 CHECKVAL(*pu64, UINT64_C(0x80040008008efd), "%llx"); 947 CHECKVAL(u64Old, UINT64_C(0), "%llx"); 948 949 CHECKOP(ASMAtomicCmpXchgExU64(pu64, 0, UINT64_C(0x80040008008efd), &u64Old), true, "%d", bool); 950 CHECKVAL(*pu64, UINT64_C(0), "%llx"); 951 CHECKVAL(u64Old, UINT64_C(0x80040008008efd), "%llx"); 952 } 953 954 955 static void tstASMAtomicCmpXchgExU64(void) 956 { 1514 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#llx", pu64, u64Old, ASMAtomicCmpXchgExU64(pu64, 0, 0, &u64Old), false, UINT64_C(0xffffffffffffffff), UINT64_C(0xffffffffffffffff)); 1515 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#llx", pu64, u64Old, ASMAtomicCmpXchgExU64(pu64, 0, UINT64_C(0xffffffffffffffff), &u64Old), true, 0, UINT64_C(0xffffffffffffffff)); 1516 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#llx", pu64, u64Old, ASMAtomicCmpXchgExU64(pu64, UINT64_C(0x0080040008008efd), 0x342, &u64Old), false, 0, 0); 1517 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#llx", pu64, u64Old, ASMAtomicCmpXchgExU64(pu64, UINT64_C(0x0080040008008efd), 0, &u64Old), true, UINT64_C(0x0080040008008efd), 0); 1518 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#llx", pu64, u64Old, ASMAtomicCmpXchgExU64(pu64, UINT64_C(0xffffffffffffffc0), UINT64_C(0x0080040008008efd), &u64Old), true, UINT64_C(0xffffffffffffffc0), UINT64_C(0x0080040008008efd)); 1519 1520 int64_t volatile *pi64 = (int64_t volatile *)pu64; 1521 int64_t i64Old = -3; 1522 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, 64, 64, &i64Old), false, -64, -64); 1523 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, 64, -64, &i64Old), true, 64, -64); 1524 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, 64, -64, &i64Old), false, 64, 64); 1525 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, INT64_MIN, -64, &i64Old), false, 64, 64); 1526 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, INT64_MIN, 64, &i64Old), true, INT64_MIN, 64); 1527 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, INT64_MAX, INT64_MIN, &i64Old), true, INT64_MAX, INT64_MIN); 1528 CHECK_OP_AND_VAL_EX2(bool, "%d", "%#lld", pi64, i64Old, ASMAtomicCmpXchgExS64(pi64, 42, INT64_MAX, &i64Old), true, 42, INT64_MAX); 1529 1530 #if ARCH_BITS == 64 1531 RTSEMEVENT volatile *phEvt = (RTSEMEVENT volatile *)pu64; 1532 RTSEMEVENT hEvtOld = (RTSEMEVENT)~(uintptr_t)31; 1533 bool fRc = true; 1534 ASMAtomicCmpXchgExHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, (RTSEMEVENT)~(uintptr_t)0, fRc, &hEvtOld); 1535 CHECKVAL(fRc, false, "%d"); 1536 CHECKVAL(*phEvt, (RTSEMEVENT)(uintptr_t)42, "%p"); 1537 CHECKVAL(hEvtOld, (RTSEMEVENT)(uintptr_t)42, "%p"); 1538 1539 ASMAtomicCmpXchgExHandle(phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, (RTSEMEVENT)(uintptr_t)42, fRc, &hEvtOld); 1540 CHECKVAL(fRc, true, "%d"); 1541 CHECKVAL(*phEvt, (RTSEMEVENT)~(uintptr_t)0x12380964, "%p"); 1542 CHECKVAL(hEvtOld, (RTSEMEVENT)(uintptr_t)42, "%p"); 1543 1544 void * volatile *ppv = (void * volatile *)pu64; 1545 void *pvOld; 1546 CHECK_OP_AND_VAL_EX2(bool, "%d", "%p", ppv, pvOld, ASMAtomicCmpXchgExPtrVoid(ppv, (void *)(intptr_t)12345678, NULL, &pvOld), false, (void *)~(uintptr_t)0x12380964, (void *)~(uintptr_t)0x12380964); 1547 CHECK_OP_AND_VAL_EX2(bool, "%d", "%p", ppv, pvOld, ASMAtomicCmpXchgExPtrVoid(ppv, (void *)(intptr_t)12345678, (void *)~(uintptr_t)0x12380964, &pvOld), true, (void *)(intptr_t)12345678, (void *)~(uintptr_t)0x12380964); 1548 1549 CHECK_OP_AND_VAL_EX2(bool, "%d", "%p", ppv, pvOld, ASMAtomicCmpXchgExPtr(ppv, (void *)~(uintptr_t)99, (void *)~(uintptr_t)99, &pvOld), false, (void *)(intptr_t)12345678, (void *)(intptr_t)12345678); 1550 CHECK_OP_AND_VAL_EX2(bool, "%d", "%p", ppv, pvOld, ASMAtomicCmpXchgExPtr(ppv, (void *)~(uintptr_t)99, (void *)(intptr_t)12345678, &pvOld), true, (void *)~(intptr_t)99, (void *)(intptr_t)12345678); 1551 #endif 1552 } 1553 1554 1555 static void tstASMAtomicCmpXchgEx(void) 1556 { 1557 DO_SIMPLE_TEST(ASMAtomicCmpXchgExU32, uint32_t); 957 1558 DO_SIMPLE_TEST(ASMAtomicCmpXchgExU64, uint64_t); 958 }959 960 961 DECLINLINE(void) tstASMAtomicReadU64Worker(uint64_t volatile *pu64)962 {963 *pu64 = 0;964 965 CHECKOP(ASMAtomicReadU64(pu64), UINT64_C(0), "%#llx", uint64_t);966 CHECKVAL(*pu64, UINT64_C(0), "%#llx");967 968 *pu64 = ~UINT64_C(0);969 CHECKOP(ASMAtomicReadU64(pu64), ~UINT64_C(0), "%#llx", uint64_t);970 CHECKVAL(*pu64, ~UINT64_C(0), "%#llx");971 972 *pu64 = UINT64_C(0xfedcba0987654321);973 CHECKOP(ASMAtomicReadU64(pu64), UINT64_C(0xfedcba0987654321), "%#llx", uint64_t);974 CHECKVAL(*pu64, UINT64_C(0xfedcba0987654321), "%#llx");975 }976 977 978 static void tstASMAtomicReadU64(void)979 {980 DO_SIMPLE_TEST(ASMAtomicReadU64, uint64_t);981 }982 983 984 DECLINLINE(void) tstASMAtomicUoReadU64Worker(uint64_t volatile *pu64)985 {986 *pu64 = 0;987 988 CHECKOP(ASMAtomicUoReadU64(pu64), UINT64_C(0), "%#llx", uint64_t);989 CHECKVAL(*pu64, UINT64_C(0), "%#llx");990 991 *pu64 = ~UINT64_C(0);992 CHECKOP(ASMAtomicUoReadU64(pu64), ~UINT64_C(0), "%#llx", uint64_t);993 CHECKVAL(*pu64, ~UINT64_C(0), "%#llx");994 995 *pu64 = UINT64_C(0xfedcba0987654321);996 CHECKOP(ASMAtomicUoReadU64(pu64), UINT64_C(0xfedcba0987654321), "%#llx", uint64_t);997 CHECKVAL(*pu64, UINT64_C(0xfedcba0987654321), "%#llx");998 }999 1000 1001 static void tstASMAtomicUoReadU64(void)1002 {1003 DO_SIMPLE_TEST(ASMAtomicUoReadU64, uint64_t);1004 1559 } 1005 1560 … … 1625 2180 1626 2181 2182 void tstASMMisc(void) 2183 { 2184 RTTestSub(g_hTest, "Misc"); 2185 for (uint32_t i = 0; i < 20; i++) 2186 { 2187 ASMWriteFence(); 2188 ASMCompilerBarrier(); 2189 ASMReadFence(); 2190 ASMNopPause(); 2191 ASMSerializeInstruction(); 2192 ASMMemoryFence(); 2193 } 2194 } 1627 2195 1628 2196 void tstASMMath(void) … … 1916 2484 BENCH_TSC(ASMSerializeInstructionIRet(), "ASMSerializeInstructionIRet"); 1917 2485 #endif 2486 BENCH(ASMReadFence(), "ASMReadFence"); 2487 BENCH(ASMWriteFence(), "ASMWriteFence"); 2488 BENCH(ASMMemoryFence(), "ASMMemoryFence"); 2489 BENCH(ASMSerializeInstruction(), "ASMSerializeInstruction"); 2490 BENCH(ASMNopPause(), "ASMNopPause"); 1918 2491 1919 2492 /* The Darwin gcc does not like this ... */ … … 1970 2543 #endif 1971 2544 #if 1 1972 tstASMAtomicXchgU8(); 1973 tstASMAtomicXchgU16(); 1974 tstASMAtomicXchgU32(); 1975 tstASMAtomicXchgU64(); 1976 tstASMAtomicXchgPtr(); 1977 tstASMAtomicCmpXchgU8(); 1978 tstASMAtomicCmpXchgU32(); 1979 tstASMAtomicCmpXchgU64(); 1980 tstASMAtomicCmpXchgExU32(); 1981 tstASMAtomicCmpXchgExU64(); 1982 tstASMAtomicReadU64(); 1983 tstASMAtomicUoReadU64(); 2545 tstASMAtomicRead(); 2546 tstASMAtomicWrite(); 2547 tstASMAtomicXchg(); 2548 tstASMAtomicCmpXchg(); 2549 tstASMAtomicCmpXchgEx(); 1984 2550 1985 2551 tstASMAtomicAddS32(); … … 2000 2566 tstASMMemFill32(); 2001 2567 2568 tstASMMisc(); 2569 2002 2570 tstASMMath(); 2003 2571
Note:
See TracChangeset
for help on using the changeset viewer.