Home | History | Annotate | Download | only in Mips
      1 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 | \
      2 # RUN:   FileCheck %s -check-prefix=CHECK-ASM
      3 #
      4 # RUN: llvm-mc %s -arch=mips -mcpu=mips32 -filetype=obj -o - | \
      5 # RUN:   llvm-readobj -sections -section-data -section-relocations -mips-abi-flags - | \
      6 # RUN:   FileCheck %s -check-prefixes=CHECK-OBJ,CHECK-OBJ-32R1,CHECK-OBJ-MIPS
      7 
      8 # RUN: llvm-mc /dev/null -arch=mips -mcpu=mips32 -mattr=fpxx -filetype=obj -o - | \
      9 # RUN:   llvm-readobj -sections -section-data -section-relocations -mips-abi-flags - | \
     10 # RUN:   FileCheck %s -check-prefixes=CHECK-OBJ,CHECK-OBJ-32R1,CHECK-OBJ-MIPS
     11 
     12 # RUN: llvm-mc /dev/null -arch=mips -mcpu=mips32r6 -mattr=fpxx -filetype=obj -o - | \
     13 # RUN:   llvm-readobj -sections -section-data -section-relocations -mips-abi-flags - | \
     14 # RUN:   FileCheck %s -check-prefixes=CHECK-OBJ,CHECK-OBJ-32R6,CHECK-OBJ-MIPS
     15 
     16 # RUN: llvm-mc /dev/null -arch=mips -mcpu=octeon -target-abi n64 -filetype=obj -o - | \
     17 # RUN:   llvm-readobj -sections -section-data -section-relocations -mips-abi-flags - | \
     18 # RUN:   FileCheck %s -check-prefixes=CHECK-OBJ,CHECK-OBJ-64R2,CHECK-OBJ-OCTEON
     19 
     20 # CHECK-ASM: .module fp=xx
     21 
     22 # Checking if the Mips.abiflags were correctly emitted.
     23 # CHECK-OBJ:       Section {
     24 # CHECK-OBJ:         Index: 5
     25 # CHECK-OBJ-LABEL:   Name: .MIPS.abiflags
     26 # CHECK-OBJ:         Type: SHT_MIPS_ABIFLAGS (0x7000002A)
     27 # CHECK-OBJ:          Flags [ (0x2)
     28 # CHECK-OBJ:           SHF_ALLOC (0x2)
     29 # CHECK-OBJ:         ]
     30 # CHECK-OBJ:         Address: 0x0
     31 # CHECK-OBJ:         Size: 24
     32 # CHECK-OBJ:         Link: 0
     33 # CHECK-OBJ:         Info: 0
     34 # CHECK-OBJ:         AddressAlignment: 8
     35 # CHECK-OBJ:         EntrySize: 24
     36 # CHECK-OBJ:         Relocations [
     37 # CHECK-OBJ:         ]
     38 # CHECK-OBJ-LABEL: }
     39 # CHECK-OBJ:       MIPS ABI Flags {
     40 # CHECK-OBJ-NEXT:    Version: 0
     41 # CHECK-OBJ-32R1-NEXT: ISA: {{MIPS32$}}
     42 # CHECK-OBJ-32R6-NEXT: ISA: MIPS32r6
     43 # CHECK-OBJ-64R2-NEXT: ISA: MIPS64r2
     44 # CHECK-OBJ-MIPS-NEXT:   ISA Extension: None (0x0)
     45 # CHECK-OBJ-OCTEON-NEXT: ISA Extension: Cavium Networks Octeon (0x5)
     46 # CHECK-OBJ-NEXT:    ASEs [ (0x0)
     47 # CHECK-OBJ-NEXT:    ]
     48 # CHECK-OBJ-32R1-NEXT: FP ABI: Hard float (32-bit CPU, Any FPU) (0x5)
     49 # CHECK-OBJ-32R6-NEXT: FP ABI: Hard float (32-bit CPU, Any FPU) (0x5)
     50 # CHECK-OBJ-64R2-NEXT: FP ABI: Hard float (double precision) (0x1)
     51 # CHECK-OBJ-32R1-NEXT: GPR size: 32
     52 # CHECK-OBJ-32R6-NEXT: GPR size: 32
     53 # CHECK-OBJ-64R2-NEXT: GPR size: 64
     54 # CHECK-OBJ-32R1-NEXT: CPR1 size: 32
     55 # CHECK-OBJ-32R6-NEXT: CPR1 size: 32
     56 # CHECK-OBJ-64R2-NEXT: CPR1 size: 64
     57 # CHECK-OBJ-NEXT:    CPR2 size: 0
     58 # CHECK-OBJ-NEXT:    Flags 1 [ (0x1)
     59 # CHECK-OBJ-NEXT:      ODDSPREG (0x1)
     60 # CHECK-OBJ-NEXT:    ]
     61 # CHECK-OBJ-NEXT:    Flags 2: 0x0
     62 # CHECK-OBJ-NEXT:  }
     63 
     64         .module fp=xx
     65 
     66 # FIXME: Test should include gnu_attributes directive when implemented.
     67 #        An explicit .gnu_attribute must be checked against the effective
     68 #        command line options and any inconsistencies reported via a warning.
     69