llvm/llvm/test/tools/yaml2obj/ELF/DWARF/debug-addr.yaml

## Test that yaml2obj emits .debug_addr section.

## a) Generate and verify a little endian DWARF32 .debug_addr section in a 64-bit object file.

# RUN: yaml2obj --docnum=1 -DENDIAN=ELFDATA2LSB %s -o %t1.dwarf32.le.o
# RUN: llvm-readobj --sections --section-data %t1.dwarf32.le.o | \
# RUN:   FileCheck %s -DSIZE=264 -DADDRALIGN=1 --check-prefixes=SHDR,DWARF32-LE

#            SHDR: Index: 1
#       SHDR-NEXT: Name: .debug_addr (1)
#       SHDR-NEXT: Type: SHT_PROGBITS (0x1)
#       SHDR-NEXT: Flags [ (0x0)
#       SHDR-NEXT: ]
#       SHDR-NEXT: Address: 0x0
#       SHDR-NEXT: Offset: 0x40
#       SHDR-NEXT: Size: [[SIZE]]
#       SHDR-NEXT: Link: 0
#       SHDR-NEXT: Info: 0
#       SHDR-NEXT: AddressAlignment: [[ADDRALIGN]]
#       SHDR-NEXT: EntrySize: 0
# DWARF32-LE-NEXT: SectionData (
# DWARF32-LE-NEXT:   0000: 0C000000 05000400 34120000 78560000
##                         |        |   | |  |        |
##                         |        |   | |  |        +------- address (4-byte)
##                         |        |   | |  +------- address (4-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 1) unit_length (4-byte)
##
# DWARF32-LE-NEXT:   0010: 14000000 05000800 21430000 00000000
##                         |        |   | |  |
##                         |        |   | |  +---------------- address (8-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 2) unit_length (4-byte)
##
# DWARF32-LE-NEXT:   0020: 65870000 00000000 0C000000 05000004
##                         |                 |        |   | |
##                         |                 |        |   | +- segment_selector_size (1-byte)
##                         |                 |        |   +- address_size (1-byte)
##                         |                 |        +--- version (2-byte)
##                         |                 +------- 3) unit_length (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-LE-NEXT:   0030: 34120000 78560000 14000000 05000008
##                         |        |        |        |   | |
##                         |        |        |        |   | +- segment_selector_size (1-byte)
##                         |        |        |        |   +- address_size (1-byte)
##                         |        |        |        +--- version (2-byte)
##                         |        |        +------- 4) unit_length (4-byte)
##                         |        +------- segment (4-byte)
##                         +------- segment (4-byte)
##
# DWARF32-LE-NEXT:   0040: 21430000 00000000 65870000 00000000
##                         |                 |
##                         |                 +---------------- segment (8-byte)
##                         +---------------- segment (8-byte)
##
# DWARF32-LE-NEXT:   0050: 1C000000 05000404 34120000 78560000
##                         |        |   | |  |        |
##                         |        |   | |  |        +------- address (4-byte)
##                         |        |   | |  +------- segment (4-byte)
##                         |        |   | +- segment_selector_size (4-byte)
##                         |        |   +- address_size (4-byte)
##                         |        +--- version (2-byte)
##                         +------- 5) unit_length (4-byte)
##
# DWARF32-LE-NEXT:   0060: 21430000 00000000 00000000 21430000
##                         |        |        |        |
##                         |        |        |        +------- address (4-byte)
##                         |        |        +------- segment (4-byte)
##                         |        +------- address (4-byte)
##                         +------- segment (4-byte)
##
# DWARF32-LE-NEXT:   0070: 34000000 05000808 34120000 00000000
##                         |        |   | |  |
##                         |        |   | |  +---------------- segment (8-byte)
##                         |        |   | +- segment_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 6) unit_length (4-byte)
##
# DWARF32-LE-NEXT:   0080: 78560000 00000000 21430000 00000000
##                         |                 |
##                         |                 +---------------- segment (8-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-LE-NEXT:   0090: 00000000 00000000 00000000 00000000
##                         |                 +---------------- segment (8-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-LE-NEXT:   00A0: 21430000 00000000 28000000 05000408
##                         |                 |        |   | |
##                         |                 |        |   | +- segment_size (1-byte)
##                         |                 |        |   +- address_size (1-byte)
##                         |                 |        +--- version (2-byte)
##                         |                 +------- 7) unit_length (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-LE-NEXT:   00B0: 34120000 00000000 78560000 21430000
##                         |                 |        |
##                         |                 |        +------- segment (8-byte)
##                         |                 +------- address (4-byte)
##                         +---------------- segment (8-byte)
##
# DWARF32-LE-NEXT:   00C0: 00000000 00000000 00000000 00000000
##                         |        |        +---------------- segment (8-byte)
##                         |        +------- address (4-btye)
##                         +------- higher 4-byte of segment
##
# DWARF32-LE-NEXT:   00D0: 21430000 28000000 05000804 34120000
##                         |        |        |   | |  +------- segment (4-byte)
##                         |        |        |   | +- segment_size (1-byte)
##                         |        |        |   +- address_size (1-byte)
##                         |        |        +--- version (2-byte)
##                         |        +------- 8) unit_length (4-byte)
##                         +------- address (4-byte)
##
# DWARF32-LE-NEXT:   00E0: 78560000 00000000 21430000 00000000
##                         |                 |        |
##                         |                 |        +------- address (8-byte)
##                         |                 +------- segment (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-LE-NEXT:   00F0: 00000000 00000000 21430000 00000000
##                         |        |        |
##                         |        |        +---------------- address (8-byte)
##                         |        +------- segment (4-byte)
##                         +------- higher 4-byte of address
##
# DWARF32-LE-NEXT:   0100: 34120000 02000400
##                         |        |   | |
##                         |        |   | +- segment_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 9) unit_length (4-byte)
# DWARF32-LE-NEXT: )

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  [[ENDIAN]]
  Type:  ET_EXEC
