Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/yaacov/smart-tools
SMART (Simple Machine Assembly and Runtime Tools) is a comprehensive suite designed to introduce students to the world of assembly language and low-level computing.
https://github.com/yaacov/smart-tools
assembler assembly cpu-emulator educational emulator hacktoberfest virtual visual-asembler
Last synced: 3 months ago
JSON representation
SMART (Simple Machine Assembly and Runtime Tools) is a comprehensive suite designed to introduce students to the world of assembly language and low-level computing.
- Host: GitHub
- URL: https://github.com/yaacov/smart-tools
- Owner: yaacov
- License: gpl-3.0
- Created: 2023-09-27T21:34:28.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-11-21T07:26:58.000Z (about 1 year ago)
- Last Synced: 2024-04-15T06:51:17.511Z (9 months ago)
- Topics: assembler, assembly, cpu-emulator, educational, emulator, hacktoberfest, virtual, visual-asembler
- Language: JavaScript
- Homepage:
- Size: 584 KB
- Stars: 7
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.ASM.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# SMART Assembly Language Tutorial
Welcome to the SMART Assembly Language tutorial! SMART stands for **Simple Machine Architecture & Runtime**. This assembly language is designed to be both simple and comprehensive, making it perfect for educational purposes. It provides a balanced approach to help students understand the foundational concepts of assembly programming without overwhelming them with intricate details.
In this guide, we'll introduce you to the basics of the SMART Assembly language, its opcodes, and how to write simple programs. Let's dive in!
## Table of Contents
- [Introduction](#introduction)
- [Opcodes](#opcodes)
- [Comments and Labels](#comments-and-labels)
- [Writing a Simple Program](#writing-a-simple-program)
- [Conclusion](#conclusion)## Introduction
SMART Assembly is a simple assembly language designed for educational purposes. It provides a set of basic opcodes to perform arithmetic, logical, and control flow operations.
## Opcodes
Here's a list of available opcodes in the SMART Assembly language:
### Register operations
- `LOADA `: Load the value from the memory location specified by `` into register A.
- `LOADB `: Load the value from the memory location specified by `` into register B.
- `STOREA `: Store the value from register A into the memory location specified by ``.
- `STOREB `: Store the value from register B into the memory location specified by ``.### Flow Commands
- `NOP`: No operation, move the program counter.
- `JUMP `: Jump to the address specified by ``.
- `JZA `: Jump to the address specified by `` if register A is zero.
- `JZB `: Jump to the address specified by `` if register B is zero.
- `END`: End the program execution.### Logic Commands
- `ORA `: Perform a bitwise OR operation between register A and the value at ``, storing the result in register A.
- `ORB `: Perform a bitwise OR operation between register B and the value at ``, storing the result in register B.
- `ANDA `: Perform a bitwise AND operation between register A and the value at ``, storing the result in register A.
- `ANDB `: Perform a bitwise AND operation between register B and the value at ``, storing the result in register B.
- `XORA `: Perform a bitwise XOR operation between register A and the value at ``, storing the result in register A.
- `XORB `: Perform a bitwise XOR operation between register B and the value at ``, storing the result in register B.
- `NOTA`: Perform a bitwise NOT operation on register A.
- `NOTB`: Perform a bitwise NOT operation on register B.### Arithmetic Commands
- `ADDA `: Add the value from the memory location specified by `` to register A.
- `ADDB `: Add the value from the memory location specified by `` to register B.
- `SHLA `: Shift the bits in register A to the left by `` positions.
- `SHLB `: Shift the bits in register B to the left by `` positions.
- `SHRA `: Shift the bits in register A to the right by `` positions.
- `SHRB `: Shift the bits in register B to the right by `` positions.### Stack Commands
- `PUSHA`: Push the value from register A onto the stack.
- `POPA`: Pop the top value from the stack into register A.
- `CALL `: Call a subroutine.
- `RET`: Return from a subroutine.
- `SETBP `: Set the Base Pointer for stack operations.
- `LOADA [BP + ]`: Load a value from the stack into register A using the Base Pointer and offset.
- `STOREA [BP + ]`: Store a value from register A onto the stack using the Base Pointer and offset.## Case insensitive
In SMART Assembly, case sensitivity is not enforced, meaning that the syntax recognizes labels and commands irrespective of letter casing. For instance, the label `START:` is equivalent to `start:`, and similarly, commands can be written in either lowercase or uppercase without affecting their functionality. Thus, `loada` and `LOADA` are interpreted as the same command.
## Comments and Labels
### Comments
In SMART Assembly, comments are denoted by a semicolon (`;`). Anything following a semicolon on a line is considered a comment and is ignored by the assembler.
Example:
```assembly
; This is a comment and will be ignored by the assembler
LOADA NUM1 ; This loads the value at NUM1 into register A
```### Labels
Labels are used to mark specific locations in the code. They are followed by a colon (:) and can be used as operands for certain opcodes. Labels are especially useful for jumps and data storage.
Example:
```assembly
START: ; This is a label named START
LOADA NUM1 ; Use the label NUM1 as an operand
```## Stack opration
The stack is a crucial data structure in SMART Assembly, facilitating temporary storage, parameter passing, and return address handling during subroutine calls. It operates on a Last-In-First-Out (LIFO) principle, where the last value pushed onto the stack is the first to be popped off.
Before utilizing stack operations, it's imperative to set the stack's start address using the SETBP opcode. If SETBP is not used, the stack pointer is set to zero, which could lead to unwanted behavior.
```assembly
SETBP STACK; rest of your program code;
; ...; start of stack memory
STACK:
; make sure to leave this memory empty for the stack to grow into it
```The stack is particularly useful for:
- Parameter Passing: Parameters can be pushed onto the stack before a subroutine call, and then accessed within the subroutine using the LOADABP and STOREABP opcodes.
- Return Address Handling: When a subroutine is called using the CALL opcode, the return address is automatically pushed onto the stack, to be retrieved later by the RET opcode.
- Local Variable Storage: Local variables can be stored on the stack, providing temporary data storage that is cleaned up when the subroutine exits.
- Nested and Recursive Calls: The stack allows for nested and recursive subroutine calls, each with its own set of parameters, local variables, and return address.See [recursive-fact.asm](./examples/recursive-fact.asm) code for function call example.
## Writing a Simple Program
Let's write a simple program to add two numbers:
```assembly
; This program adds two numbers and stores the result
START: LOADA NUM1 ; Load the first number into register A
ADDA NUM2 ; Add the value at NUM2 to register A
STOREA RESULT ; Store the resultEND ; End the program
NUM1: DATA 0x05 ; 5 in decimal
NUM2: DATA 0x03 ; 3 in decimal
RESULT: DATA 0x00 ; Placeholder for the result
```This example uses the stack to swap two numbers:
```assembly
SETBP STACK ; Init the stack pointer (base pointer); Push the pop to swap NUM1 with NUM2
LOADA NUM1
PUSHA
LOADA NUM2
PUSHAPOPA
STOREA NUM1
POPA
STOREA NUM2END ; End program
NUM1: DATA 0xF0
NUM2: DATA 0x0FSTACK: ; start of stack memory
```
In this program, we first load the first number into register A. We then add the second number to register A and store the result.Foe more examples see [examples](./examples/).
## Conclusion
This tutorial introduced you to the basics of the SMART Assembly language, including its opcodes, comments, and labels. With this knowledge, you can start writing your own programs and exploring more advanced features of the language.