Difference between revisions of "Havm"

From LRDE

(→‎Contact: Update the project's e-mail address.)
 
(3 intermediate revisions by 2 users not shown)
Line 20: Line 20:
 
== Downloads ==
 
== Downloads ==
   
* Version 0.26: https://www.lrde.epita.fr/~tiger/download/havm-0.26.tar.bz2
+
* Version 0.27: https://www.lrde.epita.fr/~tiger/download/havm-0.27.tar.gz
* Version 0.25: https://www.lrde.epita.fr/~tiger/download/havm-0.25.tar.bz2
 
   
 
== Git Repository ==
 
== Git Repository ==
   
* The Git repository is located at git://git.lrde.epita.fr/havm.
+
* The Git repository is located at https://gitlab.lrde.epita.fr/tiger/havm.git.
* You can browse it online via [http://git.lrde.epita.fr/?p=havm.git;a=summary GitWeb].
+
* You can browse it online via [https://gitlab.lrde.epita.fr/tiger/havm Gitlab].
   
 
== Documentation ==
 
== Documentation ==
   
* See HAVM's documentation at https://www.lrde.epita.fr/~tiger/doc/havm.html.
+
* See HAVM's documentation at https://www.lrde.epita.fr/~tiger/doc/:
  +
** HTML manual: https://www.lrde.epita.fr/~tiger/doc/havm.html.
 
** PDF manual: https://www.lrde.epita.fr/~tiger/doc/havm.pdf.
   
 
== Additional Resources ==
 
== Additional Resources ==
Line 38: Line 39:
 
== Contact ==
 
== Contact ==
   
Send any questions or comments to projects@lrde.epita.fr.
+
Send any questions or comments to projects⁠@⁠lrde⁠.⁠epita.⁠fr.

Latest revision as of 17:34, 27 November 2017

Introduction

HAVM is a virtual machine designed to execute simple register based high level intermediate code. It is based on the intermediate representations ("canonicalized" or not) defined by Andrew Appel in his Modern Compiler Implementation books. It is nevertheless generic enough so that any (student) compiler could target its intermediate language to HAVM's language.

Its features are:

  • two object types, integers and pointers
  • tree-like source language (two way conditional jumps, arbitrarily nested subroutines calls, etc.)
  • threaded source language (one way conditional jumps, etc.)
  • a runtime library comparable to SPIM's
  • a debugging mode displaying the instructions being executed

It was written by Robert Anisko as an LRDE member, so that EPITA students could exercise their [[Tiger.WebHome][Tiger]] compiler projects before the final jump to assembly code. It is implemented in Haskell, a pure non strict functional language very well suited for this kind of symbolic processing. HAVM was coined on both Haskell and VM, standing for Virtual Machine.

Downloads

Git Repository

Documentation

Additional Resources

This page is to be completed. In the meanwhile, see https://www.lrde.epita.fr/~tiger/download/ and http://www.lrde.epita.fr/~tiger/doc/havm.html.

Contact

Send any questions or comments to projects⁠@⁠lrde⁠.⁠epita.⁠fr.