228 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			228 lines
		
	
	
		
			6.3 KiB
		
	
	
	
		
			C
		
	
	
	
| // RUN: %clang_cc1 -ffreestanding -emit-llvm-only  -triple x86_64-windows-coff -fdump-record-layouts %s | FileCheck %s --check-prefix=CHECK-MS
 | |
| // RUN: %clang_cc1 -ffreestanding -emit-llvm-only  -triple x86_64-apple-darwin -fdump-record-layouts %s | FileCheck %s --check-prefix=CHECK-NOTMS
 | |
| #include <x86intrin.h>
 | |
| 
 | |
| #pragma pack(1)
 | |
| 
 | |
| struct s_m64 {
 | |
|   int a;
 | |
|   __m64 b;
 | |
| };
 | |
| typedef struct s_m64 m64;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m64) == 16) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m64) == 12) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m128 {
 | |
|   int a;
 | |
|   __m128 b;
 | |
| };
 | |
| typedef struct s_m128 m128;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m128) == 32) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m128) == 20) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m128i {
 | |
|   int a;
 | |
|   __m128i b;
 | |
| };
 | |
| typedef struct s_m128i m128i;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m128i) == 32) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m128i) == 20) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m128d {
 | |
|   int a;
 | |
|   __m128d b;
 | |
| };
 | |
| typedef struct s_m128d m128d;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m128d) == 32) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m128d) == 20) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m256 {
 | |
|   int a;
 | |
|   __m256 b;
 | |
| };
 | |
| typedef struct s_m256 m256;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m256) == 64) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m256) == 36) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m256i {
 | |
|   int a;
 | |
|   __m256i b;
 | |
| };
 | |
| typedef struct s_m256i m256i;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m256i) == 64) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m256i) == 36) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m256d {
 | |
|   int a;
 | |
|   __m256d b;
 | |
| };
 | |
| typedef struct s_m256d m256d;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m256d) == 64) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m256d) == 36) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m512 {
 | |
|   int a;
 | |
|   __m512 b;
 | |
| };
 | |
| typedef struct s_m512 m512;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m512) == 128) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m512) == 68) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m512i {
 | |
|   int a;
 | |
|   __m512i b;
 | |
| };
 | |
| typedef struct s_m512i m512i;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m512i) == 128) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m512i) == 68) - 1];
 | |
| #endif
 | |
| 
 | |
| struct s_m512d {
 | |
|   int a;
 | |
|   __m512d b;
 | |
| };
 | |
| typedef struct s_m512d m512d;
 | |
| 
 | |
| #if defined(_WIN32)
 | |
| static int a1[(sizeof(m512d) == 128) - 1];
 | |
| #else
 | |
| static int a1[(sizeof(m512d) == 68) - 1];
 | |
| #endif
 | |
| 
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m64
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:          8 |   __m64 b
 | |
| // CHECK-MS:            | [sizeof=16, align=8]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m128
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         16 |   __m128 b
 | |
| // CHECK-MS:            | [sizeof=32, align=16]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m128i
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         16 |   __m128i b
 | |
| // CHECK-MS:            | [sizeof=32, align=16]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m128d
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         16 |   __m128d b
 | |
| // CHECK-MS:            | [sizeof=32, align=16]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m256
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         32 |   __m256 b
 | |
| // CHECK-MS:            | [sizeof=64, align=32]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m256i
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         32 |   __m256i b
 | |
| // CHECK-MS:            | [sizeof=64, align=32]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m256d
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         32 |   __m256d b
 | |
| // CHECK-MS:            | [sizeof=64, align=32]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m512
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         64 |   __m512 b
 | |
| // CHECK-MS:            | [sizeof=128, align=64]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m512i
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         64 |   __m512i b
 | |
| // CHECK-MS:            | [sizeof=128, align=64]
 | |
| // CHECK-MS: *** Dumping AST Record Layout
 | |
| // CHECK-MS:          0 | struct s_m512d
 | |
| // CHECK-MS:          0 |   int a
 | |
| // CHECK-MS:         64 |   __m512d b
 | |
| // CHECK-MS:            | [sizeof=128, align=64]
 | |
| 
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m64
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m64 b
 | |
| // CHECK-NOTMS:            | [sizeof=12, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m128
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m128 b
 | |
| // CHECK-NOTMS:            | [sizeof=20, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m128i
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m128i b
 | |
| // CHECK-NOTMS:            | [sizeof=20, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m128d
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m128d b
 | |
| // CHECK-NOTMS:            | [sizeof=20, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m256
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m256 b
 | |
| // CHECK-NOTMS:            | [sizeof=36, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m256i
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m256i b
 | |
| // CHECK-NOTMS:            | [sizeof=36, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m256d
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m256d b
 | |
| // CHECK-NOTMS:            | [sizeof=36, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m512
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m512 b
 | |
| // CHECK-NOTMS:            | [sizeof=68, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m512i
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m512i b
 | |
| // CHECK-NOTMS:            | [sizeof=68, align=1]
 | |
| // CHECK-NOTMS: *** Dumping AST Record Layout
 | |
| // CHECK-NOTMS:          0 | struct s_m512d
 | |
| // CHECK-NOTMS:          0 |   int a
 | |
| // CHECK-NOTMS:          4 |   __m512d b
 | |
| // CHECK-NOTMS:            | [sizeof=68, align=1]
 |