even more
This commit is contained in:
parent
a8abdb667a
commit
da7317ced2
2
.gitignore
vendored
2
.gitignore
vendored
@ -50,3 +50,5 @@ modules.order
|
|||||||
Module.symvers
|
Module.symvers
|
||||||
Mkfile.old
|
Mkfile.old
|
||||||
dkms.conf
|
dkms.conf
|
||||||
|
|
||||||
|
bin
|
20
README.md
20
README.md
@ -38,17 +38,17 @@
|
|||||||
| 0x5 | PC | Program Counter |
|
| 0x5 | PC | Program Counter |
|
||||||
| 0x6 | SP | Stack Pointer |
|
| 0x6 | SP | Stack Pointer |
|
||||||
|
|
||||||
| Area of RAM | reserved | usage |
|
| Area of RAM | reserved | Writable | usage |
|
||||||
|:-------------:|:--------:|-------------------|
|
|:-------------:|:--------:|:--------:|-------------------|
|
||||||
| 00000 - 00064 | YES | system header |
|
| 00000 - 00064 | YES | NO | system header |
|
||||||
| 00064 - 65263 | NO | executable |
|
| 00064 - 65023 | NO | YES | executable |
|
||||||
| 65263 - 65519 | YES | interupt pointers |
|
| 65023 - 65279 | YES | YES | interupt pointers |
|
||||||
| 65519 - 65535 | YES | stack |
|
| 65279 - 65535 | YES | YES | stack |
|
||||||
|
|
||||||
| BYTE 1 | | | BYTE 2 | BYTE 2 |
|
| BYTE 1 | | | | BYTE 2 | BYTE 2 |
|
||||||
|------------|-------------|-------------|------------|------------|
|
|--------|--------|------------|------------|------------|------------|
|
||||||
| OPCODE | arg 1 info | arg 2 info | ARGUMENT 1 | ARGUMENT 2 |
|
| OPCODE | UNUSED | ARG 1 INFO | ARG 2 INFO | ARGUMENT 1 | ARGUMENT 2 |
|
||||||
| bit 0 - 12 | bit 12 - 14 | bit 14 - 16 | bit 0 - 16 | bit 0 - 16 |
|
| 8 bits | 4 bits | 2 bits | 2 bits | 16 bits | 16 bits |
|
||||||
|
|
||||||
| State | Argument Interpretation |
|
| State | Argument Interpretation |
|
||||||
|------:|---------------------------------------------|
|
|------:|---------------------------------------------|
|
||||||
|
2
build.sh
Executable file
2
build.sh
Executable file
@ -0,0 +1,2 @@
|
|||||||
|
mkdir ./bin
|
||||||
|
clang -o ./bin/r16e ./emu/main.c ./emu/cpu/ram.c ./lib/carg-parse/carg-parse.c
|
28
emu/cpu/ram.c
Normal file
28
emu/cpu/ram.c
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
#include "ram.h"
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
r16_int* ram = NULL;
|
||||||
|
|
||||||
|
void InitRam()
|
||||||
|
{
|
||||||
|
ram = (r16_int*)malloc(sizeof(r16_int) * UINT16_MAX);
|
||||||
|
}
|
||||||
|
|
||||||
|
r16_int GetValue(r16_int address)
|
||||||
|
{
|
||||||
|
#ifdef RAM_DO_NULL_CHECK
|
||||||
|
if (ram == NULL) { InitRam(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return ram[address.u];
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetValue(r16_int address, r16_int value)
|
||||||
|
{
|
||||||
|
#ifdef RAM_DO_NULL_CHECK
|
||||||
|
if (ram == NULL) { InitRam(); }
|
||||||
|
#endif
|
||||||
|
|
||||||
|
ram[address.u] = value;
|
||||||
|
}
|
18
emu/cpu/ram.h
Normal file
18
emu/cpu/ram.h
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
#ifndef EMU_CPU_RAM_H
|
||||||
|
#define EMU_CPU_RAM_H
|
||||||
|
|
||||||
|
#define RAM_DO_NULL_CHECK
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
typedef union
|
||||||
|
{
|
||||||
|
int16_t s;
|
||||||
|
uint16_t u;
|
||||||
|
} r16_int;
|
||||||
|
|
||||||
|
void InitRam();
|
||||||
|
void SetValue(r16_int address, r16_int value);
|
||||||
|
r16_int GetValue(r16_int address);
|
||||||
|
|
||||||
|
#endif
|
37
emu/cpu/register.c
Normal file
37
emu/cpu/register.c
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
#include "./register.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
r16_int r0, r1, r2, r3, acu, pc, sp;
|
||||||
|
|
||||||
|
r16_int *GetRegPoint(CpuRegisters reg)
|
||||||
|
{
|
||||||
|
switch (reg)
|
||||||
|
{
|
||||||
|
case R0:
|
||||||
|
return &r0;
|
||||||
|
case R1:
|
||||||
|
return &r1;
|
||||||
|
case R2:
|
||||||
|
return &r2;
|
||||||
|
case R3:
|
||||||
|
return &r3;
|
||||||
|
case ACU:
|
||||||
|
return &acu;
|
||||||
|
case PC:
|
||||||
|
return &pc;
|
||||||
|
case SP:
|
||||||
|
return &sp;
|
||||||
|
}
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
r16_int GetRegister(CpuRegisters reg)
|
||||||
|
{
|
||||||
|
return *(GetRegPoint(reg));
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetRegister(CpuRegisters reg, r16_int value)
|
||||||
|
{
|
||||||
|
*(GetRegPoint(reg)) = value;
|
||||||
|
}
|
10
emu/cpu/register.h
Normal file
10
emu/cpu/register.h
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
#ifndef EMU_CPU_REGISTER_H
|
||||||
|
#define EMU_CPU_REGISTER_H
|
||||||
|
|
||||||
|
#include "../cpu_const.h"
|
||||||
|
#include "./ram.h"
|
||||||
|
|
||||||
|
r16_int GetRegister(CpuRegisters reg);
|
||||||
|
void SetRegister(CpuRegisters reg, r16_int value);
|
||||||
|
|
||||||
|
#endif
|
13
emu/cpu/stack.c
Normal file
13
emu/cpu/stack.c
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
#include "./stack.h"
|
||||||
|
|
||||||
|
r16_int pop()
|
||||||
|
{
|
||||||
|
#ifdef DO_STACK_CHECKS
|
||||||
|
if ()
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void push(r16_int value)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
12
emu/cpu/stack.h
Normal file
12
emu/cpu/stack.h
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
#ifndef EMU_CPU_STACK_H
|
||||||
|
#define EMU_CPU_STACK_H
|
||||||
|
|
||||||
|
#include "./ram.h"
|
||||||
|
#include "./register.h"
|
||||||
|
|
||||||
|
#define STACK_SIZE 256
|
||||||
|
#define STACK_LOCATION (UINT16_MAX - STACK_SIZE)
|
||||||
|
|
||||||
|
#define DO_STACK_CHECKS
|
||||||
|
|
||||||
|
#endif
|
@ -1,6 +1,8 @@
|
|||||||
#ifndef EMU_CPU_CONST_H
|
#ifndef EMU_CPU_CONST_H
|
||||||
#define EMU_CPU_CONST_H
|
#define EMU_CPU_CONST_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
HLT = 0x00,
|
HLT = 0x00,
|
||||||
@ -44,12 +46,12 @@ typedef enum
|
|||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
value = 0x0,
|
value = 0x0,
|
||||||
register = 0x1,
|
valueInRegister = 0x1,
|
||||||
ram = 0x2,
|
valueInRam = 0x2,
|
||||||
pointerInRegister = 0x3
|
pointerInRegister = 0x3
|
||||||
} ArgumentInfo;
|
} ArgumentInfo;
|
||||||
|
|
||||||
#define INSTRUCTION_BIT_MASK 0b1111111111110000
|
#define INSTRUCTION_BIT_MASK 0b1111111100000000
|
||||||
#define INSTRUCTION_ARG_1_INFO_MASK 0b0000000000001100
|
#define INSTRUCTION_ARG_1_INFO_MASK 0b0000000000001100
|
||||||
#define INSTRUCTION_ARG_2_INFO_MASK 0b0000000000000011
|
#define INSTRUCTION_ARG_2_INFO_MASK 0b0000000000000011
|
||||||
|
|
||||||
|
14
emu/main.c
Normal file
14
emu/main.c
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
#include "../lib/carg-parse/carg-parse.h"
|
||||||
|
#include "./cpu_const.h"
|
||||||
|
|
||||||
|
int main(int argc, char **argv)
|
||||||
|
{
|
||||||
|
carg_parse_data* args = carg_parse(argc, argv);
|
||||||
|
|
||||||
|
carg_parse_free(args);
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user