185 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			185 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /****************************************************************************
 | |
| 
 | |
| Copyright(c) 2019 by Aerospace C.Power (Chongqing) Microelectronics. ALL RIGHTS RESERVED.
 | |
| 
 | |
| This Information is proprietary to Aerospace C.Power (Chongqing) Microelectronics and MAY NOT
 | |
| be copied by any method or incorporated into another program without
 | |
| the express written consent of Aerospace C.Power. This Information or any portion
 | |
| thereof remains the property of Aerospace C.Power. The Information contained herein
 | |
| is believed to be accurate and Aerospace C.Power assumes no responsibility or
 | |
| liability for its use in any way and conveys no license or title under
 | |
| any patent or copyright and makes no representation or warranty that this
 | |
| Information is free from patent or copyright infringement.
 | |
| 
 | |
| ****************************************************************************/
 | |
| #include "chip_reg_base.h"
 | |
| #include "hw_reg_api.h"
 | |
| #include "iot_bitops.h"
 | |
| #include "os_lock.h"
 | |
| #include "os_utils.h"
 | |
| #include "iot_config.h"
 | |
| #include "ahb_rf.h"
 | |
| #include "sram.h"
 | |
| #include "ahb.h"
 | |
| #include "flash.h"
 | |
| #include "sfc.h"
 | |
| #include "sec_glb.h"
 | |
| 
 | |
| #if HW_PLATFORM > HW_PLATFORM_SIMU
 | |
| #include "dbg_io.h"
 | |
| #endif
 | |
| #include "iot_io.h"
 | |
| 
 | |
| void cache_rst() {
 | |
|     sec_glb_enable(SEC_GLB_EMC);
 | |
|     ahb_cache_disable();
 | |
|     flash_init(1);
 | |
|     ahb_cache_enable();
 | |
|     ahb_cache_reset();
 | |
| }
 | |
| void cache_write_read_all()
 | |
| {
 | |
|     int i = 0, j = 0, k = 0;
 | |
|     uint32_t wdata[0x40] = {0};
 | |
|     uint32_t tmp;
 | |
|     int len = 0x40;
 | |
|     int offset = 0;
 | |
|     int atom = 0x10;
 | |
|     //int atom = 0x4000; // 16KB
 | |
|     int times = 0x1FFF;
 | |
|     // write cache
 | |
|     uint32_t *dcache = (uint32_t *) 0x03000000;
 | |
|     uint32_t *rcache = (uint32_t *) 0x03000000;
 | |
| 
 | |
|     for( j = 0; j < times; j++) {
 | |
|         // write cache
 | |
|         for ( i = 0; i < len; i++ ) {
 | |
|             wdata[i] = i;
 | |
|             *(dcache+offset+i) = wdata[i];
 | |
|             for(k=0; k< 100; k++);
 | |
|         }
 | |
|         // read dcache
 | |
|         for ( i = 0; i < len; i++ ) {
 | |
|             tmp = *(rcache+offset+i);
 | |
|             if ( tmp != wdata[i] ) {
 | |
|                 iot_printf("dcache not equal \r\n");
 | |
|                 iot_printf(" j : %d, i : %d\r\n", j, i);
 | |
|                 iot_printf("addr: %08x read: %08x, write: %08x\r\n",
 | |
|                     0x13000000+i*4+j, tmp, wdata[i]);
 | |
|                 return ;
 | |
|             }
 | |
|             for(k=0; k< 100; k++);
 | |
|         }
 | |
|         offset += atom;
 | |
|     }
 | |
| }
 | |
| 
 | |
| 
 | |
| void cache_write_read()
 | |
