553 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			553 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|  | 
 | ||
|  | #include "os_types.h"
 | ||
|  | #include "os_task.h"
 | ||
|  | #include "os_mem.h"
 | ||
|  | 
 | ||
|  | #include "dbg_io.h"
 | ||
|  | #include "iot_diag.h"
 | ||
|  | #include "iot_io.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | //#include <stdlib.h>
 | ||
|  | #include "iot_system_api.h"
 | ||
|  | #include "iot_config.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | //#include "iot_gptmr.h"
 | ||
|  | #include "iot_system.h"
 | ||
|  | //#include "os_mem.h"
 | ||
|  | //#include "cpu.h"
 | ||
|  | //#include "os_task.h"
 | ||
|  | 
 | ||
|  | #include "platform.h"
 | ||
|  | #include "encoding.h"
 | ||
|  | 
 | ||
|  | //#include "sec_glb.h"
 | ||
|  | //#include "ahb.h"
 | ||
|  | //#include "intc.h"
 | ||
|  | 
 | ||
|  | #include "bits.h"
 | ||
|  | 
 | ||
|  | #include "os_utils.h"
 | ||
|  | 
 | ||
|  | #include "iot_rtc.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #if 0
 | ||
|  | 
 | ||
|  | #include "encoding.h"
 | ||
|  | #include "bits.h"
 | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #ifdef __riscv_hard_float
 | ||
|  | # define SOFT_FLOAT_CONTEXT_SIZE 0
 | ||
|  | #else
 | ||
|  | # define SOFT_FLOAT_CONTEXT_SIZE (8 * 32)
 | ||
|  | #endif
 | ||
|  | #define HLS_SIZE 64
 | ||
|  | #define INTEGER_CONTEXT_SIZE (32 * REGBYTES)//REGBYTES
 | ||
|  | 
 | ||
|  | 
 | ||
|  | #define MACHINE_STACK_TOP() ({ \
 | ||
|  |   register uintptr_t sp asm ("sp"); \ | ||
|  |   (void*)((sp + RISCV_PGSIZE) & -RISCV_PGSIZE); }) | ||
|  | 
 | ||
|  | 
 | ||
|  | #define MENTRY_FRAME_SIZE (INTEGER_CONTEXT_SIZE + SOFT_FLOAT_CONTEXT_SIZE \
 | ||
|  |                            + HLS_SIZE) | ||
|  | 
 | ||
|  | 
 | ||
|  | void IRAM_ATTR enter_user_mode(void (*fn)(uintptr_t), uintptr_t stack) | ||
|  | { | ||
|  |   uintptr_t mstatus = read_csr(mstatus); | ||
|  |   mstatus = INSERT_FIELD(mstatus, MSTATUS_MPP, PRV_U); | ||
|  |   mstatus = INSERT_FIELD(mstatus, MSTATUS_MPIE, 0); | ||
|  |   write_csr(mstatus, mstatus); | ||
|  |   write_csr(mscratch, MACHINE_STACK_TOP() - MENTRY_FRAME_SIZE); | ||
|  |   write_csr(mepc, fn); | ||
|  |   asm volatile ("mv a0, %0; mv sp, %0; mret" : : "r" (stack)); | ||
|  |   __builtin_unreachable(); | ||
|  | } | ||
|  | 
 | ||
