summaryrefslogtreecommitdiff
path: root/tb/sim
diff options
context:
space:
mode:
authorJulianCamacho <jjulian.341@gmail.com>2022-11-17 08:16:14 -0600
committerJulianCamacho <jjulian.341@gmail.com>2022-11-17 08:16:14 -0600
commit61bf2100fbd5e0a5f4bd1f013d70d8027604bbba (patch)
treef8dda309768c57d3cbce052baf7b094ff996374a /tb/sim
parent268512c3f2c67bb72f0dab45b8112313fd585e2c (diff)
Bug fixes
Diffstat (limited to '')
-rw-r--r--tb/sim/blank.S13
-rw-r--r--tb/sim/blank.py2
-rw-r--r--tb/sim/descifrador.S72
-rw-r--r--tb/sim/descifrador.py2
4 files changed, 89 insertions, 0 deletions
diff --git a/tb/sim/blank.S b/tb/sim/blank.S
new file mode 100644
index 0000000..ea8b6e5
--- /dev/null
+++ b/tb/sim/blank.S
@@ -0,0 +1,13 @@
+.global reset
+
+reset:
+ ldr r0, =0x38000000
+ ldr r1, =0xffffffff
+ ldr r2, =(640*480)
+
+ .loop:
+ str r1, [r0], #4
+ subs r2, r2, #1
+ bne .loop
+
+ mov pc, lr \ No newline at end of file
diff --git a/tb/sim/blank.py b/tb/sim/blank.py
new file mode 100644
index 0000000..8fda8b8
--- /dev/null
+++ b/tb/sim/blank.py
@@ -0,0 +1,2 @@
+def final():
+ pass \ No newline at end of file
diff --git a/tb/sim/descifrador.S b/tb/sim/descifrador.S
new file mode 100644
index 0000000..84b529c
--- /dev/null
+++ b/tb/sim/descifrador.S
@@ -0,0 +1,72 @@
+.global reset
+reset:
+
+@ IO utilizado:
+@ 5 switches para la llave
+@ 1 switch de selección de algoritmo (xor o not)
+@ 1 botón de inicio
+
+.equ START_BUTTON, 0x30050000 @ Dirección de memoria del botón
+.equ KEY_SWITCHES, 0x30060000 @ Dirección de memoria de los switches
+.equ START, 0x00010000 @ Dirección de memoria de los pixeles
+.equ VRAM, 0x38000000
+
+@ Dirección inicial de lectura, contador y tamaño de la imagen
+ldr r1, =START
+ldr r11, =VRAM
+mov r7, #0x0
+ldr r8, =(640*480)
+
+init:
+ ldr r4, [r1], #4 @ Guarda en r4 el dato en la posición de memoria de start
+ str r4, [r11], #4 @ Vuelve a guardar en memoria ya modificado
+ add r7, r7, #1 @ Incrementa contador de tamaño de la imagen
+ cmp r7, r8 @ Compara contador con tamaño de la imagen 640 * 480
+ bne init
+
+ldr r1, =START
+ldr r11, =VRAM
+mov r7, #0x0
+
+@Esperar botón
+ldr r2, =START_BUTTON
+ldr r3, =KEY_SWITCHES
+
+idle:
+ ldr r5, [r2] @ Lee valor del botón
+ ldr r6, [r3] @ Lee valores de los switches
+ tst r5, #1 @ Si el botón de inicio es 1, se salta a start
+ beq idle
+
+@ Verificar el algoritmo seleccionado
+tst r6, #1 @ Si el valor es 1, se salta a xor, si es 0 a not
+bne xor
+
+@ Recorrer la memoria desde START y hacer not al valor en cada posicion
+@ y volverlo a guardar
+not:
+ @Procesar la mask
+ ldr r0, =0x00ffffff
+ b loop
+
+xor:
+@Procesar la llave
+ lsr r9, r6, #1
+ mov r0, r9
+ orr r0, r0, r9, lsl #8
+ orr r0, r0, r9, lsl #16
+
+loop:
+ ldr r4, [r1] @ Guarda en r4 el dato en la posición de memoria de start
+ eor r4, r4, r0 @ Hace XOR entre r4
+ str r4, [r1], #4 @ Vuelve a guardar en memoria ya modificado
+ add r7, r7, #1 @ Incrementa contador de tamaño de la imagen
+ cmp r7, r8 @ Compara contador con tamaño de la imagen 640 * 480
+ bne loop
+
+release:
+ ldr r5, [r2] @ Lee valor del botón
+ tst r5, #1 @ Si el botón de inicio es 1, se salta a start
+ bne release
+
+ b reset \ No newline at end of file
diff --git a/tb/sim/descifrador.py b/tb/sim/descifrador.py
new file mode 100644
index 0000000..8fda8b8
--- /dev/null
+++ b/tb/sim/descifrador.py
@@ -0,0 +1,2 @@
+def final():
+ pass \ No newline at end of file