Instrucción: ST |
|||||||||
|
|||||||||
Código de Operación de 16 bit |
|||||||||
1001 |
001r | rrrr | 1010 |
Operación: | Y Ü Y - 1, (Y) Ü Rr |
Operandos: | 0 £ r £ 31 |
Words: | 1 (2 bytes) |
Ciclos: | 2 |
Flags: | Ninguno |
Program Counter: | PC Ü PC + 1 |
Descripción: ST guarda un byte indirecto sin desplazamiento de un registro en el espacio de datos. Para los dispositivos con SRAM, el espacio de datos se compone del archivo de registro, memoria de I/O y SRAM interna (y SRAM externa si es aplicable). Para las dispositivos sin SRAM, el espacio de datos se compone sólo del archivo de registro. La EEPROM tiene un espacio de direcciones separado. La posición de los datos es apuntada por el registro puntero Y (16 bits) en el archivo de registro. Se limita el acceso de memoria al segmento de datos de 64K bytes. Para acceder a otro segmento de datos en dispositivos con más de 64K bytes de espacio de datos, el RAMPY en el área de I/O tiene que ser cambiado. El registro puntero Y puede quedar inalterado por el funcionamiento, puede post-incrementarse o pre-decrementarse. En este caso es pre-decrementado. Estas características están especialmente preparadas para acceder a arrays, tablas y para el uso de puntero de pila del registro puntero Y. Note que sólo el byte bajo del puntero Y se pone al día en dispositivos sin más de 256 bytes de espacio de datos. Para tales dispositivos, el byte alto del indicador no es usado por esta instrucción y puede usarse para otros propósitos. El registro RAMPX en el área de I/O se pone al día en dispositivos con más de 64K bytes de espacio de datos y el desplazamiento se agrega a la dirección de 24-bit en tales dispositivos. El resultado de estas combinaciones es indefinido: |
|
|
|
|
|
|
|
|
|
Ejemplo: |
|
CLR r29 | ; Borrar el byte alto de Y |
LDI r28,$60 |
; Poner el byte bajo de Y a $60 |
ST Y+,r0 |
; Guardar r0 en la posición del espacio de datos $60 |
; (Y post-increentado) | |
ST Y,r1 |
; Guardar r1 en la posición del espacio de datos $61 |
LDI r28,$63 |
; Poner el byte bajo de Y a $63 |
ST Y,r2 |
; Guardar r2 en la posición del espacio de datos $63 |
ST -Y,r3 |
; Guardar r3 en la posición del espacio de datos $62 |
; (Y pre-decrementado) | |
STD Y+2,r4 | ; Guardar r4 en la posición del espacio de datos $64 |