File: test_riscv_support.py

package info (click to toggle)
python-pyelftools 0.32-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 68,964 kB
  • sloc: python: 15,903; ansic: 298; asm: 86; makefile: 24; cpp: 18; sh: 4
file content (74 lines) | stat: -rw-r--r-- 3,228 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
#-------------------------------------------------------------------------------
# elftools tests
#
# Ricardo Barbedo (ricardo@barbedo.me)
# This code is in the public domain
#-------------------------------------------------------------------------------
import unittest
import os

from elftools.elf.elffile import ELFFile

class TestRISCVSupport(unittest.TestCase):
    def test_hello(self):
        with open(os.path.join('test', 'testfiles_for_unittests',
                               'simple_gcc.elf.riscv'), 'rb') as f:
            elf = ELFFile(f)
            self.assertEqual(elf.get_machine_arch(), 'RISC-V')

            # Check some other properties of this ELF file derived from readelf
            self.assertEqual(elf['e_entry'], 0x10116)
            self.assertEqual(elf.num_sections(), 13)
            self.assertEqual(elf.num_segments(), 3)

    def test_build_attributes(self):
        with open(os.path.join('test', 'testfiles_for_unittests',
                               'simple_gcc.elf.riscv'), 'rb') as f:
            elf = ELFFile(f)

            sec = elf.get_section_by_name('.riscv.attributes')
            self.assertEqual(sec['sh_type'], 'SHT_RISCV_ATTRIBUTES')
            self.assertEqual(sec.num_subsections, 1)

            subsec = sec.subsections[0]
            self.assertEqual(subsec.header['vendor_name'], 'riscv')
            self.assertEqual(subsec.num_subsubsections, 1)

            subsubsec = subsec.subsubsections[0]
            self.assertEqual(subsubsec.header.tag, 'TAG_FILE')

            for i in subsubsec.iter_attributes('TAG_STACK_ALIGN'):
                self.assertEqual(i.value, 16)

            for i in subsubsec.iter_attributes('TAG_ARCH'):
                self.assertEqual(i.value, 'rv64i2p0_m2p0_a2p0_f2p0_d2p0_c2p0_v1p0_zfh1p0_zfhmin1p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_zve32f1p0_zve32x1p0_zve64d1p0_zve64f1p0_zve64x1p0_zvl128b1p0_zvl32b1p0_zvl64b1p0')

        with open(os.path.join('test', 'testfiles_for_unittests',
                               'simple_clang.elf.riscv'), 'rb') as f:
            elf = ELFFile(f)

            sec = elf.get_section_by_name('.riscv.attributes')
            self.assertEqual(sec['sh_type'], 'SHT_RISCV_ATTRIBUTES')
            self.assertEqual(sec.num_subsections, 1)

            subsec = sec.subsections[0]
            self.assertEqual(subsec.header['vendor_name'], 'riscv')
            self.assertEqual(subsec.num_subsubsections, 1)

            subsubsec = subsec.subsubsections[0]
            self.assertEqual(subsubsec.header.tag, 'TAG_FILE')

            for i in subsubsec.iter_attributes('TAG_STACK_ALIGN'):
                self.assertEqual(i.value, 16)

            for i in subsubsec.iter_attributes('TAG_ARCH'):
                self.assertEqual(i.value, 'rv64i2p1_m2p0_a2p1_f2p2_d2p2_c2p0_v1p0_zicsr2p0_zifencei2p0_zmmul1p0_zfh1p0_zba1p0_zbb1p0_zbc1p0_zbs1p0_zve32f1p0_zve32x1p0_zve64d1p0_zve64f1p0_zve64x1p0_zvl128b1p0_zvl32b1p0_zvl64b1p0')

            for i in subsubsec.iter_attributes('TAG_PRIV_SPEC'):
                self.assertEqual(i.value, 1)

            for i in subsubsec.iter_attributes('TAG_PRIV_SPEC_MINOR'):
                self.assertEqual(i.value, 11)

if __name__ == '__main__':
    unittest.main()