DWARF:
  debug_addr:
    ## 1) Only address (4-byte) exists.
    - Version:     5
      AddressSize: 0x04
      Entries:
        - Address: 0x1234
        - Address: 0x5678
    ## 2) Only address (8-byte) exists (AddressSize is derived from FileHeader).
    - Version: 5
      Entries:
        - Address: 0x4321
        - Address: 0x8765
    ## 3) Only segment (4-byte) exists.
    - Version:             5
      AddressSize:         0x00
      SegmentSelectorSize: 0x04
      Entries:
        - Segment: 0x1234
        - Segment: 0x5678
    ## 4) Only segment (8-byte) exists.
    - Version:             5
      AddressSize:         0x00
      SegmentSelectorSize: 0x08
      Entries:
        - Segment: 0x4321
        - Segment: 0x8765
    ## 5) Both address (4-byte) and segment (4-byte) exist.
    - Version:             5
      AddressSize:         0x04
      SegmentSelectorSize: 0x04
      Entries:
        - Segment: 0x1234
          Address: 0x5678
        - Segment: 0x4321
          ## Segment exists, while address takes the default value 0x00.
        - Address: 0x4321
          ## Address exists, while segment takes the default value 0x00.
    ## 6) Both address (8-byte) and segment (8-byte) exist (AddressSize is derived from FileHeader).
    - Version:             5
      SegmentSelectorSize: 0x08
      Entries:
        - Segment: 0x1234
          Address: 0x5678
        - Segment: 0x4321
          ## Segment exists, while address takes the default value 0x00.
        - Address: 0x4321
          ## Address exists, while segment takes the default value 0x00.
    ## 7) Both address (4-byte) and segment (8-byte) exist.
    - Version:             5
      AddressSize:         0x04
      SegmentSelectorSize: 0x08
      Entries:
        - Segment: 0x1234
          Address: 0x5678
        - Segment: 0x4321
          ## Segment exists, while address takes the default value 0x00.
        - Address: 0x4321
          ## Address exists, while segment takes the default value 0x00.
    ## 8) Both address (8-byte) and segment (4-byte) exist (AddressSize is derived from FileHeader).
    - Version:             5
      SegmentSelectorSize: 0x04
      Entries:
        - Segment: 0x1234
          Address: 0x5678
        - Segment: 0x4321
          ## Segment exists, while address takes the default value 0x00.
        - Address: 0x4321
          ## Address exists, while segment takes the default value 0x00.
    ## 9) Explicitly assign a value to 'Length'.
    - Length:              0x1234
      Version:             0x02
      AddressSize:         0x04
      SegmentSelectorSize: 0x00
      Entries:             []

