puc8a


Namepuc8a JSON
Version 0.1.5 PyPI version JSON
download
home_pagehttp://github.com/wcaarls/puc8a
SummaryAssembler and C compiler for the PUC8a processor
upload_time2025-08-08 18:48:18
maintainerNone
docs_urlNone
authorWouter Caarls
requires_pythonNone
licenseGPL-3.0-or-later
keywords assembler compiler educational risc processor
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # PUC8a

Assembler and C compiler for the PUC8a processor

Copyright 2020-2025 Wouter Caarls

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

# Introduction

PUC8a is an accumulator-based microcontroller with 8-bit registers. It is used in the
ENG1448 course of PUC-Rio. This is the assembler and C compiler
infrastructure for it.

# Instruction set architecture

This very simple processor is a Harvard design, with 8-bit instructions and 8-bit data values.
Both instruction and data memories have 256 addresses.

## Registers

There are 16 registers. `r14` is `sp`; `r15` is `pc`. The C compiler uses `r13` as `fp`.

## Instructions

All ALU instructions set flags.

| Opcode(4)  | Data(4) | Mnm | Effect | Example |
|---|---|---|---|---|
| 0000 | rs | LDA  | acc <- [rs]                        | `lda  r0`    |
| 0001 | rd | STA  | [rd] <- acc                        | `sta  r0`    |
| 0100 | 0000 | LDI  | acc <- [pc+1], pc <- pc + 1      | `ldi  42`    |
| 0101 | cond | B  | if cond then pc <- [pc + 1] else pc <- pc + 1 | `bcc  42`    |
| 0110 | rs | GET  | acc <- rs                        | `get  r0`    |
| 0111 | rs | SET  | rs <- acc                        | `set  r0`    |
| 1000 | rs | ADD  | acc <- acc + rs                       | `add  r0`    |
| 1001 | rs | SUB  | acc <- acc - rs                       | `sub  r0`    |
| 1010 | rd | INC  | rd <- rd + 1                       | `inc  r0`    |
| 1011 | rd | DEC  | rd <- rd - 1                       | `dec  r0`    |
| 1100 | rs | AND  | acc <- acc & rs                       | `and  r0`    |
| 1101 | rs | OR  | acc <- acc \| rs                       | `or  r0`    |
| 1110 | rs | XOR  | acc <- acc ^ rs                       | `xor  r0`    |
| 1111 | rs | SHFT  | if (rs >= 0) acc <- acc << rs else acc <- acc >> -rs | `shft  r0`    |

## Pseudo-instructions

| Pseudo-instruction | Actual instruction |
|---|---|
| `beq` | `bz` |
| `bne` | `bnz` |
| `bhs` | `bcs` |
| `blo` | `bcc` |

## Condition codes

| Condition | Meaning |
|---|---|
| 0000 | Unconditional |
| 0001 | Zero flag set |
| 0010 | Zero flag not set |
| 0011 | Carry flag set |
| 0100 | Carry flag not set |
| 0101 | Signed less than |
| 0110 | Signed greater than or equal |

# Assembly language

Assembly statements generally follow the following structure
```asm
[LABEL:] MNEMONIC [OPERAND[, OPERAND]...]
```
The available `MNEMONIC`s can be found in the table above. `OPERAND`s can be registers, constants, or labels. Labels used as operands must be prefixed with `@`:
```asm
loop: b @loop
```
When the operand is used as the contents of a memory address, it must be enclosed in square brackets:
```asm
ldi @inp
set r0
lda [r0]
.section data
inp: .db 0
```
Apart from these statements, the assembler recognizes the following directives:

- ```asm
  .include "FILE"
  ```

  Includes a given `FILE`. The path is relative to the file being processed.

- ```asm
  .section SECTION
  ```

  Define into which memory `SECTION` the subsequent code is assembled. Options are `code` and `data`. The default is `code`.

- ```asm
  .org ADDRESS
  ```

  Sets memory `ADDRESS` at which the subsequent code will be assembled.

- ```asm
  .equ LABEL VALUE
  ```

  Creates a `LABEL` for a specific constant `VALUE`. Values may be character constants, e.g. `"c"`

- ```asm
  .db VALUE
  ```

  Inserts a `VALUE` into the instruction stream. The value may be a string constant, e.g. `"Hello, world"`

