almacenar un valor de un entero sin signo (2bytes de largo) a una variable de caracteres sin signo utilizando operadores bit a bit?
-
06-07-2019 - |
Pregunta
¿Cómo pongo el valor de 0x04 en el registro 4 si el instrucción era 1rxy? 1RXY-Cargar registro R con el valor en la dirección de memoria XY
#include <stdio.h>
unsigned char r0,r1,r2,r3,r4,r5,r6,r7,r8,r9,ra,rb,rc,rd,re,rf;
void reg_check(unsigned char reg);
void rxy1(unsigned char reg, unsigned char val);
int main(){
unsigned char memloc1=0x14;
unisgned char memloc2=0x04;
unsigned char temp,reg,val_add;
temp=(x && 0xFF00) >> 8;
if (temp = 0xB){
reg=(memloc1 &0x0F);
val_add=memloc2;
rxy1(reg,val_add);
}
return 0;
}
void reg_check(unsigned char reg){
}
void rxy1(unsigned char reg, unsigned char val){
La instrucción real es 0x1404, esta dividida en dos bytes, memloc1 y memloc2. De acuerdo con el formato de 1rxy, que significa poner valor '' en '' ubicación de memoria xy en el registro r.
así que aquí el registro 4 o unsigned char r4
tendría que mantener el valor en la ubicación de memoria 0x04 que contendría algún otro número.
Mi pregunta es cómo pruebo la variable de registro determinando la " r " o 1 " r " xy en 1 " 4 " 04 y colocando el valor contenido en la ubicación xy en la variable de caracteres sin firmar r4
por ejemplo, si la ubicación de memoria 0x04
contenía 0xFB
.
Espero que esto tenga sentido.
[editar] Ejemplo
#include <stdio.h>
int main(){
unsigned char r0,r2,r3,r4;
unsigned char mem1=0x14; //at lmemory address 00
unsigned char mem2=0x04; //at lmemory address 01
unsigned char reg_val_store=mem1 & 0x0F;
if( ((mem1= & 0xF0) >> 4) == 0x1){
if (reg_val_store == 0x4){
//then put value store at memory address "04" into register 4.
//and just say for example "0xFD" was at memory location "04"
//since register value is 4 from the instruction read in 0x1"4"04
//i want to put 0xFD in the r4 unsigned char variable, how do i do this?
r4=0xFD; // this is of course correct but the instruction read in changes and
// so does the register variable. how do i modify my code for this change?
}
}
return 0;
}
Solución
Si entiendo correctamente, desea poner B4 en la memoria [0] y 04 en la memoria [1]. ¿Estoy en lo cierto?
Esto hará eso.
memory[0] = ((x & 0xFF00) >> 8 ); //Will put B4 in memory[0]
memory[1] = (x & 0xFF); //Will put 04 in memory[1]
Creo que, a continuación, desea comprobar B y 4 por separado en la memoria [0] y luego continuar con el siguiente paso. ¿Cierto?
(memory[0] & 0xF0) >> 4 // will give you 0xB
(memory[0] & 0x0F) //will give you 0x4
¿Es esto lo que estás buscando?
Actualización : para su problema de lectura, debería usar esto.
while (!feof(f))
{
fscanf(f,"%X",&inst[i]);
i++;
}
Esto se lee hasta EOF y podría usar el valor i después de este ciclo para saber cuántas instrucciones se leen y ponerlo en una variable, por ejemplo, n_instr. Y luego, para recorrer las instrucciones, puede usar esto
while(loop<n_instr) //instead of just loop<80
{
memory[j] = ((inst[loop] & 0xFF00) >> 8 );
j=j+2;
memory[k] = (inst[loop] & 0x00FF);
k=k+2;
loop++;
}