## b) Generate and verify a big endian DWARF32 .debug_addr section.

# RUN: yaml2obj --docnum=1 -DENDIAN=ELFDATA2MSB %s -o %t1.dwarf32.be.o
# RUN: llvm-readobj --sections --section-data %t1.dwarf32.be.o | \
# RUN:   FileCheck %s -DSIZE=264 -DADDRALIGN=1 --check-prefixes=SHDR,DWARF32-BE

# DWARF32-BE-NEXT: SectionData (
# DWARF32-BE-NEXT:   0000: 0000000C 00050400 00001234 00005678
##                         |        |   | |  |        |
##                         |        |   | |  |        +------- address (4-byte)
##                         |        |   | |  +------- address (4-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 1) unit_length (4-byte)
##
# DWARF32-BE-NEXT:   0010: 00000014 00050800 00000000 00004321
##                         |        |   | |  |
##                         |        |   | |  +---------------- address (8-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 2) unit_length (4-byte)
##
# DWARF32-BE-NEXT:   0020: 00000000 00008765 0000000C 00050004
##                         |                 |        |   | |
##                         |                 |        |   | +- segment_selector_size (1-byte)
##                         |                 |        |   +- address_size (1-byte)
##                         |                 |        +--- version (2-byte)
##                         |                 +------- 3) unit_length (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-BE-NEXT:   0030: 00001234 00005678 00000014 00050008
##                         |        |        |        |   | |
##                         |        |        |        |   | +- segment_selector_size (1-byte)
##                         |        |        |        |   +- address_size (1-byte)
##                         |        |        |        +--- version (2-byte)
##                         |        |        +------- 4) unit_length (4-byte)
##                         |        +------- segment (4-byte)
##                         +------- segment (4-byte)
##
# DWARF32-BE-NEXT:   0040: 00000000 00004321 00000000 00008765
##                         |                 |
##                         |                 +---------------- segment (8-byte)
##                         +---------------- segment (8-byte)
##
# DWARF32-BE-NEXT:   0050: 0000001C 00050404 00001234 00005678
##                         |        |   | |  |        |
##                         |        |   | |  |        +------- address (4-byte)
##                         |        |   | |  +------- segment (4-byte)
##                         |        |   | +- segment_selector_size (4-byte)
##                         |        |   +- address_size (4-byte)
##                         |        +--- version (2-byte)
##                         +------- 5) unit_length (4-byte)
##
# DWARF32-BE-NEXT:   0060: 00004321 00000000 00000000 00004321
##                         |        |        |        |
##                         |        |        |        +------- address (4-byte)
##                         |        |        +------- segment (4-byte)
##                         |        +------- address (4-byte)
##                         +------- segment (4-byte)
##
# DWARF32-BE-NEXT:   0070: 00000034 00050808 00000000 00001234
##                         |        |   | |  |
##                         |        |   | |  +---------------- segment (8-byte)
##                         |        |   | +- segment_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 6) unit_length (4-byte)
##
# DWARF32-BE-NEXT:   0080: 00000000 00005678 00000000 00004321
##                         |                 |
##                         |                 +---------------- segment (8-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-BE-NEXT:   0090: 00000000 00000000 00000000 00000000
##                         |                 |
##                         |                 +---------------- segment (8-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-BE-NEXT:   00A0: 00000000 00004321 00000028 00050408
##                         |                 |        |   | |
##                         |                 |        |   | +- segment_size (1-byte)
##                         |                 |        |   +- address_size (1-byte)
##                         |                 |        +--- version (2-byte)
##                         |                 +------- 7) unit_length (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-BE-NEXT:   00B0: 00000000 00001234 00005678 00000000
##                         |                 |        |
##                         |                 |        +------- segment (8-byte)
##                         |                 +------- address (4-byte)
##                         +---------------- segment (8-byte)
##
# DWARF32-BE-NEXT:   00C0: 00004321 00000000 00000000 00000000
##                         |        |        |
##                         |        |        +---------------- segment (8-byte)
##                         |        +------- address (4-btye)
##                         +------- lower 4-byte of segment
##
# DWARF32-BE-NEXT:   00D0: 00004321 00000028 00050804 00001234
##                         |        |        |   | |  |
##                         |        |        |   | |  +------- segment (4-byte)
##                         |        |        |   | +- segment_size (1-byte)
##                         |        |        |   +- address_size (1-byte)
##                         |        |        +--- version (2-byte)
##                         |        +------- 8) unit_length (4-byte)
##                         +------- address (4-byte)
##
# DWARF32-BE-NEXT:   00E0: 00000000 00005678 00004321 00000000
##                         |                 |        |
##                         |                 |        +------- address (8-byte)
##                         |                 +------- segment (4-byte)
##                         +---------------- address (8-byte)
##
# DWARF32-BE-NEXT:   00F0: 00000000 00000000 00000000 00004321
##                         |        |        |
##                         |        |        +---------------- address (8-byte)
##                         |        +------- segment (4-byte)
##                         +------- lower 4-byte of address
##
# DWARF32-BE-NEXT:   0100: 00001234 00020400
##                         |        |   | |
##                         |        |   | +- segment_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- 9) unit_length (4-byte)
# DWARF32-BE-NEXT: )

