This repo contains the source code for the ANSI C (C90) to RISC-V compiler developed as part of the EIE 2nd Year Instruction Set Architecture and Compilers coursework completed in Spring 2023. This project was done by myself (Alvi) and Johan. Our primary road-map and direction was driven by the spec. This repo can be used a reference or guideline to learn basics of compiler design such as lexing, parsing, abstract-syntax-tree (AST) and assembly generation. Further, contexts like register allocation, stack pointer, memory management, etc can also be seen. Future works out of the scope of the project, which have not be implemented include intermediate representation and code optimisation. Please note, copying this code will be considered as plagiarism.
This project scored a 80% out of all the seen and unseen test cases, putting our compiler second-best ranked among all. The test cases varied from functions and datatypes to pointers and structs. If you have any questions and suggestions, please feel free to reach out to me or open an issue. I would be more than happy to help and learn more 😀.
Our compiler can be built by calling make bin/c_compiler
(or just make
), and must be invoked as follows:
bin/c_compiler -S <source-file.c> -o <dest-file.s>
The command-line parameters must be provided in the order outlined above mostly which has been derived from the given spec.
This file also contains a Review of our compiler given by our TA Simon Staal, which clearly outlines the strengths and weaknesses of our compiler.
This folder contains a set of test cases we used to evaluate the functional correctness of our compiler. Most of these were pre-included as part of the spec, but many have been added ourselves which can be found in Custom_Tests to further test specific edge cases and undefined behaviour during development. Each test case has accompanying driver code with which it is tested, where the driver code should always return 0.
This directory contains all the header files for our compiler, including the nodes used to develop our AST which we use to generate our assembly, as well as other helper functions which were used for various purposes such as register allocation, memory management, stack pointer, etc. The base class for our AST is node, and all of our other AST constructs was build off it. Each of the different set of constructs has been segregated to different folders to allow better readability and modularity.
This directory contains the source code for our parser written in Yacc and accompanying lexer written in flex, which are used to initially process the input source code and generate the AST. compiler.cpp contains the source code for our actual compiler, and mostly contains any directives needed at the start of the assembly code, as well as some formatting for visualisation.
-
Special thanks to John Wickerson for creating such a wonderful coursework and teaching us Compilers for 2nd Year EIE.
-
Extra-special thanks to James Nock and Simon Staal for guiding us through this project and reviewing our work with great effort to help us improve!
Personal Note: Thanks to Johan for making this wonderful project logo!