summaryrefslogtreecommitdiff
path: root/tb/sim
diff options
context:
space:
mode:
authorAlejandro Soto <alejandro@34project.org>2023-10-04 16:46:57 -0600
committerAlejandro Soto <alejandro@34project.org>2023-10-04 16:46:57 -0600
commit865a1e8ca820da17a9f9c034677a7a959ddaee36 (patch)
tree8331511442ce7746e58fb798b2ad036915ac68be /tb/sim
parent972678950297ab158541a8afec2cbcd01a996959 (diff)
app, doc, image_processing, tb/sim/descifrador: remove;5D
Diffstat (limited to 'tb/sim')
-rw-r--r--tb/sim/descifrador.S72
-rw-r--r--tb/sim/descifrador.py20
2 files changed, 0 insertions, 92 deletions
diff --git a/tb/sim/descifrador.S b/tb/sim/descifrador.S
deleted file mode 100644
index 84b529c..0000000
--- a/tb/sim/descifrador.S
+++ /dev/null
@@ -1,72 +0,0 @@
-.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
deleted file mode 100644
index a77375b..0000000
--- a/tb/sim/descifrador.py
+++ /dev/null
@@ -1,20 +0,0 @@
-LOG = 'image_processing/log'
-FILE = 'image_processing/out_file'
-SIZE = 640 * 480 * 4
-START = 0x10000
-
-loads = {START: FILE}
-consts = {0x30050000: 1, 0x30060000: 0}
-cycles = 23000000
-mem_dumps = [range(START, START + SIZE)]
-enable_video = True
-
-def final():
- words = []
- with open(FILE, 'rb') as file:
- while data := file.read(4):
- words.append(int.from_bytes(data, 'little') ^ 0x00ffffff)
-
- assert_mem(START, words)
- with open(LOG, 'w') as log:
- print(read_mem(START, SIZE), file=log)