## c) Generate and verify a little endian DWARF64 .debug_addr section.

# RUN: yaml2obj --docnum=2 -DENDIAN=ELFDATA2LSB %s -o %t2.dwarf64.le.o
# RUN: llvm-readobj --sections --section-data %t2.dwarf64.le.o | \
# RUN:   FileCheck %s -DSIZE=56 -DADDRALIGN=1 --check-prefixes=SHDR,DWARF64-LE

# DWARF64-LE-NEXT: SectionData (
# DWARF64-LE-NEXT:   0000: FFFFFFFF 0C000000 00000000 05000400
##                         |                          |   | |
##                         |                          |   | +- segment_selector_size (1-byte)
##                         |                          |   +- address_size (1-byte)
##                         |                          +--- version (2-byte)
##                         +------------------------- unit_length (12-byte)
##
# DWARF64-LE-NEXT:   0010: 34120000 78560000 FFFFFFFF 14000000
##                         |        |        |
##                         |        |        +---------------- unit_length (12-byte)
##                         |        +------- address (4-byte)
##                         +------- address (4-byte)
##
# DWARF64-LE-NEXT:   0020: 00000000 05000800 21430000 00000000
##                         |        |   | |  |
##                         |        |   | |  +---------------- address (8-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- last 4-byte of unit_length
##
# DWARF64-LE-NEXT:   0030: 65870000 00000000
##                         |
##                         +---------------- address (8-byte)
# DWARF64-LE-NEXT: )

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  [[ENDIAN]]
  Type:  ET_EXEC
DWARF:
  debug_addr:
    - Format:      DWARF64
      Version:     5
      AddressSize: 0x04
      Entries:
        - Address: 0x1234
        - Address: 0x5678
    - Format:   DWARF64
      Version:  5
      Entries:
        - Address: 0x4321
        - Address: 0x8765

## d) Generate and verify a big endian DWARF64 .debug_addr section.

# RUN: yaml2obj --docnum=2 -DENDIAN=ELFDATA2MSB %s -o %t2.dwarf64.be.o
# RUN: llvm-readobj --sections --section-data %t2.dwarf64.be.o | \
# RUN:   FileCheck %s -DSIZE=56 -DADDRALIGN=1 --check-prefixes=SHDR,DWARF64-BE

