summaryrefslogtreecommitdiff
path: root/app/descifrador.s
blob: bb10e87867d4fc4450baca6eeaf4ba97d6abda4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
.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

@ Dirección inicial de lectura, contador y tamaño de la imagen
ldr r1, =START
mov  r7, #0x0
ldr r8, =307200

@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 
  cmp r5, #1    @ Si el botón de inicio es 1, se salta a start
  bne  idle

@ Verificar el algoritmo seleccionado
  and r10, r6, #1  @ Bit mask para seleccionar el primer bit de los switches
  cmp r10, #1    	@ Si el valor es 1, se salta a not, si es 0 a xor
  beq not
  cmp r10, #0
  beq  xor
  

@ Recorrer la memoria desde START y hacer not al valor en cada posicion
@ y volverlo a guardar
not:
  @Procesar la mask
	mov r9, #0b11111111     @Hacer mask de 1s
	mov r0, r9, lsl #8      
	orr r0, r0, r9, lsl #16
	orr r0, r0, r9, lsl #24
	b loop

xor:
@Procesar la llave
	lsr r9, r6, #1
	mov r0, r9, lsl #8
	orr r0, r0, r9, lsl #16
	orr r0, r0, r9, lsl #24

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 y 46
  str  r4, [r1]   	@ Vuelve a guardar en memoria ya modificado
  add  r1, r1, #4  	@ Incrementa el valor de r4, para ir al siguiente pixel
  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
  b  halt

halt:
  b halt