344 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			344 lines
		
	
	
		
			7.3 KiB
		
	
	
	
		
			C
		
	
	
		
			Executable File
		
	
	
	
	
| /****************************************************************************
 | |
| 
 | |
| 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.
 | |
| 
 | |
| ****************************************************************************/
 | |
| /* os shim includes */
 | |
| #include "os_types.h"
 | |
| #include "os_task.h"
 | |
| #include "os_utils.h"
 | |
| 
 | |
| /* common includes */
 | |
| #include "iot_io.h"
 | |
| #include "iot_bitops.h"
 | |
| #include "iot_pkt_api.h"
 | |
| #include "iot_ipc.h"
 | |
| #include "iot_plc_lib.h"
 | |
| #include "iot_dbglog_api.h"
 | |
| #include "iot_config.h"
 | |
| 
 | |
| /* driver includes */
 | |
| #include "iot_clock.h"
 | |
| #include "iot_uart.h"
 | |
| #include "iot_led.h"
 | |
| 
 | |
| /* cli includes */
 | |
| #include "iot_cli.h"
 | |
| #include "iot_uart_h.h"
 | |
| 
 | |
| /* debug includes*/
 | |
| #include "dbg_io.h"
 | |
| 
 | |
| #include "spi.h"
 | |
| #include "apb.h"
 | |
| #include "apb_hw.h"
 | |
| #include "gpio_mtx.h"
 | |
| 
 | |
|  extern int platform_init();
 | |
| 
 | |
| os_task_h test_init_handle;
 | |
| 
 | |
| #define debug_printf(s)
 | |
| 
 | |
| void print_hex(int hex)
 | |
| {
 | |
|     char hex_buf[11];
 | |
|     int index, data;
 | |
| 
 | |
|     hex_buf[0] = '0';
 | |
|     hex_buf[1] = 'x';
 | |
|     hex_buf[10] = '\0';
 | |
| 
 | |
|     index = 9;
 | |
|     while(index>1)
 | |
|     {
 | |
|         data = hex&0xFF;
 | |
|         hex_buf[index] = (data>9) ? (data-10+'A') : (data+'0');
 | |
|         hex >>= 4;
 | |
|         index--;
 | |
|     }
 | |
|     iot_printf(hex_buf);
 | |
| }
 | |
| 
 | |
| int spi_test_device=2; //DEVICE_SPI0_MASTER;
 | |
| #define SPI_READ_SIZE 256
 | |
| char spi_tx_buf[SPI_READ_SIZE];
 | |
| char spi_rx_buf[SPI_READ_SIZE];
 | |
| xfer_buf spi_tx, spi_rx;
 | |
| int do_spi_test_poll = 1;
 | |
| void spi_test_poll()
 | |
| {
 | |
|     int offset,i;
 | |
|     iot_spi_cfg_t cfg = {0};
 | |
|     cfg.gpio.clk = 17;
 | |
|     cfg.gpio.cs = 18;
 | |
|     cfg.gpio.miso = 19;
 | |
|     cfg.gpio.mosi = 20;
 | |
|     cfg.port = 2;
 | |
|     (void)iot_spi_module_init(&cfg);
 | |
|     /* Use default configuration */
 | |
|     (void)iot_spi_dev_register_detail
 | |
|     (spi_test_device, NULL, NULL, NULL, NULL, 0x0);
 | |
| 
 | |
|     spi_tx.p_nt = NULL;
 | |
|     spi_tx.txbuf = spi_tx_buf;
 | |
|     spi_tx.rxbuf = spi_rx_buf;
 | |
|     spi_tx.size = 10;
 | |
| 
 | |
|     os_mem_set(spi_tx_buf, 0x55, SPI_READ_SIZE);
 | |
| 
 | |
|     offset = 0;
 | |
|     while(1)
 | |
|     {
 | |
|         spi_tx_buf[0] = (char)offset++;
 | |
| 
 | |
|         (void)iot_spi_poll_transfer(spi_test_device, &spi_tx);
 | |
|         //offset += SPI_READ_SIZE;
 | |
|         iot_printf("%d\r\n",spi_tx.xfer_size);
 | |
|         i = 0;
 | |
|         while(i < spi_tx.xfer_size)
 | |
|         {
 | |
|           iot_printf("0x%x, 0x%x\r\n",spi_tx.txbuf[i],spi_tx.rxbuf[i]);
 | |
|           i++;
 | |
|         }
 | |
| 		iot_printf("---------------------------\r\n");
 | |
|     }
 | |
| 
 | |
| }
 | |