# DWARF64-BE-NEXT: SectionData (
# DWARF64-BE-NEXT:   0000: FFFFFFFF 00000000 0000000C 00050400
##                         |                          |   | |
##                         |                          |   | +- segment_selector_size (1-byte)
##                         |                          |   +- address_size (1-byte)
##                         |                          +--- version (2-byte)
##                         +------------------------- unit_length (12-byte)
##
# DWARF64-BE-NEXT:   0010: 00001234 00005678 FFFFFFFF 00000000
##                         |        |        |
##                         |        |        +---------------- unit_length (12-byte)
##                         |        +------- address (4-byte)
##                         +------- address (4-byte)
##
# DWARF64-BE-NEXT:   0020: 00000014 00050800 00000000 00004321
##                         |        |   | |  |
##                         |        |   | |  +---------------- address (8-byte)
##                         |        |   | +- segment_selector_size (1-byte)
##                         |        |   +- address_size (1-byte)
##                         |        +--- version (2-byte)
##                         +------- last 4-byte of unit_length
##
# DWARF64-BE-NEXT:   0030: 00000000 00008765
##                         |
##                         +---------------- address (8-byte)
# DWARF64-BE-NEXT: )

## e) Test that yaml2obj emits an error message if the 'Version' fields is missing.

# RUN: not yaml2obj --docnum=3 %s 2>&1 | FileCheck %s --check-prefix=MISSING-VERSION

# MISSING-VERSION: error: missing required key 'Version'

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
DWARF:
  debug_addr:
    - Entries: []

## f) Generate the .debug_addr section from raw section content.

# RUN: yaml2obj --docnum=4 %s -o %t4.o
# RUN: llvm-readobj --sections --section-data %t4.o | \
# RUN:   FileCheck %s -DADDRALIGN=0 -DSIZE=3 --check-prefixes=SHDR,ARBITRARY-CONTENT

#      ARBITRARY-CONTENT: SectionData (
# ARBITRARY-CONTENT-NEXT:   0000: 112233
# ARBITRARY-CONTENT-NEXT: )

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name:    .debug_addr
    Type:    SHT_PROGBITS
    Content: "112233"

## g) Generate the .debug_addr section when the "Size" is specified.

# RUN: yaml2obj --docnum=5 %s -o %t5.o
# RUN: llvm-readelf --hex-dump=.debug_addr %t5.o | FileCheck %s --check-prefix=SIZE

#       SIZE: Hex dump of section '.debug_addr':
#  SIZE-NEXT: 0x00000000 00000000 00000000 00000000 00000000 ................
# SIZE-EMPTY:

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name: .debug_addr
    Type: SHT_PROGBITS
    Size: 0x10

## h) Test that yaml2obj emits an error message when both the "Size" and the
## "debug_addr" entry are specified at the same time.

# RUN: not yaml2obj --docnum=6 %s 2>&1 | FileCheck %s --check-prefix=ERROR

# ERROR: yaml2obj: error: cannot specify section '.debug_addr' contents in the 'DWARF' entry and the 'Content' or 'Size' in the 'Sections' entry at the same time

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name: .debug_addr
    Type: SHT_PROGBITS
    Size: 0x10
DWARF:
  debug_addr:
    - Version: 5
      Entries: []

## i) Test that yaml2obj emits an error message when both the "Content" and the
## "debug_addr" entry are specified at the same time.

# RUN: not yaml2obj --docnum=7 %s 2>&1 | FileCheck %s --check-prefix=ERROR

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name:    .debug_addr
    Type:    SHT_PROGBITS
    Content: "00"
DWARF:
  debug_addr:
    - Version: 5
      Entries: []

## j) Test that all the properties can be overridden by the section header when
## the "debug_addr" entry doesn't exist.

# RUN: yaml2obj --docnum=8 %s -o %t8.o
# RUN: llvm-readelf --sections %t8.o | FileCheck %s --check-prefix=OVERRIDDEN

