An Efficient Intel Assembler Tool Design

효율적인 인텔 어셈블러 도구 설계

  • Jung, Seungil (Department of Cyber Security Research Center, KAIST) ;
  • Ryou, Jae-Cheol (Department of Computer Engineering, Chungnam National University)
  • 정승일 (한국과학기술원 사이버보안연구센터) ;
  • 류재철 (충남대학교 컴퓨터공학과)
  • Published : 2020.07.15

Abstract

소스 코드가 없는 악성코드를 분석하거나 소프트웨어 취약점 분석을 위해 바이너리 분석이 요구된다. 바이너리 분석을 위한 도구 중 어셈블러는 사용자의 입력 없이 컴파일러 내부에서 수행되기 때문에 사용자 관점의 연구는 많지 않다. 그러나 바이너리 분석 과정 중 역어셈블과 중간언어(Intermediate Representation)의 정확성을 검증하기 위해 사용자가 어셈블리어를 입력하여 결과를 확인할 수 있는 어셈블러가 요구된다. 본 논문에서는 어셈블리어를 바이너리 코드로 변환하는 어셈블러 도구를 함수형 언어인 F#으로 구현하여 어셈블리 과정을 효율적으로 설계한 어셈블러 도구를 제안한다. F#의 강력한 패턴 매칭 기능을 사용하여 수백개의 명령어를 일괄적이고 직관적으로 처리하는 과정을 설계하고 구현하였다.

Keywords