| 
 | |
| static xfer_buf *int_hd;
 | |
| 
 | |
| void spi_test_intterupt_handler(int status)
 | |
| {
 | |
|     int cnt;
 | |
| 
 | |
|     if(NULL == int_hd)
 | |
|         return ;
 | |
| 
 | |
|     if(status&SPI_RXFIFO_FULL)
 | |
|     {
 | |
|         (void)iot_spi_get_rx_data_cnt(DEVICE_SPI0_MASTER, &cnt);
 | |
|         if(int_hd->rxbuf)
 | |
|         {
 | |
|             cnt = iot_spi_read_data(DEVICE_SPI0_MASTER, int_hd->rxbuf+int_hd->xfer_size, cnt);
 | |
|             int_hd->xfer_size += cnt;
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             /* Clear fifo */
 | |
|             (void)iot_spi_read_data(DEVICE_SPI0_MASTER, NULL, cnt);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if(status&SPI_TXFIFO_EMPTY)
 | |
|     {
 | |
|         (void)iot_spi_get_tx_data_space_cnt(DEVICE_SPI0_MASTER, &cnt);
 | |
|         if(int_hd->txbuf)
 | |
|         {
 | |
|             cnt = iot_spi_write_data(DEVICE_SPI0_MASTER, int_hd->rxbuf+int_hd->xfer_size, cnt);
 | |
|             int_hd->xfer_size += cnt;
 | |
|         }
 | |
|         else
 | |
|         {
 | |
|             (void)iot_spi_write_data(DEVICE_SPI0_MASTER, NULL, cnt);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     if(int_hd->size == int_hd->xfer_size)
 | |
|         int_hd = int_hd->p_nt;
 | |
| }
 | |
| 
 | |
| void spi_test_interrupt(void)
 | |
| {
 | |
|     iot_spi_cfg_t cfg = {0};
 | |
|     cfg.gpio.clk = 37;
 | |
|     cfg.gpio.cs = 28;
 | |
|     cfg.gpio.miso = 40;
 | |
|     cfg.gpio.mosi = 39;
 | |
| 	cfg.port = 0;
 | |
|     (void)iot_spi_module_init(&cfg);
 | |
| 
 | |
| 
 | |
|     spi_tx.p_nt = NULL;
 | |
|     spi_tx.txbuf = spi_tx_buf;
 | |
|     spi_tx.rxbuf = NULL;
 | |
|     spi_tx.size = 0x04;
 | |
|     spi_tx.xfer_size =0;
 | |
| 
 | |
|     spi_rx.p_nt = NULL;
 | |
|     spi_rx.rxbuf = spi_rx_buf;
 | |
|     spi_rx.txbuf = NULL;
 | |
|     spi_rx.size = SPI_READ_SIZE;
 | |
|     spi_rx.xfer_size =0;
 | |
| 
 | |
|     int_hd = &spi_tx;
 | |
| 
 | |
|     /* Use default configuration */
 | |
|     (void)iot_spi_dev_register_detail(spi_test_device, NULL, NULL, NULL, spi_test_intterupt_handler, \
 | |
|         SPI_RXFIFO_FULL|SPI_TXFIFO_EMPTY);
 | |
| 
 | |
| }
 | |
| 
 | |
| void spi_pin_config(void)
 | |
| {
 | |
|     apb_enable(APB_GMTX); //GMTX_EB_OFFSET + 32
 | |
|     //apb_enable(APB_GPIO);
 | |
|     /* UART0  */
 | |
|     *(int*)0x44007008 = 0x0; /* FUNCTION 1 TXD */
 | |
|     *(int*)0x4400700C = 0x0; /* FUNCTION 1 RXD*/
 | |
|     *(int*)0x44020024 = 0x1000; /* SIG9 <- core */
 | |
| 
 | |
|     /* SPI FLASH */
 | |
|     /*
 | |
|         GPIO 20 <-> CLK
 | |
|         GPIO 17 <-> CS
 | |
|         GPIO 18 <-> MISO
 | |
|         GPIO 19 <-> MOSI
 | |
|        */
 | |
| #if 1
 | |
|     *(int*)0x44007080 = 0x0; /* FUNCTION 1 GPIO 16 */
 | |
|     *(int*)0x44007084 = 0x0; /* FUNCTION 1 GPIO 17 */
 | |
|     *(int*)0x44007088 = 0x0; /* FUNCTION 1 GPIO 18 */
 | |
|     *(int*)0x4400708C = 0x0; /* FUNCTION 1 GPIO 19 */
 | |
| #endif
 | |
|     *(int*)0x44020040 = 18; /* MISO <- GPIO18 */
 | |
| 
 | |
|     *(int*)0x44020450 = 20; /* CLK -> GPIO20 */
 | |
|     *(int*)0x44020444 = 21; /* CS  -> GPIO17 */
 | |
|     *(int*)0x4402044C = 22; /* MOSI  -> GPIO19 */
 | |
| 
 | |
| 
 | |
| }
 | |
| 
 | |
| void dma_spi_gpio_config()
 | |
| {
 | |
|     gpio_mtx_enable();
 | |
|     gpio_sig_info_t info1 = {
 | |
|         4,
 | |
|         {
 | |
|             {IO_TYPE_OUT, 0, 10, 0xff, 20},
 | |
|             {IO_TYPE_OUT, 0, 11, 0xff, 21},
 | |
|             {IO_TYPE_OUT, 0, 15, 0xff, 22},
 | |
|             {IO_TYPE_IN, 0, 12, 16, 0xff}
 | |
|         }
 | |
|     };
 | |
|     gpio_module_pin_select(&info1);
 | |
|     gpio_module_sig_select(&info1, GPIO_MTX_MODE_MATRIX);
 | |
| }
 | |
|  void test_init()
 | |
| {
 | |
| #if 0
 | |
|     /* init common modules */
 | |
|     iot_bitops_init();
 | |
| 
 | |
|     /* init os related modules and utilities */
 | |
|     os_utils_init();
 | |
| 
 | |
|     /* init dbglog module */
 | |
|     iot_dbglog_init();
 | |
| 
 | |
|     /*init uart module*/
 | |
|     iot_uart_init(1);
 | |
| 
 | |
|     spi_pin_config();
 | |
| #endif
 | |
|     //dma_spi_gpio_config();
 | |
|     if(do_spi_test_poll)
 | |
|         spi_test_poll();
 | |
|     else
 | |
|         spi_test_interrupt();
 | |
| }
 | |
| 
 | |
| 
 | |
| void iot_task_1(void *arg)
 | |
| {
 | |
|     iot_printf("Entry Task 1 ..\r\n");
 | |
| 
 | |
|     for(;;) {
 | |
|        test_init();
 | |
|        os_delete_task(test_init_handle);
 | |
|     }
 | |
| 
 | |
| }
 | |
| 
 | |
| int32_t iot_task_init()
 | |
| {
 | |
|     /* start plc lib task */
 | |
|     test_init_handle = os_create_task(iot_task_1, NULL, 9);
 | |
| 
 | |
| 
 | |
|     //create the tasks;
 | |
|     if(test_init_handle != NULL) {
 | |
|         iot_printf("Task 1 created successfully .. \r\n");
 | |
|     }
 | |
| 
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| int32_t iot_task_start()
 | |
| {
 | |
|     //start the tasks;
 | |
|     os_start_kernel();
 | |
| 
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| static int32_t iot_platform_init()
 | |
| {
 | |
|     /*platform intialization*/
 | |
|     platform_init();
 | |
| 
 | |
|     //resource initializations;
 | |
|     system_clock_init();
 | |
| #if 0
 | |
|     system_uart_init();
 | |
| #endif
 | |
|     dbg_uart_init();
 | |
| #if 0
 | |
|     dbg_uart_stage1_init();
 | |
| 
 | |
|     iot_led_init();
 | |
| #endif
 | |
|     return 0;
 | |
| }
 | |
| 
 | |
| 
 | |
| int32_t iot_module_init(void)
 | |
| {
 | |
|     //platform intialization;
 | |
|     iot_platform_init();
 | |
| 
 | |
|     //create all the tasks;
 | |
|     iot_task_init();
 | |
| 
 | |
|     iot_printf("starting...\n");
 | |
| 
 | |
|     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();
 | |
|     iot_module_start();
 | |
|     return 0;
 | |
| }
 |