| {
 | |
|     int i = 0, j = 0, k = 0;
 | |
|     uint32_t wdata[0x50][0x10] = {0};
 | |
|     int len = 0x10;
 | |
|     int offset = 0;
 | |
|     int atom = 0x4000; // 16KB
 | |
|     uint32_t tmp;
 | |
|     uint32_t ran_pos = 0;
 | |
|     uint32_t *dcache = (uint32_t *) 0x13000000;
 | |
|     uint32_t *rcache = (uint32_t *) 0x13000000;
 | |
| 
 | |
|     iot_printf("write and read loop test\n");
 | |
|     for( j = 0; j < 0x50; j++) {
 | |
|         // write cache
 | |
|         for ( i = 0; i < len; i++ ) {
 | |
|             wdata[j][i] = 1;
 | |
|             *(dcache+offset+i*4) = wdata[j][i];
 | |
|             for(k=0; k< 300; k++);
 | |
|         }
 | |
|         for ( i = 0; i < len; i++ ) {
 | |
|             tmp = *(rcache+offset+i*4 + ran_pos);
 | |
|             if ( tmp != wdata[j][i] ) {
 | |
|                 iot_printf(" not equal \r\n");
 | |
|                 iot_printf(" j : %d, i : %d\r\n", j, i);
 | |
|                 iot_printf("addr: %08x read: %08x, write: %08x\r\n",
 | |
|                     0x13000000+i*4+j, tmp, wdata[j][i]);
 | |
|                 return ;
 | |
|             }
 | |
|             for(k=0; k< 300; k++);
 | |
|         }
 | |
|         offset += atom;
 | |
|     }
 | |
| }
 | |
| 
 | |
| void cache_write_read_byte()
 | |
| {
 | |
|     uint8_t *code = (uint8_t *) 0x13000000;
 | |
|     uint8_t *data = (uint8_t *) 0x13020000;
 | |
| 
 | |
|     uint8_t tmp = 0;
 | |
|     int i = 0, j = 0;
 | |
|     iot_printf("byte write and read test\n");
 | |
|     iot_printf("range of 0x13000000 - 0x13060000\n");
 | |
|     iot_printf("write code to 5a\r\n");
 | |
|     for (i = 0; i < 0x20000; i++) {
 | |
|         *(code+i) =  0x5a;
 | |
|         for(j = 0; j < 100; j++);
 | |
|         if ( i % 0x100 == 0 ) {
 | |
|             iot_printf("i: %08x\r\n", i);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     iot_printf("write code to a5\r\n");
 | |
|     for (i = 0; i < 0x40000; i++) {
 | |
|         *(data+i) = 0x11;
 | |
|         for(j = 0; j < 100; j++);
 | |
|         if ( i % 0x100 == 0 ) {
 | |
|             iot_printf("i: %08x\r\n", i);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // read
 | |
|     for (i = 0; i < 0x20000; i++) {
 | |
|         tmp = *(code+i);
 | |
|         if ( tmp != 0x5a ) {
 | |
|             iot_printf("error: i: %08x\r\n", i);
 | |
|             return ;
 | |
|         }
 | |
| 
 | |
|         if ( i % 0x100 == 0 ) {
 | |
|             iot_printf("read: %08x\r\n", i);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     for (i = 0; i < 0x40000; i++) {
 | |
|         tmp = *(data+i);
 | |
|         if ( tmp != 0x11 ) {
 | |
|             iot_printf("error: i: %08x\r\n", i);
 | |
|             return ;
 | |
|         }
 | |
|         if ( i % 0x100 == 0 ) {
 | |
|             iot_printf("read: %08x\r\n", i);
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| void cache_test(){
 | |
|     dbg_uart_init();
 | |
| 
 | |
|     /* rst sfc */
 | |
|     cache_rst();
 | |
|     cache_write_read_byte();
 | |
|     cache_write_read();
 | |
|     cache_write_read_all();
 | |
|     iot_printf("end............\n");
 | |
|     while(1);
 | |
| }
 | |
| 
 | |
| #ifdef __GNUC__
 | |
| 
 | |
| int main(void) {
 | |
|     cache_test();
 | |
|     return 0;
 | |
| }
 | |
| #endif // __GCC__
 | |
| 
 |