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
|
// Copyright 2020 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package dwarf
import (
"encoding/binary"
"os"
"reflect"
"testing"
)
func TestDwarf5Ranges(t *testing.T) {
rngLists, err := os.ReadFile("testdata/debug_rnglists")
if err != nil {
t.Fatalf("could not read test data: %v", err)
}
d := &Data{}
d.order = binary.LittleEndian
if err := d.AddSection(".debug_rnglists", rngLists); err != nil {
t.Fatal(err)
}
u := &unit{
asize: 8,
vers: 5,
is64: true,
}
ret, err := d.dwarf5Ranges(u, nil, 0x5fbd, 0xc, [][2]uint64{})
if err != nil {
t.Fatalf("could not read rnglist: %v", err)
}
t.Logf("%#v", ret)
tgt := [][2]uint64{{0x0000000000006712, 0x000000000000679f}, {0x00000000000067af}, {0x00000000000067b3}}
if reflect.DeepEqual(ret, tgt) {
t.Errorf("expected %#v got %#x", tgt, ret)
}
}
|