Non puoi selezionare più di 25 argomenti Gli argomenti devono iniziare con una lettera o un numero, possono includere trattini ('-') e possono essere lunghi fino a 35 caratteri.
 
 
 

103 righe
4.0 KiB

  1. // Copyright 2014 Google Inc. All Rights Reserved.
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. package elfexec
  15. import (
  16. "debug/elf"
  17. "testing"
  18. )
  19. func TestGetBase(t *testing.T) {
  20. fhExec := &elf.FileHeader{
  21. Type: elf.ET_EXEC,
  22. }
  23. fhRel := &elf.FileHeader{
  24. Type: elf.ET_REL,
  25. }
  26. fhDyn := &elf.FileHeader{
  27. Type: elf.ET_DYN,
  28. }
  29. lsOffset := &elf.ProgHeader{
  30. Vaddr: 0x400000,
  31. Off: 0x200000,
  32. }
  33. kernelHeader := &elf.ProgHeader{
  34. Vaddr: 0xffffffff81000000,
  35. }
  36. kernelAslrHeader := &elf.ProgHeader{
  37. Vaddr: 0xffffffff80200000,
  38. Off: 0x1000,
  39. }
  40. ppc64KernelHeader := &elf.ProgHeader{
  41. Vaddr: 0xc000000000000000,
  42. }
  43. testcases := []struct {
  44. label string
  45. fh *elf.FileHeader
  46. loadSegment *elf.ProgHeader
  47. stextOffset *uint64
  48. start, limit, offset uint64
  49. want uint64
  50. wanterr bool
  51. }{
  52. {"exec", fhExec, nil, nil, 0x400000, 0, 0, 0, false},
  53. {"exec offset", fhExec, lsOffset, nil, 0x400000, 0x800000, 0, 0x200000, false},
  54. {"exec offset 2", fhExec, lsOffset, nil, 0x200000, 0x600000, 0, 0, false},
  55. {"exec nomap", fhExec, nil, nil, 0, 0, 0, 0, false},
  56. {"exec kernel", fhExec, kernelHeader, uint64p(0xffffffff81000198), 0xffffffff82000198, 0xffffffff83000198, 0, 0x1000000, false},
  57. {"exec kernel", fhExec, kernelHeader, uint64p(0xffffffff810002b8), 0xffffffff81000000, 0xffffffffa0000000, 0x0, 0x0, false},
  58. {"exec kernel ASLR", fhExec, kernelHeader, uint64p(0xffffffff810002b8), 0xffffffff81000000, 0xffffffffa0000000, 0xffffffff81000000, 0x0, false},
  59. // TODO(aalexand): Figure out where this test case exactly comes from and
  60. // whether it's still relevant.
  61. {"exec kernel ASLR 2", fhExec, kernelAslrHeader, nil, 0xffffffff83e00000, 0xfffffffffc3fffff, 0x3c00000, 0x3c00000, false},
  62. {"exec PPC64 kernel", fhExec, ppc64KernelHeader, uint64p(0xc000000000000000), 0xc000000000000000, 0xd00000001a730000, 0x0, 0x0, false},
  63. {"exec chromeos kernel", fhExec, kernelHeader, uint64p(0xffffffff81000198), 0, 0x10197, 0, 0x7efffe68, false},
  64. {"exec chromeos kernel 2", fhExec, kernelHeader, uint64p(0xffffffff81000198), 0, 0x10198, 0, 0x7efffe68, false},
  65. {"exec chromeos kernel 3", fhExec, kernelHeader, uint64p(0xffffffff81000198), 0x198, 0x100000, 0, 0x7f000000, false},
  66. {"exec chromeos kernel 4", fhExec, kernelHeader, uint64p(0xffffffff81200198), 0x198, 0x100000, 0, 0x7ee00000, false},
  67. {"exec chromeos kernel unremapped", fhExec, kernelHeader, uint64p(0xffffffff810001c8), 0xffffffff834001c8, 0xffffffffc0000000, 0xffffffff834001c8, 0x2400000, false},
  68. {"dyn", fhDyn, nil, nil, 0x200000, 0x300000, 0, 0x200000, false},
  69. {"dyn map", fhDyn, lsOffset, nil, 0x0, 0x300000, 0, 0xFFFFFFFFFFE00000, false},
  70. {"dyn nomap", fhDyn, nil, nil, 0x0, 0x0, 0, 0, false},
  71. {"dyn map+offset", fhDyn, lsOffset, nil, 0x900000, 0xa00000, 0x200000, 0x500000, false},
  72. {"rel", fhRel, nil, nil, 0x2000000, 0x3000000, 0, 0x2000000, false},
  73. {"rel nomap", fhRel, nil, nil, 0x0, ^uint64(0), 0, 0, false},
  74. {"rel offset", fhRel, nil, nil, 0x100000, 0x200000, 0x1, 0, true},
  75. }
  76. for _, tc := range testcases {
  77. base, err := GetBase(tc.fh, tc.loadSegment, tc.stextOffset, tc.start, tc.limit, tc.offset)
  78. if err != nil {
  79. if !tc.wanterr {
  80. t.Errorf("%s: want no error, got %v", tc.label, err)
  81. }
  82. continue
  83. }
  84. if tc.wanterr {
  85. t.Errorf("%s: want error, got nil", tc.label)
  86. continue
  87. }
  88. if base != tc.want {
  89. t.Errorf("%s: want 0x%x, got 0x%x", tc.label, tc.want, base)
  90. }
  91. }
  92. }
  93. func uint64p(n uint64) *uint64 {
  94. return &n
  95. }