|  | void IRAM_ATTR app() | ||
|  | { | ||
|  |    while(1) | ||
|  |    	{}; | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #if 0
 | ||
|  | #define write_csr(reg, val) ({ \
 | ||
|  |   if (__builtin_constant_p(val) && (unsigned long)(val) < 32) \ | ||
|  |     asm volatile ("csrw " #reg ", %0" :: "i"(val)); \ | ||
|  |   else \ | ||
|  |     asm volatile ("csrw " #reg ", %0" :: "r"(val)); }) | ||
|  | 
 | ||
|  | #ifdef __riscv_hard_float
 | ||
|  | # define SOFT_FLOAT_CONTEXT_SIZE 0
 | ||
|  | #else
 | ||
|  | # define SOFT_FLOAT_CONTEXT_SIZE (8 * 32)
 | ||
|  | #endif
 | ||
|  | #define HLS_SIZE 64
 | ||
|  | #define INTEGER_CONTEXT_SIZE (32 * REGBYTES)//REGBYTES
 | ||
|  |    | ||
|  |    | ||
|  | #define MACHINE_STACK_TOP() ({ \
 | ||
|  | 	register uintptr_t sp asm ("sp"); \ | ||
|  | 	(void*)((sp + RISCV_PGSIZE) & -RISCV_PGSIZE); }) | ||
|  |    | ||
|  |    | ||
|  | #define MENTRY_FRAME_SIZE (INTEGER_CONTEXT_SIZE + SOFT_FLOAT_CONTEXT_SIZE \
 | ||
|  | 							 + HLS_SIZE) | ||
|  | 
 | ||
|  | 
 | ||
|  | #define SYS_write 64
 | ||
|  | #define SYS_exit 93
 | ||
|  | #define SYS_timer 1234
 | ||
|  | 
 | ||