- ```asm
  .macro NAME
  ; code
  .endmacro
  ```

  Defines a macro. The code inside the macro can use arguments of the form `$0`, `$1`, etc., which are replaced by the actual arguments when the macro is called using `NAME arg0, arg1`. Labels inside the macro that start with an underscore are localized such that the same macro can be called multiple times.

# Installation

```
pip install puc8a
```

or

```
git clone https://github.com/wcaarls/puc8a
cd puc8a
pip install .
```

# Usage

```
usage: as-puc8a [-h] [-o OUTPUT] [-s] [-t N] [-E] file

PUC8a Assembler (c) 2020-2025 Wouter Caarls, PUC-Rio

positional arguments:
  file                  ASM source file

options:
  -h, --help            show this help message and exit
  -o OUTPUT, --output OUTPUT
                        Output file
  -s, --simulate        Simulate resulting program
  -t N, --test N        Simulate for 1000 steps and check whether PC == N
  -E                    Output preprocessed assembly code

```

```
usage: cc-puc8a [-h] [-o OUTPUT] [-s] [-t N] [-S] [-O {0,1,2}] file

PUC8a C compiler (c) 2020-2025 Wouter Caarls, PUC-Rio

positional arguments:
  file                  C source file

options:
  -h, --help            show this help message and exit
  -o OUTPUT, --output OUTPUT
                        Output file
  -s, --simulate        Simulate resulting program
  -t N, --test N        Simulate for 1000 steps and check whether PC == N
  -S                    Output assembly code
  -O {0,1,2}            Optimization level

```

# Examples

Directly compile C to VHDL
```
./cc-puc8a examples/c/hello.c
```

Create assembly from C
```
./cc-puc8a examples/c/hello.c -S
```

Assemble to VHDL code
```
./as-puc8a examples/asm/ps2_lcd.asm
```

Assemble to VHDL package
```
./as-puc8a examples/asm/ps2_lcd.asm -o ps2_lcd.vhdl
```

Simulate resulting C or assembly program
```
./cc-puc8a -O0 examples/c/unittest.c -s
./as-puc8a examples/asm/simple.asm -s
```

# Acknowledgments

