/Shellcode_IA32

Shellcode_IA32 is a dataset consisting of challenging but common assembly instructions, collected from real shellcodes, with their natural language descriptions. The dataset can be used for neural machine translation tasks to automatically generate software exploits from natural language.

GNU General Public License v3.0GPL-3.0

Shellcode_IA32

Shellcode_IA32 is a dataset containing more than 20 years of shellcodes from a variety of sources and is the largest collection of shellcodes in assembly available to date. We are currently extending the dataset. Up to now, we released two versions of the dataset.

Version 1

The dataset was presented for the first time in the paper Shellcode_IA32: A Dataset for Automatic Shellcode Generation, accepted to the 1st Workshop on Natural Language Processing for Programming (NLP4Prog 2021). This version consists of 3,200 examples of instructions in assembly language for IA-32 (the 32-bit version of the x86 Intel Architecture) from publicly available security exploits. We collected assembly programs used to generate shellcode from exploit-db and from shell-storm. We enriched the dataset by adding examples of assembly programs for the IA-32 architecture from popular tutorials and books. This allowed us to understand how different authors and assembly experts comment and, thus, how to deal with the ambiguity of natural language in this specific context. Our dataset consists of 10% of instructions collected from books and guidelines, and the rest from real shellcodes.

Our focus is on Linux, the most common OS for security-critical network services. Accordingly, we added assembly instructions written with Netwide Assembler (NASM) for Linux.

Each line of Shellcode_IA32 dataset represents a snippet - intent pair. The snippet is a line or a combination of multiple lines of assembly code, built by following the NASM syntax. The intent is a comment in the English language.

We conducted an extensive experimental evaluation using the Shellcode_IA32 dataset in the journal paper Can we generate shellcodes via natural language? An empirical study, published in the Automated Software Engineering (AUSE) journal. The paper also contains further statistics on the dataset.

Version 2

Shellcode_IA32 dataset has been extended to build the Decoder Dataset (an assembly dataset used for decoding the encoded shellcodes) presented in the paper EVIL: Exploiting Software via Natural Language. The extended dataset and the code to reproduce the experiments of the paper can be found on this GitHub repository. This second version of the dataset includes 3,715 assembly code snippets with their description in the English language.

Version 3

We are currently working to further extend the dataset.