#      OVERRIDDEN: [Nr] Name        Type   Address          Off    Size   ES Flg Lk Inf Al
#      OVERRIDDEN: [ 1] .debug_addr STRTAB 0000000000002020 000050 000008 01   A  2   1  2
# OVERRIDDEN-NEXT: [ 2] .sec        STRTAB 0000000000000000 000058 000000 00      0   0  0

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name:         .debug_addr
    Type:         SHT_STRTAB  ## SHT_PROGBITS by default.
    Flags:        [SHF_ALLOC] ## 0 by default.
    Link:         .sec        ## 0 by default.
    EntSize:      1           ## 0 by default.
    Info:         1           ## 0 by default.
    AddressAlign: 2           ## 0 by default.
    Address:      0x2020      ## 0x00 by default.
    Offset:       0x50        ## 0x40 for the first section.
    Size:         0x08        ## Set the "Size" so that we can reuse the check tag "OVERRIDDEN".
  - Name:         .sec        ## Linked by .debug_addr.
    Type:         SHT_STRTAB

## k) Test that all the properties can be overridden by the section header when
## the "debug_addr" entry exists.

# RUN: yaml2obj --docnum=9 %s -o %t9.o
# RUN: llvm-readelf --sections %t9.o | FileCheck %s --check-prefix=OVERRIDDEN

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
Sections:
  - Name:         .debug_addr
    Type:         SHT_STRTAB  ## SHT_PROGBITS by default.
    Flags:        [SHF_ALLOC] ## 0 by default.
    Link:         .sec        ## 0 by default.
    EntSize:      1           ## 0 by default.
    Info:         1           ## 0 by default.
    AddressAlign: 2           ## 1 by default.
    Address:      0x2020      ## 0x00 by default.
    Offset:       0x50        ## 0x40 for the first section.
  - Name:         .sec        ## Linked by .debug_addr.
    Type:         SHT_STRTAB
DWARF:
  debug_addr:
    - Version: 5
      Entries: []

## l) Test that yaml2obj still generates a .debug_addr section if we assign an invalid value
## to 'AddressSize' or 'SegmentSelectorSize' when the 'Entries' list is empty.

# RUN: yaml2obj --docnum=10 -DSIZENAME=AddressSize %s -o %t10.addr.o
# RUN: llvm-readelf --hex-dump=.debug_addr %t10.addr.o | \
# RUN:   FileCheck -DADDRSIZE=03 -DSEGSIZE=00 %s --check-prefix=ADDR-SEG-SIZE

# RUN: yaml2obj --docnum=10 -DSIZENAME=SegmentSelectorSize %s -o %t10.seg.o
# RUN: llvm-readelf --hex-dump=.debug_addr %t10.seg.o | \
# RUN:   FileCheck -DADDRSIZE=08 -DSEGSIZE=03 %s --check-prefix=ADDR-SEG-SIZE

#      ADDR-SEG-SIZE: Hex dump of section '.debug_addr':
# ADDR-SEG-SIZE-NEXT: 0x00000000 04000000 0500[[ADDRSIZE]][[SEGSIZE]]

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
DWARF:
  debug_addr:
    - Version:      5
      [[SIZENAME]]: 3
      Entries:      []

## m) Test that yaml2obj emits an error message if we try to assign an invalid value to
## 'AddressSize' or 'SegmentSelectorSize' when the 'Entries' list isn't empty.

# RUN: not yaml2obj --docnum=11 -DSIZENAME=AddressSize %s 2>&1 | \
# RUN:   FileCheck -DFIELD=address %s --check-prefix=INVALID-SIZE

# RUN: not yaml2obj --docnum=11 -DSIZENAME=SegmentSelectorSize %s 2>&1 | \
# RUN:   FileCheck -DFIELD=segment %s --check-prefix=INVALID-SIZE

# INVALID-SIZE: yaml2obj: error: unable to write debug_addr [[FIELD]]: invalid integer write size: 3

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
DWARF:
  debug_addr:
    - Version:      5
      [[SIZENAME]]: 3
      Entries:
        - Address: 0x1234

## n) Test that the .debug_addr section header is emitted if the "debug_addr"
## entry is empty.

# RUN: yaml2obj --docnum=12 %s -o %t12.o
# RUN: llvm-readobj --sections %t12.o | \
# RUN:   FileCheck %s -DSIZE=0 -DADDRALIGN=1 --check-prefix=SHDR

--- !ELF
FileHeader:
  Class: ELFCLASS64
  Data:  ELFDATA2LSB
  Type:  ET_EXEC
DWARF:
  debug_addr: []