The C compiler is based on [PPCI](https://github.com/windelbouwman/ppci).

Copyright (c) 2011-2019, Windel Bouwman

All rights reserved.

Redistribution and use in source and binary forms, with or without
modification, are permitted provided that the following conditions are met:

1. Redistributions of source code must retain the above copyright notice, this
list of conditions and the following disclaimer.

2. Redistributions in binary form must reproduce the above copyright notice,
this list of conditions and the following disclaimer in the documentation
and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

            

Raw data

            {
    "_id": null,
    "home_page": "http://github.com/wcaarls/puc8a",
    "name": "puc8a",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "assembler compiler educational risc processor",
    "author": "Wouter Caarls",
    "author_email": "wouter@puc-rio.br",
    "download_url": "https://files.pythonhosted.org/packages/a7/4c/f434e6ce86e70e700e4d566360a2dd0c07b5d5f9b93b1b0b5e748472f3b2/puc8a-0.1.5.tar.gz",
    "platform": null,
    "description": "# PUC8a\n\nAssembler and C compiler for the PUC8a processor\n\nCopyright 2020-2025 Wouter Caarls\n\nThis program is free software: you can redistribute it and/or modify\nit under the terms of the GNU General Public License as published by\nthe Free Software Foundation, either version 3 of the License, or\n(at your option) any later version.\n\nThis program is distributed in the hope that it will be useful,\nbut WITHOUT ANY WARRANTY; without even the implied warranty of\nMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\nGNU General Public License for more details.\n\nYou should have received a copy of the GNU General Public License\nalong with this program.  If not, see <http://www.gnu.org/licenses/>.\n\n# Introduction\n\nPUC8a is an accumulator-based microcontroller with 8-bit registers. It is used in the\nENG1448 course of PUC-Rio. This is the assembler and C compiler\ninfrastructure for it.\n\n# Instruction set architecture\n\nThis very simple processor is a Harvard design, with 8-bit instructions and 8-bit data values.\nBoth instruction and data memories have 256 addresses.\n\n## Registers\n\nThere are 16 registers. `r14` is `sp`; `r15` is `pc`. The C compiler uses `r13` as `fp`.\n\n## Instructions\n\nAll ALU instructions set flags.\n\n| Opcode(4)  | Data(4) | Mnm | Effect | Example |\n|---|---|---|---|---|\n| 0000 | rs | LDA  | acc <- [rs]                        | `lda  r0`    |\n| 0001 | rd | STA  | [rd] <- acc                        | `sta  r0`    |\n| 0100 | 0000 | LDI  | acc <- [pc+1], pc <- pc + 1      | `ldi  42`    |\n| 0101 | cond | B  | if cond then pc <- [pc + 1] else pc <- pc + 1 | `bcc  42`    |\n| 0110 | rs | GET  | acc <- rs                        | `get  r0`    |\n| 0111 | rs | SET  | rs <- acc                        | `set  r0`    |\n| 1000 | rs | ADD  | acc <- acc + rs                       | `add  r0`    |\n| 1001 | rs | SUB  | acc <- acc - rs                       | `sub  r0`    |\n| 1010 | rd | INC  | rd <- rd + 1                       | `inc  r0`    |\n| 1011 | rd | DEC  | rd <- rd - 1                       | `dec  r0`    |\n| 1100 | rs | AND  | acc <- acc & rs                       | `and  r0`    |\n| 1101 | rs | OR  | acc <- acc \\| rs                       | `or  r0`    |\n| 1110 | rs | XOR  | acc <- acc ^ rs                       | `xor  r0`    |\n| 1111 | rs | SHFT  | if (rs >= 0) acc <- acc << rs else acc <- acc >> -rs | `shft  r0`    |\n\n## Pseudo-instructions\n\n| Pseudo-instruction | Actual instruction |\n|---|---|\n| `beq` | `bz` |\n| `bne` | `bnz` |\n| `bhs` | `bcs` |\n| `blo` | `bcc` |\n\n## Condition codes\n\n| Condition | Meaning |\n|---|---|\n| 0000 | Unconditional |\n| 0001 | Zero flag set |\n| 0010 | Zero flag not set |\n| 0011 | Carry flag set |\n| 0100 | Carry flag not set |\n| 0101 | Signed less than |\n| 0110 | Signed greater than or equal |\n\n# Assembly language\n\nAssembly statements generally follow the following structure\n```asm\n[LABEL:] MNEMONIC [OPERAND[, OPERAND]...]\n```\nThe available `MNEMONIC`s can be found in the table above. `OPERAND`s can be registers, constants, or labels. Labels used as operands must be prefixed with `@`:\n```asm\nloop: b @loop\n```\nWhen the operand is used as the contents of a memory address, it must be enclosed in square brackets:\n```asm\nldi @inp\nset r0\nlda [r0]\n.section data\ninp: .db 0\n```\nApart from these statements, the assembler recognizes the following directives:\n\n- ```asm\n  .include \"FILE\"\n  ```\n\n  Includes a given `FILE`. The path is relative to the file being processed.\n\n- ```asm\n  .section SECTION\n  ```\n\n  Define into which memory `SECTION` the subsequent code is assembled. Options are `code` and `data`. The default is `code`.\n\n- ```asm\n  .org ADDRESS\n  ```\n\n  Sets memory `ADDRESS` at which the subsequent code will be assembled.\n\n- ```asm\n  .equ LABEL VALUE\n  ```\n\n  Creates a `LABEL` for a specific constant `VALUE`. Values may be character constants, e.g. `\"c\"`\n\n- ```asm\n  .db VALUE\n  ```\n\n  Inserts a `VALUE` into the instruction stream. The value may be a string constant, e.g. `\"Hello, world\"`\n\n- ```asm\n  .macro NAME\n  ; code\n  .endmacro\n  ```\n\n  Defines a macro. The code inside the macro can use arguments of the form `$0`, `$1`, etc., which are replaced by the actual arguments when the macro is called using `NAME arg0, arg1`. Labels inside the macro that start with an underscore are localized such that the same macro can be called multiple times.\n\n# Installation\n\n```\npip install puc8a\n```\n\nor\n\n```\ngit clone https://github.com/wcaarls/puc8a\ncd puc8a\npip install .\n```\n\n# Usage\n\n```\nusage: as-puc8a [-h] [-o OUTPUT] [-s] [-t N] [-E] file\n\nPUC8a Assembler (c) 2020-2025 Wouter Caarls, PUC-Rio\n\npositional arguments:\n  file                  ASM source file\n\noptions:\n  -h, --help            show this help message and exit\n  -o OUTPUT, --output OUTPUT\n                        Output file\n  -s, --simulate        Simulate resulting program\n  -t N, --test N        Simulate for 1000 steps and check whether PC == N\n  -E                    Output preprocessed assembly code\n\n```\n\n```\nusage: cc-puc8a [-h] [-o OUTPUT] [-s] [-t N] [-S] [-O {0,1,2}] file\n\nPUC8a C compiler (c) 2020-2025 Wouter Caarls, PUC-Rio\n\npositional arguments:\n  file                  C source file\n\noptions:\n  -h, --help            show this help message and exit\n  -o OUTPUT, --output OUTPUT\n                        Output file\n  -s, --simulate        Simulate resulting program\n  -t N, --test N        Simulate for 1000 steps and check whether PC == N\n  -S                    Output assembly code\n  -O {0,1,2}            Optimization level\n\n```\n\n# Examples\n\nDirectly compile C to VHDL\n```\n./cc-puc8a examples/c/hello.c\n```\n\nCreate assembly from C\n```\n./cc-puc8a examples/c/hello.c -S\n```\n\nAssemble to VHDL code\n```\n./as-puc8a examples/asm/ps2_lcd.asm\n```\n\nAssemble to VHDL package\n```\n./as-puc8a examples/asm/ps2_lcd.asm -o ps2_lcd.vhdl\n```\n\nSimulate resulting C or assembly program\n```\n./cc-puc8a -O0 examples/c/unittest.c -s\n./as-puc8a examples/asm/simple.asm -s\n```\n\n# Acknowledgments\n\nThe C compiler is based on [PPCI](https://github.com/windelbouwman/ppci).\n\nCopyright (c) 2011-2019, Windel Bouwman\n\nAll rights reserved.\n\nRedistribution and use in source and binary forms, with or without\nmodification, are permitted provided that the following conditions are met:\n\n1. Redistributions of source code must retain the above copyright notice, this\nlist of conditions and the following disclaimer.\n\n2. Redistributions in binary form must reproduce the above copyright notice,\nthis list of conditions and the following disclaimer in the documentation\nand/or other materials provided with the distribution.\n\nTHIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\" AND\nANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\nWARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE\nDISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE\nFOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL\nDAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR\nSERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER\nCAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,\nOR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE\nOF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.\n",
    "bugtrack_url": null,
    "license": "GPL-3.0-or-later",
    "summary": "Assembler and C compiler for the PUC8a processor",
    "version": "0.1.5",
    "project_urls": {
        "Homepage": "http://github.com/wcaarls/puc8a"
    },
    "split_keywords": [
        "assembler",
        "compiler",
        "educational",
        "risc",
        "processor"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "14516efca66347ba2404b55a4979c270e4ee6e8500da0d0146e17fe7a412c9ed",
                "md5": "78ff183b901f9c62a60acc48be174d7a",
                "sha256": "d0ccbf795af7b719c0d583dc9ca29fd8f8f0fd2df0b02b5d018468345a27188c"
            },
            "downloads": -1,
            "filename": "puc8a-0.1.5-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "78ff183b901f9c62a60acc48be174d7a",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 347967,
            "upload_time": "2025-08-08T18:48:16",
            "upload_time_iso_8601": "2025-08-08T18:48:16.873865Z",
            "url": "https://files.pythonhosted.org/packages/14/51/6efca66347ba2404b55a4979c270e4ee6e8500da0d0146e17fe7a412c9ed/puc8a-0.1.5-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "a74cf434e6ce86e70e700e4d566360a2dd0c07b5d5f9b93b1b0b5e748472f3b2",
                "md5": "36980db13bc3febb9f43588009f9690a",
                "sha256": "48669a89e76f3b7fac3769220b30bd8229f4dbcf60ba6a2243823a415f944b16"
            },
            "downloads": -1,
            "filename": "puc8a-0.1.5.tar.gz",
            "has_sig": false,
            "md5_digest": "36980db13bc3febb9f43588009f9690a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 289448,
            "upload_time": "2025-08-08T18:48:18",
            "upload_time_iso_8601": "2025-08-08T18:48:18.676953Z",
            "url": "https://files.pythonhosted.org/packages/a7/4c/f434e6ce86e70e700e4d566360a2dd0c07b5d5f9b93b1b0b5e748472f3b2/puc8a-0.1.5.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-08-08 18:48:18",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "wcaarls",
    "github_project": "puc8a",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "lcname": "puc8a"
}
        
Elapsed time: 0.75611s