core/hyperbus: Start testing Register writes.
This commit is contained in:
parent
59756b4342
commit
441d05ee36
|
@ -175,6 +175,8 @@ __attribute__((__used__)) int main(int i, char **c)
|
||||||
|
|
||||||
sdr_ok = 1;
|
sdr_ok = 1;
|
||||||
|
|
||||||
|
uint16_t config_reg_0;
|
||||||
|
|
||||||
/* HyperRAM Register access test */
|
/* HyperRAM Register access test */
|
||||||
hyperram_reg_control_write(
|
hyperram_reg_control_write(
|
||||||
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
||||||
|
@ -199,6 +201,7 @@ __attribute__((__used__)) int main(int i, char **c)
|
||||||
);
|
);
|
||||||
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
||||||
printf("Configuration Register 0 : %08lx\n", hyperram_reg_rdata_read());
|
printf("Configuration Register 0 : %08lx\n", hyperram_reg_rdata_read());
|
||||||
|
config_reg_0 = hyperram_reg_rdata_read();
|
||||||
|
|
||||||
hyperram_reg_control_write(
|
hyperram_reg_control_write(
|
||||||
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
||||||
|
@ -208,10 +211,36 @@ __attribute__((__used__)) int main(int i, char **c)
|
||||||
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
||||||
printf("Configuration Register 1 : %08lx\n", hyperram_reg_rdata_read());
|
printf("Configuration Register 1 : %08lx\n", hyperram_reg_rdata_read());
|
||||||
|
|
||||||
|
config_reg_0 &= ~(1 << 3); /* Enable Variable Latency */
|
||||||
|
printf("New config_reg_0: %08lx\n", config_reg_0);
|
||||||
|
hyperram_reg_wdata_write(config_reg_0);
|
||||||
|
hyperram_reg_control_write(
|
||||||
|
1 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
||||||
|
0 << CSR_HYPERRAM_REG_CONTROL_READ_OFFSET |
|
||||||
|
2 << CSR_HYPERRAM_REG_CONTROL_REG_OFFSET
|
||||||
|
);
|
||||||
|
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_WRITE_DONE_OFFSET)) == 0);
|
||||||
|
|
||||||
printf("reg_control: %x\n", hyperram_reg_control_read());
|
printf("reg_control: %x\n", hyperram_reg_control_read());
|
||||||
printf("reg_status: %x\n", hyperram_reg_status_read());
|
printf("reg_status: %x\n", hyperram_reg_status_read());
|
||||||
printf("reg_debug: %x\n", hyperram_reg_debug_read());
|
printf("reg_debug: %x\n", hyperram_reg_debug_read());
|
||||||
|
|
||||||
|
hyperram_reg_control_write(
|
||||||
|
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
||||||
|
1 << CSR_HYPERRAM_REG_CONTROL_READ_OFFSET |
|
||||||
|
2 << CSR_HYPERRAM_REG_CONTROL_REG_OFFSET
|
||||||
|
);
|
||||||
|
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
||||||
|
printf("Configuration Register 0 after update : %08lx\n", hyperram_reg_rdata_read());
|
||||||
|
|
||||||
|
hyperram_reg_control_write(
|
||||||
|
0 << CSR_HYPERRAM_REG_CONTROL_WRITE_OFFSET |
|
||||||
|
1 << CSR_HYPERRAM_REG_CONTROL_READ_OFFSET |
|
||||||
|
3 << CSR_HYPERRAM_REG_CONTROL_REG_OFFSET
|
||||||
|
);
|
||||||
|
while ((hyperram_reg_status_read() & (1 << CSR_HYPERRAM_REG_STATUS_READ_DONE_OFFSET)) == 0);
|
||||||
|
printf("Configuration Register 1 : %08lx\n", hyperram_reg_rdata_read());
|
||||||
|
|
||||||
|
|
||||||
#if defined(CSR_ETHMAC_BASE) || defined(MAIN_RAM_BASE) || defined(CSR_SPIFLASH_CORE_BASE)
|
#if defined(CSR_ETHMAC_BASE) || defined(MAIN_RAM_BASE) || defined(CSR_SPIFLASH_CORE_BASE)
|
||||||
printf("--========== \e[1mInitialization\e[0m ============--\n");
|
printf("--========== \e[1mInitialization\e[0m ============--\n");
|
||||||
|
|
Loading…
Reference in New Issue