|  |   /* Fires a syscall */ | ||
|  |   long syscall(long num, long arg0, long arg1, long arg2) | ||
|  |   { | ||
|  | 	  register long a7 asm("a7") = num; | ||
|  | 	  register long a0 asm("a0") = arg0; | ||
|  | 	  register long a1 asm("a1") = arg1; | ||
|  | 	  register long a2 asm("a2") = arg2; | ||
|  | 	  asm volatile ("ecall":"+r"(a0) : "r"(a1), "r"(a2), "r"(a7)); | ||
|  | 	  return a0; | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  |    | ||
|  |   void  enter_user_mode(void (*fn)(uintptr_t), uintptr_t stack) | ||
|  |   { | ||
|  | 	uintptr_t mstatus = read_csr(mstatus); | ||
|  | //	uintptr_t pmpcfg0 = read_csr(pmpcfg0);
 | ||
|  | //	uintptr_t pmpaddr0 = read_csr(pmpaddr0);
 | ||
|  | //	uintptr_t pmpaddr1 = read_csr(pmpaddr1);
 | ||
|  | 
 | ||
|  | //	pmpcfg0 = INSERT_FIELD(pmpcfg0, 0xff00, 0xf);
 | ||
|  | 
 | ||
|  | 	 | ||
|  | 	mstatus = INSERT_FIELD(mstatus, MSTATUS_MPP, PRV_U); | ||
|  | 	mstatus = INSERT_FIELD(mstatus, MSTATUS_MPIE, 0); | ||
|  | 	write_csr(mstatus, mstatus); | ||
|  | 
 | ||
|  | 	write_csr(pmpcfg0, 0x1f0f00);  //0x8f00
 | ||
|  | 	write_csr(pmpaddr0, 0x3ff6400);//0x3fff800
 | ||
|  | 	write_csr(pmpaddr1, 0x3ffffff);//0x3fff401
 | ||
|  | 	write_csr(pmpaddr2, 0x440000ff);//0x3fff401
 | ||
|  | 
 | ||
|  | 	 | ||
|  | 	write_csr(mscratch, MACHINE_STACK_TOP() - MENTRY_FRAME_SIZE); | ||
|  | 	write_csr(mepc, fn); | ||
|  | 	asm volatile ("mv a0, %0; mv sp, %0; mret" : : "r" (stack)); | ||
|  | 	__builtin_unreachable(); | ||
|  |   } | ||
|  | 
 | ||
|  |   size_t iott_strlen( const char *s ) | ||
|  |   { | ||
|  | 	  uint32_t r = 0; | ||
|  | 	  while( *s++ ) r++; | ||
|  | 	  return r; | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Prints a string with a syscall  */ | ||
|  | static void printstr(const char* s) | ||
|  | { | ||
|  | 	syscall(SYS_write, 1, (long) s, iott_strlen(s)); | ||
|  | } | ||
|  | 
 | ||
|  |   void  app()//IRAM_ATTR
 | ||
|  |   { | ||
|  |     unsigned int i=0, j=0; | ||
|  |    | ||
|  | 	 while(1) | ||
|  | 	  { | ||
|  | 	  if (i%1000==0) 	 | ||
|  | 	      printstr("hello world!!!!.\n"); | ||
|  | 	  if (j%2000==0) | ||
|  | 	  	printstr("hello ZZZZZZYYYYZZZZZZYYYYYYY!!!!.\n"); | ||
|  | 	  if (i == 6666666) | ||
|  | 	  	{ | ||
|  | 	  	printstr("read IIs base addr!.\n"); | ||
|  | 		j = ((volatile uint32_t)*((volatile uint32_t*)(0x44000000))); | ||
|  | 	  	} | ||
|  | 	   i++; | ||
|  | 	   j++; | ||
|  | 	  }; | ||
|  |   } | ||
|  | 
 | ||
|  | 
 | ||
|  | void boot_loader()  // IRAM_ATTR
 | ||
|  | { | ||
|  |  // extern char trap_entry;
 | ||
|  |  // write_csr(utvec, &trap_entry);
 | ||
|  |  // write_csr(uscratch, 0);
 | ||
|  |  // write_csr(uie, 0);
 | ||
|  | 
 | ||
|  |   enter_user_mode(app, (uintptr_t)0x0fffd000);// 0x0ffe8800
 | ||
|  | } | ||
|  | 
 | ||
|  | void user_task_1(){ | ||
|  | while(1) | ||
|  | { | ||
|  | 	printstr("user_task_1....\n"); | ||
|  | 	 | ||
|  | 	os_delay(400); | ||
|  | 	printstr("user_task_1...ffffffffff.\n"); | ||
|  | 
 | ||
|  | 
 | ||
|  | 	//iot_printf("starting...\n");
 | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  |     for(;;) { | ||
|  | 
 | ||
|  | 	//boot_loader();
 | ||
|  | 
 | ||
|  | 	 | ||
|  |        printstr("user_task_1....\n"); | ||
|  | 
 | ||
|  |         os_delay(4000); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | 
 | ||
|  | void user_task_2(){ | ||
|  | 	//unsigned int j=0;
 | ||
|  | 
 | ||
|  | while(1) | ||
|  | { | ||
|  | 	printstr("user_task_2....\n"); | ||
|  | 	 | ||
|  | 	os_delay(100); | ||
|  | 	 | ||
|  | 	//j = ((volatile uint32_t)*((volatile uint32_t*)(0x44000000)));
 | ||
|  | //if (j!=0)
 | ||
|  | //{
 | ||
|  | 	printstr("user_task_2...hahahahahaha!!!\n"); | ||
|  | 
 | ||
|  | //}
 | ||
|  | 
 | ||
|  | 	//iot_printf("starting...\n");
 | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  |     for(;;) { | ||
|  | 
 | ||
|  | 	//boot_loader();
 | ||
|  | 
 | ||
|  | 	 | ||
|  |        printstr("user_task_1....\n"); | ||
|  | 
 | ||
|  |         os_delay(4000); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | void user_task_3(){ | ||
|  | while(1) | ||
|  | { | ||
|  | 	printstr("user_task_3....\n"); | ||
|  | 	 | ||
|  | 	os_delay(10); | ||
|  | 	printstr("user_task_3...ttttttt.\n"); | ||
|  | 
 | ||
|  | 
 | ||
|  | 	//iot_printf("starting...\n");
 | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  |     for(;;) { | ||
|  | 
 | ||
|  | 	//boot_loader();
 | ||
|  | 
 | ||
|  | 	 | ||
|  |        printstr("user_task_1....\n"); | ||
|  | 
 | ||
|  |         os_delay(4000); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | int32_t iot__task_start() | ||
|  | { | ||
|  |     //start the tasks;
 | ||
|  |     os_start_kernel(); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | int32_t iot__module_start(void) | ||
|  | { | ||
|  |     int32_t res = 0; | ||
|  | 
 | ||
|  |     res = iot__task_start(); | ||
|  | 
 | ||
|  |     return res; | ||
|  | } | ||
|  | 
 | ||
|  | static int32_t iot__platform_init() | ||
|  | { | ||
|  |     /*platform intialization*/ | ||
|  |     platform_init(); | ||
|  | 
 | ||
|  |     //resource initializations;
 | ||
|  | //    system_clock_init();
 | ||
|  | 
 | ||
|  | //    system_uart_init();
 | ||
|  | 
 | ||
|  |     dbg_uart_init(); | ||
|  | 
 | ||
|  |    // dbg_uart_stage1_init();
 | ||
|  | 
 | ||
|  |   //  iot_led_init();
 | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | int32_t iot__task_init() | ||
|  | { | ||
|  | 	os_task_h handle; | ||
|  | 
 | ||
|  |     handle = os_create_task(user_task_1, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         iot_printf("task 1 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  | 	    handle = os_create_task(user_task_2, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         iot_printf("task 2 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  | 	    handle = os_create_task(user_task_3, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         iot_printf("task 3 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | void task_init() | ||
|  | { | ||
|  | 	os_task_h handle; | ||
|  | 
 | ||
|  |     handle = os_create_task(user_task_1, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |       //  iot_printf("task 1 init successfully...\n");
 | ||
|  |       printstr("user mode task 1 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  | 		    handle = os_create_task(user_task_2, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         printstr("task 2 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  | 	    handle = os_create_task(user_task_3, NULL, 9); | ||
|  | 
 | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         printstr("task 3 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  |     iot__module_start(); | ||
|  | 
 | ||
|  |     return; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | int32_t iot__module_init(void) | ||
|  | { | ||
|  |     //platform intialization;
 | ||
|  |     iot__platform_init(); | ||
|  | 
 | ||
|  |     //create all the tasks;
 | ||
|  |     iot__task_init(); | ||
|  | 
 | ||
|  |     iot_printf("starting...\n"); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | int main(void)  //IRAM_ATTR
 | ||
|  | { | ||
|  | unsigned int j; | ||
|  | 
 | ||
|  | 	//platform intialization;
 | ||
|  | 	  iot__platform_init(); | ||
|  | 
 | ||
|  |    	  iot_printf("entering user mode...\n"); | ||
|  | 	   | ||
|  | 		  j = ((volatile uint32_t)*((volatile uint32_t*)(0x44000000))); | ||
|  | 
 | ||
|  | 		  iot_printf("0x%xhahahahahaha!!!  \n",j); | ||
|  | 	   | ||
|  | 	   | ||
|  | 
 | ||
|  | 	  enter_user_mode(task_init, (uintptr_t)0x0fffd000);// 0x0ffe8800
 | ||
|  | 	  return 0; | ||
|  | 
 | ||
|  | 	//module init;
 | ||
|  | 	 iot__module_init(); | ||
|  | 	 | ||
|  | 	//module start;
 | ||
|  | 	 iot__module_start(); | ||
|  | 
 | ||
|  | 	 return 0; | ||
|  | 
 | ||
|  |     //uint8_t buf[32];
 | ||
|  |     uint32_t addr1 = 0xffd9000;  | ||
|  |     //uint32_t addr2 = 0x10003000; 
 | ||
|  |     //uint32_t i;
 | ||
|  |      | ||
|  |     dbg_uart_init(); | ||
|  | 
 | ||
|  | 	iot_printf("hello world.\n"); | ||
|  | 
 | ||
|  | 
 | ||
|  | 	boot_loader(); | ||
|  | 
 | ||
|  | 
 | ||
|  | while(1) | ||
|  | 	{}; | ||
|  | 
 | ||
|  |     dbg_uart_init(); | ||
|  | 
 | ||
|  |    // iot_mem_read(buf, addr1, 32);
 | ||
|  |     //iot_mem_write(buf, addr2, 32);
 | ||
|  | 
 | ||
|  |    // for(i = 0; i < 32; i++){
 | ||
|  |   //      iot_printf("0x%08x:0x%02x\r\n", addr1+i, *(uint8_t*)(addr1+i));
 | ||
|  |   //      iot_printf("0x%08x:0x%02x\r\n", addr2+i, *(uint8_t*)(addr2+i));
 | ||
|  |   //  }
 | ||
|  |     while(1) { | ||
|  |         iot_printf("hello world. 0x%x\n",*((uint32_t *)addr1)); | ||
|  |     } | ||
|  |     while(1); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | #endif
 | ||
|  | 
 | ||
|  | 
 | ||
|  | static int32_t iot__platform_init() | ||
|  | { | ||
|  |     /*platform intialization*/ | ||
|  |     platform_init(); | ||
|  | 
 | ||
|  |     //resource initializations;
 | ||
|  | //    system_clock_init();
 | ||
|  | 
 | ||
|  | //    system_uart_init();
 | ||
|  | 
 | ||
|  |     dbg_uart_init(); | ||
|  | 
 | ||
|  |    // dbg_uart_stage1_init();
 | ||
|  | 
 | ||
|  |   //  iot_led_init();
 | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | void user_task_1(){ | ||
|  | 
 | ||
|  |     iot_time_tm_t curr_tm; | ||
|  | 
 | ||
|  |     *((volatile uint32_t*)(0x05c0f808)) = 0xffffffff; | ||
|  |     curr_tm.tm_year=2012; | ||
|  |     curr_tm.tm_mon=1; | ||
|  |     curr_tm.tm_mday=11; | ||
|  |     curr_tm.tm_hour=4; | ||
|  |     curr_tm.tm_min=55; | ||
|  |     curr_tm.tm_sec=0; | ||
|  | 
 | ||
|  |     iot_rtc_set(&curr_tm); | ||
|  | 
 | ||
|  |     while(1) | ||
|  |     { | ||
|  |         iot_rtc_get(&curr_tm); | ||
|  |         iot_printf("user_task_1 %d-%d-%d %d:%d:%d\n",curr_tm.tm_year,curr_tm.tm_mon,curr_tm.tm_mday,curr_tm.tm_hour,curr_tm.tm_min,curr_tm.tm_sec); | ||
|  |         os_delay(500); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | int32_t iot__task_init() | ||
|  | { | ||
|  |     os_task_h handle; | ||
|  | 
 | ||
|  |     handle = os_create_task(user_task_1, NULL, 9); | ||
|  | 
 | ||
|  |     //create the tasks;
 | ||
|  |     if(handle != NULL) { | ||
|  |         iot_printf("task 1 init successfully...\n"); | ||
|  |     } | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | int32_t iot__module_init(void) | ||
|  | { | ||
|  |     //platform intialization;
 | ||
|  |     iot__platform_init(); | ||
|  | 
 | ||
|  |     //create all the tasks;
 | ||
|  |     iot__task_init(); | ||
|  |     iot_rtc_init(); | ||
|  |     iot_printf("starting...\n"); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | int32_t iot__task_start() | ||
|  | { | ||
|  |     //start the tasks;
 | ||
|  |     os_start_kernel(); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 | ||
|  | int32_t iot__module_start(void) | ||
|  | { | ||
|  |     int32_t res = 0; | ||
|  | 
 | ||
|  |     res = iot__task_start(); | ||
|  | 
 | ||
|  |     return res; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | int main(void) | ||
|  | { | ||
|  |     //module init;
 | ||
|  |     iot__module_init(); | ||
|  | 
 | ||
|  |     //module start;
 | ||
|  |     iot__module_start(); | ||
|  | 
 | ||
|  |     return 0; | ||
|  | } | ||
|  | 
 |