check_placements.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. #!/usr/bin/env python
  2. #
  3. # SPDX-FileCopyrightText: 2020-2023 Espressif Systems (Shanghai) CO LTD
  4. # SPDX-License-Identifier: Apache-2.0
  5. #
  6. # Check placements in this test app for main
  7. # specified in main/linker.lf
  8. import argparse
  9. import subprocess
  10. from pyparsing import LineEnd, LineStart, Literal, Optional, Word, alphanums, hexnums
  11. argparser = argparse.ArgumentParser()
  12. argparser.add_argument('objdump')
  13. argparser.add_argument('elf')
  14. argparser.add_argument('--no-rtc', action='store_true')
  15. args = argparser.parse_args()
  16. contents = subprocess.check_output([args.objdump, '-t', args.elf]).decode()
  17. def check_location(symbol, expected):
  18. pattern = (LineStart() + Word(hexnums).setResultsName('address')
  19. + Optional(Word(alphanums, exact=1))
  20. + Optional(Word(alphanums,exact=1))
  21. + Word(alphanums + '._*').setResultsName('actual')
  22. + Word(hexnums)
  23. + Literal(symbol)
  24. + LineEnd())
  25. try:
  26. results = pattern.searchString(contents)[0]
  27. except IndexError:
  28. raise Exception("check placement fail: '%s' was not found" % (symbol))
  29. if results.actual != expected:
  30. raise Exception("check placement fail: '%s' was placed in '%s', not in '%s'" % (symbol, results.actual, expected))
  31. print("check placement pass: '%s' was successfully placed in '%s'" % (symbol, results.actual))
  32. return int(results.address, 16)
  33. # src1:func1 (noflash) - explicit mapping for func2 using 'rtc' scheme
  34. # should have been dropped since it is unreferenced.
  35. func1 = check_location('func1', '.iram0.text')
  36. sym1_start = check_location('_sym1_start', '*ABS*')
  37. sym1_end = check_location('_sym1_end', '*ABS*')
  38. assert func1 >= sym1_start, 'check placement fail: func1 comes before __sym1_start'
  39. assert func1 < sym1_end, 'check placement fail: func1 comes after __sym1_end'
  40. assert sym1_start % 9 == 0, '_sym1_start is not aligned as specified in linker fragment'
  41. assert sym1_end % 12 == 0, '_sym1_end is not aligned as specified in linker fragment'
  42. print('check placement pass: _sym1_start < func1 < __sym1_end and alignments checked')
  43. # src1:func2 (rtc) - explicit mapping for func2 using 'rtc' scheme
  44. if not args.no_rtc:
  45. check_location('func2', '.rtc.text')
  46. # src1 (default) - only func3 in src1 remains that has not been
  47. # mapped using a different scheme
  48. check_location('func3', '.flash.text')
  49. check_location('func4', '.iram0.text')