update -Wall -Werror

This commit is contained in:
pvvx 2017-09-07 02:26:00 +03:00
parent 2c29a376ba
commit 7cb9553f73
102 changed files with 3686 additions and 3504 deletions

View file

@ -6,7 +6,8 @@ Module RTL00(RTL8710AF), [F11AMIM13](http://fn-link.en.made-in-china.com/product
[PADI](https://www.pine64.org/?page_id=946) (RTL8710AF), [F10AFIM13-B1](http://en.ofeixin.com/products_detail/productId=65.html) (RTL8710AF), [TinyCon2005-A-BE](http://www.ralinwi.com/product.aspx?info_lb=54&flag=1) (RTL8711AF),<br> [PADI](https://www.pine64.org/?page_id=946) (RTL8710AF), [F10AFIM13-B1](http://en.ofeixin.com/products_detail/productId=65.html) (RTL8710AF), [TinyCon2005-A-BE](http://www.ralinwi.com/product.aspx?info_lb=54&flag=1) (RTL8711AF),<br>
[WFM-400](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0113&level=3) (RTL8711AM), [WFM-410](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0114&level=3) (RTL8711AF), [WFM-250](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0112&level=3) (RTL8195AM),<br> [WFM-400](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0113&level=3) (RTL8711AM), [WFM-410](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0114&level=3) (RTL8711AF), [WFM-250](http://www.rayson.com/rayson/en/?pros=product&pros=product&b_cat_id=A03&m_cat_id=A0304&s_cat_id=A030401&prod_id=P0112&level=3) (RTL8195AM),<br>
[AW-CU238, AW-CU239](https://www.buyiot.net/pd-1) (RTL8711AM), [AW-CU245, AW-CU245, AW-CU245](https://www.buyiot.net/home-1) (RTL8711AM/RTL8195AM/RTL8711AF),<br> [AW-CU238, AW-CU239](https://www.buyiot.net/pd-1) (RTL8711AM), [AW-CU245, AW-CU245, AW-CU245](https://www.buyiot.net/home-1) (RTL8711AM/RTL8195AM/RTL8711AF),<br>
[WG6611](http://www.jorjin.com/product.php?id=98) (RTL8711AM), [RAK473](http://www.rakwireless.com/en/download/RAK473/Firmware%20Upgrade) (RTL8711AM), [RAK474, RAK476](http://www.rakwireless.com/en/download/RAK473/Firmware%20Upgrade) (RTL8711AF), ...<br> [WG6611](http://www.jorjin.com/product.php?id=98) (RTL8711AM), [RAK473](http://www.rakwireless.com/en/download/RAK473/Firmware%20Upgrade) (RTL8711AM), [RAK474, RAK476](http://www.rakwireless.com/en/download/RAK473/Firmware%20Upgrade) (RTL8711AF), [6110R-IF](http://en.ofeixin.com/products_detail/productId=65.html) (RTL8710AF),<br>
[MJIOT-AMB-01](http://www.nb-iot-tech.com/mjiot-amb-01-en.html) (RTL8710AF), [MJIOT-AMB-02](http://www.nb-iot-tech.com/mjiot-amb-02-en.html) (RTL8195AM), ...<br>
RTL00 module (RTL8710AF)<br> RTL00 module (RTL8710AF)<br>

View file

@ -184,7 +184,9 @@ uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state) {
struct ip_addr netmask; struct ip_addr netmask;
struct ip_addr gw; struct ip_addr gw;
uint32_t IPaddress; uint32_t IPaddress;
#if CONFIG_DEBUG_LOG > 2
uint8_t iptab[4]; uint8_t iptab[4];
#endif
uint8_t DHCP_state; uint8_t DHCP_state;
int mscnt = 0; int mscnt = 0;
struct netif *pnetif = NULL; struct netif *pnetif = NULL;
@ -228,12 +230,14 @@ uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state) {
/* Stop DHCP */ /* Stop DHCP */
// dhcp_stop(pnetif); /* can not stop, need to renew, Robbie*/ // dhcp_stop(pnetif); /* can not stop, need to renew, Robbie*/
#if CONFIG_DEBUG_LOG > 2
iptab[0] = (uint8_t) (IPaddress >> 24); iptab[0] = (uint8_t) (IPaddress >> 24);
iptab[1] = (uint8_t) (IPaddress >> 16); iptab[1] = (uint8_t) (IPaddress >> 16);
iptab[2] = (uint8_t) (IPaddress >> 8); iptab[2] = (uint8_t) (IPaddress >> 8);
iptab[3] = (uint8_t) (IPaddress); iptab[3] = (uint8_t) (IPaddress);
info_printf("Interface %d IP address: %d.%d.%d.%d\n", idx, iptab[3], info_printf("Interface %d IP address: %d.%d.%d.%d\n", idx, iptab[3],
iptab[2], iptab[1], iptab[0]); iptab[2], iptab[1], iptab[0]);
#endif
#if CONFIG_WLAN #if CONFIG_WLAN
error_flag = RTW_NO_ERROR; error_flag = RTW_NO_ERROR;
#endif #endif
@ -251,6 +255,7 @@ uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state) {
IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1, NETMASK_ADDR2, NETMASK_ADDR3); IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1, NETMASK_ADDR2, NETMASK_ADDR3);
IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3); IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3);
netif_set_addr(pnetif, &ipaddr, &netmask, &gw); netif_set_addr(pnetif, &ipaddr, &netmask, &gw);
#if CONFIG_DEBUG_LOG > 2
iptab[0] = IP_ADDR3; iptab[0] = IP_ADDR3;
iptab[1] = IP_ADDR2; iptab[1] = IP_ADDR2;
@ -258,6 +263,7 @@ uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state) {
iptab[3] = IP_ADDR0; iptab[3] = IP_ADDR0;
info_printf("Interface %d DHCP timeout\n", idx); info_printf("Interface %d DHCP timeout\n", idx);
info_printf("Static IP address: %d.%d.%d.%d\n", iptab[3], iptab[2], iptab[1], iptab[0]); info_printf("Static IP address: %d.%d.%d.%d\n", iptab[3], iptab[2], iptab[1], iptab[0]);
#endif
#if CONFIG_WLAN #if CONFIG_WLAN
error_flag = RTW_DHCP_FAIL; error_flag = RTW_DHCP_FAIL;
#endif #endif

View file

@ -9,22 +9,30 @@
#define DATA_IRAM_ATTR #define DATA_IRAM_ATTR
#define ICACHE_RAM_ATTR #define ICACHE_RAM_ATTR
#define os_printf(...) rtl_printf(__VA_ARGS__)
#define os_printf_plus(...) rtl_printf(__VA_ARGS__)
#define os_sprintf_fd(...) rtl_sprintf(__VA_ARGS__)
#define ets_sprintf(...) rtl_sprintf(__VA_ARGS__)
#ifndef os_malloc
#define os_malloc pvPortMalloc
#define os_zalloc pvPortZalloc
#define os_calloc pvPortCalloc
#define os_realloc pvPortRealloc
#endif
#undef os_free
#define os_free vPortFree
#define system_get_free_heap_size xPortGetFreeHeapSize
#undef os_realloc
#define os_realloc pvPortReAlloc
#define os_printf rtl_printf
#define os_printf_plus rtl_printf
#define os_sprintf_fd rtl_sprintf
#define ets_sprintf rtl_sprintf
//#ifndef os_malloc
#undef os_malloc
extern void *pvPortMalloc(size_t xWantedSize);
#define os_malloc pvPortMalloc
#undef os_zalloc
extern void *pvPortZalloc(size_t xWantedSize);
#define os_zalloc pvPortZalloc
//#undef os_calloc
//#define os_calloc pvPortCalloc
#undef os_realloc
extern void *pvPortReAlloc(void *pv, size_t xWantedSize);
#define os_realloc pvPortReAlloc
#undef os_free
extern void vPortFree(void *pv);
#define os_free vPortFree
//#endif
extern size_t xPortGetFreeHeapSize(void);
#define system_get_free_heap_size xPortGetFreeHeapSize
#define os_bzero rtl_bzero #define os_bzero rtl_bzero
#define os_delay_us wait_us // HalDelayUs #define os_delay_us wait_us // HalDelayUs
@ -104,22 +112,28 @@ extern SpiFlashChip * flashchip; // in RAM-BIOS: 0x3fffc714
#define spi_flash_read(faddr, pbuf, size) flash_stream_read(&flashobj, faddr, size, (uint8_t *)pbuf) #define spi_flash_read(faddr, pbuf, size) flash_stream_read(&flashobj, faddr, size, (uint8_t *)pbuf)
#define spi_flash_erase_block(blk) flash_erase_block(&flashobj, (blk)<<16); #define spi_flash_erase_block(blk) flash_erase_block(&flashobj, (blk)<<16);
#ifndef ip4_addr1
#define ip4_addr1(ipaddr) (((u8_t*)(ipaddr))[0]) #define ip4_addr1(ipaddr) (((u8_t*)(ipaddr))[0])
#define ip4_addr2(ipaddr) (((u8_t*)(ipaddr))[1]) #define ip4_addr2(ipaddr) (((u8_t*)(ipaddr))[1])
#define ip4_addr3(ipaddr) (((u8_t*)(ipaddr))[2]) #define ip4_addr3(ipaddr) (((u8_t*)(ipaddr))[2])
#define ip4_addr4(ipaddr) (((u8_t*)(ipaddr))[3]) #define ip4_addr4(ipaddr) (((u8_t*)(ipaddr))[3])
#endif
/* These are cast to u16_t, with the intent that they are often arguments /* These are cast to u16_t, with the intent that they are often arguments
* to printf using the U16_F format from cc.h. */ * to printf using the U16_F format from cc.h. */
#ifndef ip4_addr1_16
#define ip4_addr1_16(ipaddr) ((u16_t)ip4_addr1(ipaddr)) #define ip4_addr1_16(ipaddr) ((u16_t)ip4_addr1(ipaddr))
#define ip4_addr2_16(ipaddr) ((u16_t)ip4_addr2(ipaddr)) #define ip4_addr2_16(ipaddr) ((u16_t)ip4_addr2(ipaddr))
#define ip4_addr3_16(ipaddr) ((u16_t)ip4_addr3(ipaddr)) #define ip4_addr3_16(ipaddr) ((u16_t)ip4_addr3(ipaddr))
#define ip4_addr4_16(ipaddr) ((u16_t)ip4_addr4(ipaddr)) #define ip4_addr4_16(ipaddr) ((u16_t)ip4_addr4(ipaddr))
#endif
#undef IP2STR
#define IP2STR(ipaddr) ip4_addr1_16(ipaddr), \ #define IP2STR(ipaddr) ip4_addr1_16(ipaddr), \
ip4_addr2_16(ipaddr), \ ip4_addr2_16(ipaddr), \
ip4_addr3_16(ipaddr), \ ip4_addr3_16(ipaddr), \
ip4_addr4_16(ipaddr) ip4_addr4_16(ipaddr)
#undef IPSTR
#define IPSTR "%d.%d.%d.%d" #define IPSTR "%d.%d.%d.%d"
#ifndef MAC2STR #ifndef MAC2STR

View file

@ -95,11 +95,11 @@
#define memset rtl_memset #define memset rtl_memset
#define strcat rtl_strcat #define strcat rtl_strcat
#define strchr rtl_strchr #define strchr rtl_strchr
#define strcmp(s1, s2) rtl_strcmp((const char *)s1, (const char *)s2) #define strcmp rtl_strcmp
#define strcpy rtl_strcpy #define strcpy rtl_strcpy
#define strlen(str) rtl_strlen((const char *)str) #define strlen rtl_strlen
#define strncat rtl_strncat #define strncat rtl_strncat
#define strncmp(s1, s2, n) rtl_strncmp((const char *)s1, (const char *)s2, n) #define strncmp rtl_strncmp
#define strncpy rtl_strncpy #define strncpy rtl_strncpy
#define strstr rtl_strstr #define strstr rtl_strstr
#define strsep rtl_strsep #define strsep rtl_strsep
@ -157,13 +157,22 @@
// //
// memory management // memory management
// //
#ifndef CONFIG_MBED_ENABLED #undef malloc
extern void *pvPortMalloc(size_t xWantedSize); extern void *pvPortMalloc(size_t xWantedSize);
extern void vPortFree( void *pv );
#define malloc pvPortMalloc #define malloc pvPortMalloc
#undef zalloc
extern void *pvPortZalloc(size_t xWantedSize);
#define zalloc pvPortZalloc #define zalloc pvPortZalloc
#undef realloc
extern void *pvPortReAlloc(void *pv, size_t xWantedSize);
#define realloc pvPortReAlloc
#undef free
extern void vPortFree(void *pv);
#define free vPortFree #define free vPortFree
#endif
#elif defined (CONFIG_PLATFORM_8711B) #elif defined (CONFIG_PLATFORM_8711B)
#if defined (__IARSTDLIB__) #if defined (__IARSTDLIB__)

View file

@ -16,6 +16,8 @@
#endif #endif
#include <lwip_netconf.h> #include <lwip_netconf.h>
#include <osdep_service.h> #include <osdep_service.h>
#include "dhcp.h"
#include "dhcp/dhcps.h"
#if CONFIG_EXAMPLE_WLAN_FAST_CONNECT #if CONFIG_EXAMPLE_WLAN_FAST_CONNECT
#include "wlan_fast_connect/example_wlan_fast_connect.h" #include "wlan_fast_connect/example_wlan_fast_connect.h"
@ -157,6 +159,9 @@ extern unsigned char dhcp_mode_sta;
#include "freertos/wrapper.h" #include "freertos/wrapper.h"
#include "skbuff.h" #include "skbuff.h"
extern int is_promisc_enabled();
extern int promisc_set(rtw_rcr_level_t enabled, void (*callback)(u8 *, unsigned int, void *), int len_used);
//------------------------------------------------------------------------end-patch// //------------------------------------------------------------------------end-patch//
static int wifi_connect_local(rtw_network_info_t *pWifi) { static int wifi_connect_local(rtw_network_info_t *pWifi) {
int ret = 0; int ret = 0;
@ -278,8 +283,8 @@ static void wifi_disconn_hdl(char* buf, int buf_len, int flags, void* userdata)
else if (rtw_join_status == 0) else if (rtw_join_status == 0)
error_flag = RTW_CONNECT_FAIL; error_flag = RTW_CONNECT_FAIL;
else if (rtw_join_status == JOIN_COMPLETE | JOIN_SECURITY_COMPLETE else if (rtw_join_status == (JOIN_COMPLETE | JOIN_SECURITY_COMPLETE
| JOIN_ASSOCIATED | JOIN_AUTHENTICATED | JOIN_LINK_READY) | JOIN_ASSOCIATED | JOIN_AUTHENTICATED | JOIN_LINK_READY))
error_flag = RTW_WRONG_PASSWORD; error_flag = RTW_WRONG_PASSWORD;
} }
@ -368,6 +373,7 @@ void restore_wifi_info_to_flash() {
#endif #endif
extern int wext_set_bssid(const char *ifname, const __u8 *bssid);
//----------------------------------------------------------------------------// //----------------------------------------------------------------------------//
int wifi_connect( int wifi_connect(
unsigned char bssid[ETH_ALEN], unsigned char bssid[ETH_ALEN],
@ -380,7 +386,7 @@ int wifi_connect(
int ssid_len = 0; int ssid_len = 0;
int password_len = 0; int password_len = 0;
int bssid_len = 6; // int bssid_len = 6;
xSemaphoreHandle join_semaphore; xSemaphoreHandle join_semaphore;
rtw_result_t result = RTW_SUCCESS; rtw_result_t result = RTW_SUCCESS;
u8 wep_hex = 0; u8 wep_hex = 0;
@ -440,7 +446,7 @@ int wifi_connect(
if (password_len == 10) { if (password_len == 10) {
u32 g[5] = { 0 }; unsigned int g[5] = { 0 };
u8 i = 0; u8 i = 0;
sscanf((const char*) password, "%02x%02x%02x%02x%02x", &g[0], sscanf((const char*) password, "%02x%02x%02x%02x%02x", &g[0],
&g[1], &g[2], &g[3], &g[4]); &g[1], &g[2], &g[3], &g[4]);
@ -450,7 +456,7 @@ int wifi_connect(
password_len = 5; password_len = 5;
wep_hex = 1; wep_hex = 1;
} else if (password_len == 26) { } else if (password_len == 26) {
u32 g[13] = { 0 }; unsigned int g[13] = { 0 };
u8 i = 0; u8 i = 0;
sscanf((const char*) password, "%02x%02x%02x%02x%02x%02x%02x" sscanf((const char*) password, "%02x%02x%02x%02x%02x%02x%02x"
"%02x%02x%02x%02x%02x%02x", &g[0], &g[1], &g[2], &g[3], "%02x%02x%02x%02x%02x%02x", &g[0], &g[1], &g[2], &g[3],
@ -731,6 +737,8 @@ int wifi_get_ap_info(rtw_bss_info_t * ap_info, rtw_security_t* security) {
return ret; return ret;
} }
extern int wext_get_drv_ability(const char *ifname, uint32_t *ability);
int wifi_get_drv_ability(uint32_t *ability) { int wifi_get_drv_ability(uint32_t *ability) {
return wext_get_drv_ability(WLAN0_NAME, ability); return wext_get_drv_ability(WLAN0_NAME, ability);
} }
@ -948,6 +956,8 @@ int wifi_get_last_error(void) {
int wpas_wps_init(const char* ifname); int wpas_wps_init(const char* ifname);
#endif #endif
extern int set_hidden_ssid(const char *ifname, uint8_t value);
int wifi_start_ap(char *ssid, rtw_security_t security_type, char *password, int channel, char ssid_hidden) { int wifi_start_ap(char *ssid, rtw_security_t security_type, char *password, int channel, char ssid_hidden) {
const char *ifname = WLAN0_NAME; const char *ifname = WLAN0_NAME;
int ssid_len = 0; int ssid_len = 0;
@ -1543,10 +1553,8 @@ int wifi_restart_ap(unsigned char *ssid, rtw_security_t security_type,
printf("AP: security_type=%d\n", setting.security_type); printf("AP: security_type=%d\n", setting.security_type);
printf("AP: password=%s\n", (char* )setting.password); printf("AP: password=%s\n", (char* )setting.password);
printf("AP: key_idx =%d\n", setting.key_idx); printf("AP: key_idx =%d\n", setting.key_idx);
ret = wifi_connect((char*) setting.ssid, setting.security_type, ret = wifi_connect(NULL, 0 , (char*) setting.ssid, setting.security_type,
(char*) setting.password, strlen((char* )setting.ssid), (char*) setting.password, setting.key_idx, NULL);
strlen((char* )setting.password), setting.key_idx,
NULL);
if (ret == RTW_SUCCESS) { if (ret == RTW_SUCCESS) {
#if CONFIG_DHCP_CLIENT #if CONFIG_DHCP_CLIENT
/* Start DHCPClient */ /* Start DHCPClient */
@ -1726,6 +1734,9 @@ int wifi_remove_packet_filter(unsigned char filter_id) {
#endif #endif
#ifdef CONFIG_AP_MODE #ifdef CONFIG_AP_MODE
extern int wext_enable_forwarding(const char *ifname);
extern int wext_disable_forwarding(const char *ifname);
int wifi_enable_forwarding(void) { int wifi_enable_forwarding(void) {
return wext_enable_forwarding(WLAN0_NAME); return wext_enable_forwarding(WLAN0_NAME);
} }
@ -1739,6 +1750,8 @@ int wifi_disable_forwarding(void) {
* usage: wifi_set_ch_deauth(0) -> wlan0 wifi_connect -> wifi_set_ch_deauth(1) * usage: wifi_set_ch_deauth(0) -> wlan0 wifi_connect -> wifi_set_ch_deauth(1)
*/ */
#ifdef CONFIG_CONCURRENT_MODE #ifdef CONFIG_CONCURRENT_MODE
extern int wext_set_ch_deauth(const char *ifname, __u8 enable);
int wifi_set_ch_deauth(__u8 enable) { int wifi_set_ch_deauth(__u8 enable) {
return wext_set_ch_deauth(WLAN1_NAME, enable); return wext_set_ch_deauth(WLAN1_NAME, enable);
} }

View file

@ -102,7 +102,7 @@ void wifi_indication(WIFI_EVENT_INDICATE event, unsigned char *buf, int buf_len,
// , and tries not to share the same stack with wlan driver if remaining stack space is // , and tries not to share the same stack with wlan driver if remaining stack space is
// not available for the following operations. // not available for the following operations.
// ex: using semaphore to notice another thread. // ex: using semaphore to notice another thread.
switch (event) { switch ((int)event) {
case WIFI_EVENT_DISCONNECT: case WIFI_EVENT_DISCONNECT:
#if(WIFI_INDICATE_MSG>0) #if(WIFI_INDICATE_MSG>0)
info_printf("%s(%d): Disconnection indication received\n", __func__, event); info_printf("%s(%d): Disconnection indication received\n", __func__, event);

View file

@ -19,9 +19,8 @@
extern void _promisc_deinit(_adapter *padapter); extern void _promisc_deinit(_adapter *padapter);
extern int _promisc_recv_func(_adapter *padapter, recv_frame *rframe); extern int _promisc_recv_func(_adapter *padapter, recv_frame *rframe);
extern int _promisc_set(rtw_rcr_level_t enabled, void (*callback)(unsigned char *, unsigned int, void *), unsigned char len_used); extern int _promisc_set(rtw_rcr_level_t enabled, void (*callback)(unsigned char *, unsigned int, void *), unsigned char len_used);
extern unsigned char is_promisc_enabled(void); extern unsigned char _is_promisc_enabled(void);
extern int promisc_get_fixed_channel(void *fixed_bssid, unsigned char *ssid, int *ssid_length); extern int _promisc_get_fixed_channel(void *fixed_bssid, unsigned char *ssid, int *ssid_length);
extern unsigned char is_promisc_enabled(void);
#endif #endif
@ -111,7 +110,7 @@ static struct eth_buffer eth_buffer;
#ifdef CONFIG_PROMISC #ifdef CONFIG_PROMISC
#define MAX_PACKET_FILTER_INFO 5 #define MAX_PACKET_FILTER_INFO 5
#define FILTER_ID_INIT_VALUE 10 #define FILTER_ID_INIT_VALUE 10
rtw_packet_filter_info_t paff_array[MAX_PACKET_FILTER_INFO]={0, 0, 0, 0, 0}; rtw_packet_filter_info_t paff_array[MAX_PACKET_FILTER_INFO]; // ={0, 0, 0, 0, 0};
static u8 packet_filter_enable_num = 0; static u8 packet_filter_enable_num = 0;
void promisc_init_packet_filter() void promisc_init_packet_filter()

View file

@ -209,7 +209,7 @@ int wext_get_passphrase(const char *ifname, __u8 *passphrase) {
rtw_result_t ret = RTW_ERROR; rtw_result_t ret = RTW_ERROR;
if(pdev) { if(pdev) {
uint16 len[4]; uint16 len[4];
ret = rtw_wx_get_passphrase(pdev, 0, &len, passphrase); ret = rtw_wx_get_passphrase(pdev, 0,(union iwreq_data *) &len, passphrase);
if(ret == RTW_SUCCESS) passphrase[len[2]] = '\0'; if(ret == RTW_SUCCESS) passphrase[len[2]] = '\0';
debug_printf("pas[%d]-<%s>\n", len[2], passphrase); debug_printf("pas[%d]-<%s>\n", len[2], passphrase);
} }
@ -404,7 +404,6 @@ int wext_get_lps_dtim(const char *ifname, __u8 *lps_dtim) {
int wext_set_tos_value(const char *ifname, __u8 *tos_value) { int wext_set_tos_value(const char *ifname, __u8 *tos_value) {
struct iwreq iwr; struct iwreq iwr;
int ret = -1;
__u8 para[sizeof("set_tos_value") + 4]; __u8 para[sizeof("set_tos_value") + 4];
int cmd_len = sizeof("set_tos_value"); int cmd_len = sizeof("set_tos_value");
memset(&iwr, 0, sizeof(iwr)); memset(&iwr, 0, sizeof(iwr));
@ -562,6 +561,8 @@ int wext_get_mode(const char *ifname, int *mode) {
#endif #endif
} }
extern int rtw_wx_set_ap_essid(struct net_device *dev, struct iw_request_info *a, union iwreq_data *wrqu, char *extra);
int wext_set_ap_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len) { int wext_set_ap_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len) {
#ifdef USE_WIFI_ADAPTER #ifdef USE_WIFI_ADAPTER
struct net_device * pdev = rltk_wlan_info[0].dev; struct net_device * pdev = rltk_wlan_info[0].dev;
@ -572,7 +573,7 @@ int wext_set_ap_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len) {
uint16 len[2]; uint16 len[2];
len[0] = ssid_len; len[0] = ssid_len;
len[1] = (ssid_len != 0); len[1] = (ssid_len != 0);
ret = rtw_wx_set_ap_essid(pdev, 0, &len, ssid); ret = rtw_wx_set_ap_essid(pdev, 0, (union iwreq_data *) &len, (char *)ssid);
} }
return ret; return ret;
#else #else
@ -751,7 +752,7 @@ int wext_private_command_with_retval(const char *ifname, char *cmd,
iwr.u.data.length = buf_size; iwr.u.data.length = buf_size;
iwr.u.data.flags = 0; iwr.u.data.flags = 0;
ret = iw_ioctl(ifname, SIOCDEVPRIVATE, &iwr); ret = iw_ioctl(ifname, SIOCDEVPRIVATE, &iwr);
if (ret >= 0 & ret_buf != NULL) { if (ret >= 0 && ret_buf != NULL) {
if (ret_len > iwr.u.data.length) if (ret_len > iwr.u.data.length)
ret_len = iwr.u.data.length; ret_len = iwr.u.data.length;
memcpy(ret_buf, (char *) iwr.u.data.pointer, ret_len); memcpy(ret_buf, (char *) iwr.u.data.pointer, ret_len);
@ -923,7 +924,6 @@ int wext_set_gen_ie(const char *ifname, char *buf, __u16 buf_len, __u16 flags) {
int wext_set_autoreconnect(const char *ifname, __u8 mode, __u8 retyr_times, int wext_set_autoreconnect(const char *ifname, __u8 mode, __u8 retyr_times,
__u16 timeout) { __u16 timeout) {
struct iwreq iwr; struct iwreq iwr;
int ret = 0;
__u8 para[sizeof("SetAutoRecnt") + 4]; __u8 para[sizeof("SetAutoRecnt") + 4];
int cmd_len = sizeof("SetAutoRecnt"); int cmd_len = sizeof("SetAutoRecnt");
memset(&iwr, 0, sizeof(iwr)); memset(&iwr, 0, sizeof(iwr));
@ -1017,7 +1017,7 @@ int wext_update_custom_ie(const char *ifname, void * cus_ie, int ie_index) {
#endif #endif
} else { } else {
memset(&iwr, 0, sizeof(iwr)); memset(&iwr, 0, sizeof(iwr));
cmd_len = para = pvPortMalloc((4) * 2 + cmd_len); //size:addr len+cmd_len para = pvPortMalloc((4) * 2 + cmd_len); //size:addr len+cmd_len
if (para != NULL) { if (para != NULL) {
//Cmd //Cmd
snprintf(para, cmd_len, "UpdateIE"); snprintf(para, cmd_len, "UpdateIE");

View file

@ -91,7 +91,7 @@ STATION_CONFIG wifi_st_cfg = {
.ssid = DEF_ST_SSID, .ssid = DEF_ST_SSID,
.password = DEF_ST_PASSWORD, .password = DEF_ST_PASSWORD,
.bssid = DEF_ST_BSSID, .bssid = DEF_ST_BSSID,
.flg = DEF_ST_BSSID, .flg = DEF_ST_USE_BSSID,
.security = DEF_ST_SECURITY, .security = DEF_ST_SECURITY,
.autoreconnect = DEF_ST_AUTORECONNECT, .autoreconnect = DEF_ST_AUTORECONNECT,
.reconnect_pause = DEF_ST_RECONNECT_PAUSE, .reconnect_pause = DEF_ST_RECONNECT_PAUSE,
@ -204,8 +204,8 @@ LOCAL int wlan_init_done_callback(void) {
//char wlan_st_name[] = WLAN0_NAME; //char wlan_st_name[] = WLAN0_NAME;
char wlan_st_name[] = WLAN0_NAME; char wlan_st_name[] = WLAN0_NAME;
char wlan_ap_name[] = WLAN1_NAME; char wlan_ap_name[] = WLAN1_NAME;
char wlan_st_netifn = 0; unsigned char wlan_st_netifn = 0;
char wlan_ap_netifn = 1; unsigned char wlan_ap_netifn = 1;
uint32 get_new_ip(void) uint32 get_new_ip(void)
@ -256,7 +256,7 @@ extern Rltk_wlan_t rltk_wlan_info[2]; // in wrapper.h
};*/ };*/
#define get_padapter(num) (*(_adapter **)((rltk_wlan_info[num].dev)->priv)); #define get_padapter(num) (*(_adapter **)((rltk_wlan_info[num].dev)->priv));
LOCAL rtw_result_t _wext_set_lps_dtim(int adapter_num, uint8 lps_dtim ) { rtw_result_t _wext_set_lps_dtim(int adapter_num, uint8 lps_dtim ) {
_adapter * pad = get_padapter(adapter_num); _adapter * pad = get_padapter(adapter_num);
rtw_result_t ret = RTW_ERROR; rtw_result_t ret = RTW_ERROR;
if(pad) { if(pad) {
@ -265,7 +265,7 @@ LOCAL rtw_result_t _wext_set_lps_dtim(int adapter_num, uint8 lps_dtim ) {
return ret; return ret;
} }
LOCAL rtw_result_t _wext_enable_powersave(int adapter_num, uint8 ips_mode, uint8 lps_mode) { rtw_result_t _wext_enable_powersave(int adapter_num, uint8 ips_mode, uint8 lps_mode) {
_adapter * pad = get_padapter(adapter_num); _adapter * pad = get_padapter(adapter_num);
rtw_result_t ret = RTW_ERROR; rtw_result_t ret = RTW_ERROR;
if(pad) { if(pad) {
@ -278,7 +278,7 @@ LOCAL rtw_result_t _wext_enable_powersave(int adapter_num, uint8 ips_mode, uint8
return ret; return ret;
} }
LOCAL int _wext_cmp_ssid(int adapter_num, uint8 *ssid) LOCAL int _wext_cmp_ssid(int adapter_num, unsigned char *ssid)
{ {
_adapter * pad = get_padapter(adapter_num); _adapter * pad = get_padapter(adapter_num);
int ret = 0; int ret = 0;
@ -357,7 +357,7 @@ LOCAL rtw_result_t wifi_run_ap(void) {
int timeout = wifi_test_timeout_ms / wifi_test_timeout_step_ms; int timeout = wifi_test_timeout_ms / wifi_test_timeout_step_ms;
while (1) { while (1) {
#if 1 #if 1
if (_wext_cmp_ssid(WLAN_AP_NETIF_NUM, &wifi_ap_cfg.ssid )) { if (_wext_cmp_ssid(WLAN_AP_NETIF_NUM, wifi_ap_cfg.ssid )) {
#else #else
char essid[33]; char essid[33];
if ((wext_get_ssid(wlan_ap_name, (unsigned char *) essid) > 0) if ((wext_get_ssid(wlan_ap_name, (unsigned char *) essid) > 0)
@ -404,7 +404,7 @@ LOCAL rtw_result_t StartStDHCPClient(void)
debug_printf("Start DHCPClient...\n"); debug_printf("Start DHCPClient...\n");
int ret = RTW_SUCCESS; int ret = RTW_SUCCESS;
struct netif * pnetif = &xnetif[WLAN_ST_NETIF_NUM]; struct netif * pnetif = &xnetif[WLAN_ST_NETIF_NUM];
DHCP_CONFIG *p = (dhcp_cfg *)&wifi_st_dhcp; DHCP_CONFIG *p = (DHCP_CONFIG *)&wifi_st_dhcp;
unsigned char mode = p->mode; unsigned char mode = p->mode;
if(mode == 2 && p->ip != IP4ADDR(255,255,255,255) && p->ip != IP4ADDR(0,0,0,0)) { // fixed ip if(mode == 2 && p->ip != IP4ADDR(255,255,255,255) && p->ip != IP4ADDR(0,0,0,0)) { // fixed ip
netif_set_addr(pnetif, (ip_addr_t *)&p->ip, (ip_addr_t *)&p->mask, (ip_addr_t *)&p->gw); netif_set_addr(pnetif, (ip_addr_t *)&p->ip, (ip_addr_t *)&p->mask, (ip_addr_t *)&p->gw);
@ -597,8 +597,8 @@ LOCAL void _LwIP_Init(void)
xnetif[idx].name[0] = 'r'; xnetif[idx].name[0] = 'r';
xnetif[idx].name[1] = '0' + idx; xnetif[idx].name[1] = '0' + idx;
} }
netif_add(&xnetif[WLAN_ST_NETIF_NUM], (struct netif *)&wifi_st_dhcp.ip, (struct netif *)&wifi_st_dhcp.mask, (struct netif *)&wifi_st_dhcp.gw, NULL, &ethernetif_init, &tcpip_input); netif_add(&xnetif[WLAN_ST_NETIF_NUM], (ip_addr_t *)&wifi_st_dhcp.ip, (ip_addr_t *)&wifi_st_dhcp.mask, (ip_addr_t *)&wifi_st_dhcp.gw, NULL, &ethernetif_init, &tcpip_input);
netif_add(&xnetif[WLAN_AP_NETIF_NUM], (struct netif *)&wifi_ap_dhcp.ip, (struct netif *)&wifi_ap_dhcp.mask, (struct netif *)&wifi_ap_dhcp.gw, NULL, &ethernetif_init, &tcpip_input); netif_add(&xnetif[WLAN_AP_NETIF_NUM], (ip_addr_t *)&wifi_ap_dhcp.ip, (ip_addr_t *)&wifi_ap_dhcp.mask, (ip_addr_t *)&wifi_ap_dhcp.gw, NULL, &ethernetif_init, &tcpip_input);
#if CONFIG_ETHERNET // && NET_IF_NUM > 2 #if CONFIG_ETHERNET // && NET_IF_NUM > 2
{ {
struct ip_addr ipaddr; struct ip_addr ipaddr;
@ -623,6 +623,9 @@ LOCAL void _LwIP_Init(void)
} }
} }
extern int rltk_set_tx_power_percentage(rtw_tx_pwr_percentage_t power_percentage_idx);
int wifi_run(rtw_mode_t mode) { int wifi_run(rtw_mode_t mode) {
int ret = 0; int ret = 0;
#if CONFIG_DEBUG_LOG > 4 #if CONFIG_DEBUG_LOG > 4
@ -663,8 +666,8 @@ int wifi_run(rtw_mode_t mode) {
netbios_set_name(WLAN_ST_NETIF_NUM, lwip_host_name[0]); netbios_set_name(WLAN_ST_NETIF_NUM, lwip_host_name[0]);
#endif #endif
#endif #endif
netif_set_addr(&xnetif[WLAN_ST_NETIF_NUM], &wifi_st_dhcp.ip, netif_set_addr(&xnetif[WLAN_ST_NETIF_NUM], (ip_addr_t *) &wifi_st_dhcp.ip,
&wifi_st_dhcp.mask, &wifi_st_dhcp.gw); (ip_addr_t *) &wifi_st_dhcp.mask, (ip_addr_t *) &wifi_st_dhcp.gw);
pnif = &xnetif[WLAN_AP_NETIF_NUM]; pnif = &xnetif[WLAN_AP_NETIF_NUM];
#if LWIP_NETIF_HOSTNAME #if LWIP_NETIF_HOSTNAME
// @todo ethernetif_init()... // @todo ethernetif_init()...
@ -673,8 +676,8 @@ int wifi_run(rtw_mode_t mode) {
netbios_set_name(WLAN_AP_NETIF_NUM, lwip_host_name[1]); netbios_set_name(WLAN_AP_NETIF_NUM, lwip_host_name[1]);
#endif #endif
#endif #endif
netif_set_addr(&xnetif[WLAN_AP_NETIF_NUM], &wifi_ap_dhcp.ip, netif_set_addr(&xnetif[WLAN_AP_NETIF_NUM], (ip_addr_t *) &wifi_ap_dhcp.ip,
&wifi_ap_dhcp.mask, &wifi_ap_dhcp.gw); (ip_addr_t *) &wifi_ap_dhcp.mask, (ip_addr_t *) &wifi_ap_dhcp.gw);
} }
switch(mode) { switch(mode) {
@ -856,3 +859,32 @@ void show_wifi_cfg(void) {
printf("\tSave flags: %p\n", wifi_cfg.save_flg); printf("\tSave flags: %p\n", wifi_cfg.save_flg);
} }
#if SDK_VER_NUM >= 0x4000
extern int wext_get_associated_client_list(const char *ifname, void * client_list_buffer, __u16 buffer_length);
int show_wifi_ap_clients(void) {
if((wifi_mode == RTW_MODE_AP) || (wifi_mode == RTW_MODE_STA_AP)) {
struct {
int count;
rtw_mac_t mac_list[AP_STA_NUM];
} client_info;
client_info.count = AP_STA_NUM;
if(wext_get_associated_client_list(wlan_ap_name, &client_info, sizeof(client_info)) >= 0) {
if(client_info.count) {
printf("\tAP %u clients:\n", client_info.count);
int client_idx = 0;
while(client_idx++ < client_info.count) {
unsigned char *pmac = client_info.mac_list[client_idx].octet;
printf("\tsta[%u]: %02x:%02x:%02x:%02x:%02x:%02x\n", client_idx,
pmac[0],pmac[1],pmac[2],pmac[3],pmac[4],pmac[5]);
}
} else {
printf("\tAP clients none\n");
}
return client_info.count;
};
};
printf("Get AP clients error!\n");
return -1;
}
#endif

View file

@ -10,10 +10,12 @@
#include "wifi_constants.h" #include "wifi_constants.h"
#include "queue.h" #include "queue.h"
#ifndef ip4_addr1
#define ip4_addr1(ipaddr) (((uint8_t*)(ipaddr))[0]) #define ip4_addr1(ipaddr) (((uint8_t*)(ipaddr))[0])
#define ip4_addr2(ipaddr) (((uint8_t*)(ipaddr))[1]) #define ip4_addr2(ipaddr) (((uint8_t*)(ipaddr))[1])
#define ip4_addr3(ipaddr) (((uint8_t*)(ipaddr))[2]) #define ip4_addr3(ipaddr) (((uint8_t*)(ipaddr))[2])
#define ip4_addr4(ipaddr) (((uint8_t*)(ipaddr))[3]) #define ip4_addr4(ipaddr) (((uint8_t*)(ipaddr))[3])
#endif
#define IPSTR "%d.%d.%d.%d" #define IPSTR "%d.%d.%d.%d"
@ -118,8 +120,8 @@ extern unsigned char wifi_mode; // rtw_mode_t
extern unsigned char wifi_st_status; // WIFI_STA_ENUM extern unsigned char wifi_st_status; // WIFI_STA_ENUM
extern char wlan_st_name[]; extern char wlan_st_name[];
extern char wlan_ap_name[]; extern char wlan_ap_name[];
extern char wlan_st_netifn; extern unsigned char wlan_st_netifn;
extern char wlan_ap_netifn; extern unsigned char wlan_ap_netifn;
/* WiFi Station & scan security */ /* WiFi Station & scan security */
typedef enum { typedef enum {
@ -152,6 +154,9 @@ void show_wifi_st_ip(void);
void show_wifi_cfg(void); void show_wifi_cfg(void);
void show_wifi_st_cfg(void); void show_wifi_st_cfg(void);
void show_wifi_ap_cfg(void); void show_wifi_ap_cfg(void);
#if SDK_VER_NUM >= 0x4000
int show_wifi_ap_clients(void);
#endif
uint32 read_wifi_cfg(uint32 flg); uint32 read_wifi_cfg(uint32 flg);
uint32 write_wifi_cfg(uint32 flg); uint32 write_wifi_cfg(uint32 flg);
int wifi_run(rtw_mode_t mode); int wifi_run(rtw_mode_t mode);
@ -185,4 +190,9 @@ rtw_result_t api_wifi_scan(api_scan_result_handler_t scan_result_cb);
void wifi_close_scan(void); void wifi_close_scan(void);
rtw_result_t _wext_set_lps_dtim(int adapter_num, uint8 lps_dtim);
int _wext_get_lps_dtim(int adapter_num);
rtw_result_t _wext_enable_powersave(int adapter_num, uint8 ips_mode, uint8 lps_mode);
#endif // _WIFI_API_H_ #endif // _WIFI_API_H_

View file

@ -90,7 +90,7 @@ LOCAL void _wifi_scan_done_hdl(char* buf, int buf_len, int flags, void* userdata
web_scan_handler_t * pwscn_rec = &web_scan_handler_ptr; web_scan_handler_t * pwscn_rec = &web_scan_handler_ptr;
if(pscan_rec->gscan_result_handler) { if(pscan_rec->gscan_result_handler) {
// сторонний вывод // сторонний вывод
(*pscan_rec->gscan_result_handler)(pscan_rec); (*pscan_rec->gscan_result_handler)((rtw_scan_handler_result_t *) pscan_rec);
} }
else { else {
// оставить структуру pscan_rec->pap_details[i] для вывода в web scan на 5 сек // оставить структуру pscan_rec->pap_details[i] для вывода в web scan на 5 сек
@ -136,6 +136,7 @@ LOCAL int _wifi_scan_networks(rtw_scan_result_handler_t results_handler) {
} }
/* -------- wext_set_pscan_channels ----------------- */ /* -------- wext_set_pscan_channels ----------------- */
extern int iw_ioctl(const char * ifname, unsigned long request, struct iwreq * pwrq);
LOCAL int wext_set_pscan_channels(void) { LOCAL int wext_set_pscan_channels(void) {
struct iwreq iwr; struct iwreq iwr;
@ -183,7 +184,7 @@ rtw_result_t api_wifi_scan(api_scan_result_handler_t scan_result_cb)
// error_printf("Error xTimerStart\n"); // error_printf("Error xTimerStart\n");
} else if(wext_set_pscan_channels() < 0) { } else if(wext_set_pscan_channels() < 0) {
// error_printf("ERROR: wifi set partial scan channel fail\n"); // error_printf("ERROR: wifi set partial scan channel fail\n");
} else if(_wifi_scan_networks(scan_result_cb) != RTW_SUCCESS) { } else if(_wifi_scan_networks((rtw_scan_result_handler_t) scan_result_cb) != RTW_SUCCESS) {
// error_printf("ERROR: wifi scan failed\n"); // error_printf("ERROR: wifi scan failed\n");
} else if(scan_result_cb) { } else if(scan_result_cb) {
int i = 300; int i = 300;

View file

@ -259,7 +259,7 @@ s8 sdio_sd_setClock(SD_CLK_FREQUENCY SDCLK) {
DBG_SDIO_ERR("Malloc ADMA2 table fail.\n"); DBG_SDIO_ERR("Malloc ADMA2 table fail.\n");
return -1; return -1;
} }
DBG_SDIO_INFO("SD card set CLK %d Hz\n", PLATFORM_CLOCK/(4<<(8-SDCLK))); DBG_SDIO_INFO("SD card set CLK %d Hz\n", PLATFORM_CLOCK/(2 << (SD_CLK_41_6MHZ - SDCLK)));
sta = HalSdioHostOp.HalSdioHostChangeSdClock(&SdioHostAdapter, SDCLK); sta = HalSdioHostOp.HalSdioHostChangeSdClock(&SdioHostAdapter, SDCLK);
rtw_mfree(padma, sizeof(ADMA2_DESC_FMT)); rtw_mfree(padma, sizeof(ADMA2_DESC_FMT));
if (sta) if (sta)

View file

@ -39,8 +39,8 @@
// 0x0000h ~ 0x00FFh System Configuration // 0x0000h ~ 0x00FFh System Configuration
// //
//----------------------------------------------------- //-----------------------------------------------------
#define REG_SYS_ISO_CTRL 0x0000 #define REG_SYS_ISO_CTRL_ 0x0000
#define REG_SYS_FUNC_EN 0x0002 #define REG_SYS_FUNC_EN_ 0x0002
#define REG_APS_FSMCO 0x0004 #define REG_APS_FSMCO 0x0004
#define REG_SYS_CLKR 0x0008 #define REG_SYS_CLKR 0x0008
#define REG_9346CR 0x000A #define REG_9346CR 0x000A
@ -515,7 +515,7 @@
#define REG_BSSID1 0x0708 #define REG_BSSID1 0x0708
/* port0 & port1 enable */ /* port0 & port1 enable */
#define REG_PORT_CTRL 0x76D //#define REG_PORT_CTRL 0x76D
//----------------------------------------------------- //-----------------------------------------------------
// //
@ -872,7 +872,7 @@ Default: 00b.
#define IMR_PSTIMEOUT BIT14 // Power save time out interrupt #define IMR_PSTIMEOUT BIT14 // Power save time out interrupt
#define IMR_BcnInt BIT13 // Beacon DMA Interrupt 0 #define IMR_BcnInt BIT13 // Beacon DMA Interrupt 0
#define IMR_RXFOVW BIT12 // Receive FIFO Overflow #define IMR_RXFOVW BIT12 // Receive FIFO Overflow
#define IMR_RDU BIT11 // Receive Descriptor Unavailable #define IMR_RDU_ BIT11 // Receive Descriptor Unavailable
#define IMR_ATIMEND BIT10 // For 92C,ATIM Window End Interrupt. For 8723 and later ICs, it also means P2P CTWin End interrupt. #define IMR_ATIMEND BIT10 // For 92C,ATIM Window End Interrupt. For 8723 and later ICs, it also means P2P CTWin End interrupt.
#define IMR_BDOK BIT9 // Beacon Queue DMA OK Interrup #define IMR_BDOK BIT9 // Beacon Queue DMA OK Interrup
#define IMR_HIGHDOK BIT8 // High Queue DMA OK Interrupt #define IMR_HIGHDOK BIT8 // High Queue DMA OK Interrupt

View file

@ -133,14 +133,14 @@ void rltk_wlan_recv(int idx, struct eth_drv_sg *sg_list, int sg_len)
DBG_TRACE("%s is called", __FUNCTION__); DBG_TRACE("%s is called", __FUNCTION__);
if (!rltk_wlan_check_isup(idx))
return;
if(idx == -1){ if(idx == -1){
DBG_ERR("skb is NULL"); DBG_ERR("skb is NULL");
return; return;
} }
if (!rltk_wlan_check_isup(idx))
return;
skb = rltk_wlan_get_recv_skb(idx); skb = rltk_wlan_get_recv_skb(idx);
DBG_ASSERT(skb, "No pending rx skb"); DBG_ASSERT(skb, "No pending rx skb");

View file

@ -1,6 +1,6 @@
#ifndef _SDCARD_H_ #ifndef _SDCARD_H_
#define _SDCARD_H_ #define _SDCARD_H_
#include "fatfs_ext/inc/ff_driver.h" #include "ff_driver.h"
extern ll_diskio_drv SD_disk_Driver; extern ll_diskio_drv SD_disk_Driver;
#endif #endif

View file

@ -17,6 +17,8 @@
#include "us_ticker_api.h" #include "us_ticker_api.h"
#include "platform_autoconf.h" #include "platform_autoconf.h"
#include "FreeRTOS.h"
#include "task.h"
#define WAIT_US_USE_CYCCNT #define WAIT_US_USE_CYCCNT

View file

@ -27,7 +27,9 @@ extern "C" {
typedef enum { typedef enum {
IRQ_NONE, IRQ_NONE,
IRQ_RISE, IRQ_RISE,
IRQ_FALL IRQ_FALL,
IRQ_LOW,
IRQ_HIGH
} gpio_irq_event; } gpio_irq_event;
typedef void (*gpio_irq_handler)(uint32_t id, gpio_irq_event event); typedef void (*gpio_irq_handler)(uint32_t id, gpio_irq_event event);

View file

@ -24,10 +24,12 @@
extern "C" { extern "C" {
#endif #endif
/*
typedef enum { typedef enum {
IRQ_LOW = 3, IRQ_LOW = 3,
IRQ_HIGH =4 IRQ_HIGH =4
} gpio_irq_event_ex; } gpio_irq_event_ex;
*/
void gpio_irq_deinit(gpio_irq_t *obj); void gpio_irq_deinit(gpio_irq_t *obj);
void gpio_irq_pull_ctrl(gpio_irq_t *obj, PinMode pull_type); void gpio_irq_pull_ctrl(gpio_irq_t *obj, PinMode pull_type);

View file

@ -118,13 +118,13 @@ void analogin_init (analogin_t *obj, PinName pin){
} }
float analogin_read(analogin_t *obj){ float analogin_read(analogin_t *obj){
float value; // float value;
union { union {
unsigned int ui[2]; unsigned int ui[2];
unsigned short us[4]; unsigned short us[4];
} adata; } adata;
PSAL_ADC_HND p = &((&(obj->SalADCMngtAdpt))->pSalHndPriv->SalADCHndPriv); PSAL_ADC_HND p = &((&(obj->SalADCMngtAdpt))->pSalHndPriv->SalADCHndPriv);
RtkADCReceiveBuf(p, &adata.ui); RtkADCReceiveBuf(p, (u32 *) &adata.ui);
return (float)(adata.us[p->DevNum]) / (float)(0xCE80); return (float)(adata.us[p->DevNum]) / (float)(0xCE80);
/* /*
uint32_t AnaloginTmp[2] = {0,0}; uint32_t AnaloginTmp[2] = {0,0};
@ -161,7 +161,7 @@ uint16_t analogin_read_u16(analogin_t *obj){
unsigned short us[4]; unsigned short us[4];
} adata; } adata;
PSAL_ADC_HND p = &((&(obj->SalADCMngtAdpt))->pSalHndPriv->SalADCHndPriv); PSAL_ADC_HND p = &((&(obj->SalADCMngtAdpt))->pSalHndPriv->SalADCHndPriv);
RtkADCRxManualRotate(p, &adata.ui); RtkADCRxManualRotate(p, (u32 *) &adata.ui);
return adata.us[p->DevNum]; return adata.us[p->DevNum];
/* /*
uint32_t AnaloginTmp[2] = {0,0}; uint32_t AnaloginTmp[2] = {0,0};

View file

@ -592,6 +592,8 @@ unsigned int flash_get_size(flash_t *obj) {
/* /*
* Read Flash OTP data * Read Flash OTP data
*/ */
extern void SpicTxCmdWithDataRtl8195A(u8 cmd, u8 DataPhaseLen, u8* pData, SPIC_INIT_PARA SpicInitPara);
int flash_otp_read(flash_t *obj, uint32_t address, uint32_t Length, int flash_otp_read(flash_t *obj, uint32_t address, uint32_t Length,
uint8_t * data) { uint8_t * data) {
int ret = 1; int ret = 1;

View file

@ -350,7 +350,7 @@ LOCAL FLASH_EEP_ATTR unsigned int pack_cfg_fmem(fobj_head obj)
#if 0 #if 0
copy_align4_to_align1((uint8 *)pbuf, rdaddr, len); copy_align4_to_align1((uint8 *)pbuf, rdaddr, len);
#else #else
SpicUserReadFourByteRtl8195A(len, rdaddr, (unsigned int *)pbuf, flashobj.SpicInitPara.Mode.BitMode); SpicUserReadFourByteRtl8195A(len, rdaddr, (u32 *)pbuf, flashobj.SpicInitPara.Mode.BitMode);
#endif #endif
int i = 0; int i = 0;
int size4b = len >> 2; int size4b = len >> 2;
@ -376,7 +376,7 @@ LOCAL signed short FLASH_EEP_ATTR _flash_write_cfg(void *ptr, unsigned short id,
fobj_head fobj; fobj_head fobj;
fobj.n.id = id; fobj.n.id = id;
fobj.n.size = size; fobj.n.size = size;
bool retb = false; // bool retb = false;
unsigned int faddr = get_addr_bscfg(false); unsigned int faddr = get_addr_bscfg(false);
if(faddr >= FMEM_ERROR_MAX) { if(faddr >= FMEM_ERROR_MAX) {

View file

@ -573,6 +573,7 @@ int i2c_enable_control(i2c_t *obj, int enable) {
pSalI2CHND->pInitDat->I2CEn = enable; pSalI2CHND->pInitDat->I2CEn = enable;
pSalI2CMngtAdpt->pHalOp->HalI2CEnable(pSalI2CHND->pInitDat); pSalI2CMngtAdpt->pHalOp->HalI2CEnable(pSalI2CHND->pInitDat);
return 1;
} }
#if DEVICE_I2CSLAVE #if DEVICE_I2CSLAVE
@ -719,14 +720,14 @@ int i2c_slave_write(i2c_t *obj, const char *data, int length) {
* \return result * \return result
*/ */
int i2c_slave_set_for_rd_req(i2c_t *obj, int set) { int i2c_slave_set_for_rd_req(i2c_t *obj, int set) {
PSAL_I2C_MNGT_ADPT pSalI2CMngtAdpt = NULL; PSAL_I2C_MNGT_ADPT pSalI2CMngtAdpt;
PSAL_I2C_HND pSalI2CHND = NULL; // PSAL_I2C_HND pSalI2CHND = NULL;
PHAL_I2C_INIT_DAT pHalI2CInitDat = NULL; PHAL_I2C_INIT_DAT pHalI2CInitDat;
PHAL_I2C_OP pHalI2COP = NULL; PHAL_I2C_OP pHalI2COP;
u32 I2CLocalTemp; u32 I2CLocalTemp;
pSalI2CMngtAdpt = &(obj->SalI2CMngtAdpt); pSalI2CMngtAdpt = &(obj->SalI2CMngtAdpt);
pSalI2CHND = &(pSalI2CMngtAdpt->pSalHndPriv->SalI2CHndPriv); // pSalI2CHND = &(pSalI2CMngtAdpt->pSalHndPriv->SalI2CHndPriv);
pHalI2CInitDat = pSalI2CMngtAdpt->pHalInitDat; pHalI2CInitDat = pSalI2CMngtAdpt->pHalInitDat;
pHalI2COP = pSalI2CMngtAdpt->pHalOp; pHalI2COP = pSalI2CMngtAdpt->pHalOp;
@ -772,6 +773,7 @@ int i2c_slave_set_for_data_nak(i2c_t *obj, int set_nak) {
//} //}
HAL_I2C_WRITE32(pSalI2CHND->DevNum, REG_DW_I2C_IC_SLV_DATA_NACK_ONLY, set_nak); HAL_I2C_WRITE32(pSalI2CHND->DevNum, REG_DW_I2C_IC_SLV_DATA_NACK_ONLY, set_nak);
return 1;
} }
#endif // CONFIG_I2C_SLAVE_EN #endif // CONFIG_I2C_SLAVE_EN

View file

@ -253,7 +253,7 @@ void log_uart_irq_set(log_uart_t *obj, LOG_UART_INT_ID irq, uint32_t enable)
char log_uart_getc(log_uart_t *obj) char log_uart_getc(log_uart_t *obj)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
while (!log_uart_readable(obj)); while (!log_uart_readable(obj));
return (char)(HAL_UART_READ32(UART_REV_BUF_OFF) & 0xFF); return (char)(HAL_UART_READ32(UART_REV_BUF_OFF) & 0xFF);
@ -261,7 +261,7 @@ char log_uart_getc(log_uart_t *obj)
void log_uart_putc(log_uart_t *obj, char c) void log_uart_putc(log_uart_t *obj, char c)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
while (!log_uart_writable(obj)); while (!log_uart_writable(obj));
HAL_UART_WRITE8(UART_TRAN_HOLD_OFF, c); HAL_UART_WRITE8(UART_TRAN_HOLD_OFF, c);
@ -269,7 +269,7 @@ void log_uart_putc(log_uart_t *obj, char c)
int log_uart_readable(log_uart_t *obj) int log_uart_readable(log_uart_t *obj)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
volatile u8 line_status; volatile u8 line_status;
line_status = HAL_UART_READ8(UART_LINE_STATUS_REG_OFF); line_status = HAL_UART_READ8(UART_LINE_STATUS_REG_OFF);
@ -283,7 +283,7 @@ int log_uart_readable(log_uart_t *obj)
int log_uart_writable(log_uart_t *obj) int log_uart_writable(log_uart_t *obj)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
volatile u8 line_status; volatile u8 line_status;
line_status = HAL_UART_READ8(UART_LINE_STATUS_REG_OFF); line_status = HAL_UART_READ8(UART_LINE_STATUS_REG_OFF);
@ -321,7 +321,7 @@ void log_uart_clear_rx(log_uart_t *obj)
void log_uart_break_set(log_uart_t *obj) void log_uart_break_set(log_uart_t *obj)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
u32 RegValue; u32 RegValue;
RegValue = HAL_UART_READ32(UART_LINE_CTL_REG_OFF); RegValue = HAL_UART_READ32(UART_LINE_CTL_REG_OFF);
@ -331,7 +331,7 @@ void log_uart_break_set(log_uart_t *obj)
void log_uart_break_clear(log_uart_t *obj) void log_uart_break_clear(log_uart_t *obj)
{ {
HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart); // HAL_LOG_UART_ADAPTER *pUartAdapter=(PHAL_LOG_UART_ADAPTER)&(obj->log_hal_uart);
u32 RegValue; u32 RegValue;
RegValue = HAL_UART_READ32(UART_LINE_CTL_REG_OFF); RegValue = HAL_UART_READ32(UART_LINE_CTL_REG_OFF);

View file

@ -44,6 +44,8 @@ const PinMap PinMap_PWM[] = {
{NC, NC, 0} {NC, NC, 0}
}; };
extern void * rtl_memset(void *m, int c, size_t n);
int pwmout_init(pwmout_t* obj, PinName pin) int pwmout_init(pwmout_t* obj, PinName pin)
{ {
uint32_t peripheral; uint32_t peripheral;

View file

@ -536,12 +536,12 @@ int32_t serial_send_stream (serial_t *obj, char *ptxbuf, uint32_t len)
int32_t serial_recv_stream_dma (serial_t *obj, char *prxbuf, uint32_t len) int32_t serial_recv_stream_dma (serial_t *obj, char *prxbuf, uint32_t len)
{ {
PHAL_RUART_OP pHalRuartOp; // PHAL_RUART_OP pHalRuartOp;
PHAL_RUART_ADAPTER pHalRuartAdapter=(PHAL_RUART_ADAPTER)&(obj->hal_uart_adp); PHAL_RUART_ADAPTER pHalRuartAdapter=(PHAL_RUART_ADAPTER)&(obj->hal_uart_adp);
u8 uart_idx = pHalRuartAdapter->UartIndex; u8 uart_idx = pHalRuartAdapter->UartIndex;
int32_t ret; int32_t ret;
pHalRuartOp = &(obj->hal_uart_op); // pHalRuartOp = &(obj->hal_uart_op);
if ((serial_dma_en[uart_idx] & SERIAL_RX_DMA_EN)==0) { if ((serial_dma_en[uart_idx] & SERIAL_RX_DMA_EN)==0) {
PUART_DMA_CONFIG pHalRuartDmaCfg; PUART_DMA_CONFIG pHalRuartDmaCfg;
@ -563,12 +563,12 @@ int32_t serial_recv_stream_dma (serial_t *obj, char *prxbuf, uint32_t len)
int32_t serial_send_stream_dma (serial_t *obj, char *ptxbuf, uint32_t len) int32_t serial_send_stream_dma (serial_t *obj, char *ptxbuf, uint32_t len)
{ {
PHAL_RUART_OP pHalRuartOp; // PHAL_RUART_OP pHalRuartOp;
PHAL_RUART_ADAPTER pHalRuartAdapter=(PHAL_RUART_ADAPTER)&(obj->hal_uart_adp); PHAL_RUART_ADAPTER pHalRuartAdapter=(PHAL_RUART_ADAPTER)&(obj->hal_uart_adp);
u8 uart_idx = pHalRuartAdapter->UartIndex; u8 uart_idx = pHalRuartAdapter->UartIndex;
int32_t ret; int32_t ret;
pHalRuartOp = &(obj->hal_uart_op); // pHalRuartOp = &(obj->hal_uart_op);
if ((serial_dma_en[uart_idx] & SERIAL_TX_DMA_EN)==0) { if ((serial_dma_en[uart_idx] & SERIAL_TX_DMA_EN)==0) {
PUART_DMA_CONFIG pHalRuartDmaCfg; PUART_DMA_CONFIG pHalRuartDmaCfg;

View file

@ -58,13 +58,11 @@ void spi_init (spi_t *obj, PinName mosi, PinName miso, PinName sclk, PinName sse
_memset((void*)obj, 0, sizeof(spi_t)); _memset((void*)obj, 0, sizeof(spi_t));
obj->state = 0; obj->state = 0;
uint32_t SystemClock = SystemGetCpuClk();
uint32_t MaxSsiFreq = (SystemClock >> 2) >> 1;
/* SsiClockDivider doesn't support odd number */ /* SsiClockDivider doesn't support odd number */
DBG_SSI_INFO("SystemClock: %d\n", SystemClock); DBG_SSI_INFO("SystemClock: %d\n", SystemGetCpuClk());
DBG_SSI_INFO("MaxSsiFreq : %d\n", MaxSsiFreq); DBG_SSI_INFO("MaxSsiFreq : %d\n", (SystemClock >> 2) >> 1);
ssi_mosi = pinmap_peripheral(mosi, PinMap_SSI_MOSI); ssi_mosi = pinmap_peripheral(mosi, PinMap_SSI_MOSI);
ssi_miso = pinmap_peripheral(miso, PinMap_SSI_MISO); ssi_miso = pinmap_peripheral(miso, PinMap_SSI_MISO);

View file

@ -41,7 +41,7 @@ extern void HalDeinitLogUart(void);
#ifdef CONFIG_SDR_EN #ifdef CONFIG_SDR_EN
//#if defined ( __ICCARM__ ) //#if defined ( __ICCARM__ )
extern u8 IsSdrPowerOn(); extern u8 IsSdrPowerOn(void);
//#endif //#endif
#endif #endif
/** /**
@ -204,11 +204,16 @@ void sys_reset(void)
} }
#ifdef CONFIG_SDR_EN #ifdef CONFIG_SDR_EN
extern u8 IsSdrPowerOn(void);
u8 sys_is_sdram_power_on(void) u8 sys_is_sdram_power_on(void)
{ {
return IsSdrPowerOn(); return IsSdrPowerOn();
} }
extern void SdrPowerOff(void);
void sys_sdram_off(void) void sys_sdram_off(void)
{ {
if (IsSdrPowerOn()) { if (IsSdrPowerOn()) {

View file

@ -30,8 +30,8 @@
#define DHCP_MESSAGE_HTYPE (1) #define DHCP_MESSAGE_HTYPE (1)
#define DHCP_MESSAGE_HLEN (6) #define DHCP_MESSAGE_HLEN (6)
#define DHCP_SERVER_PORT (67) //#define DHCP_SERVER_PORT (67)
#define DHCP_CLIENT_PORT (68) //#define DHCP_CLIENT_PORT (68)
#define DHCP_MESSAGE_TYPE_DISCOVER (1) #define DHCP_MESSAGE_TYPE_DISCOVER (1)
#define DHCP_MESSAGE_TYPE_OFFER (2) #define DHCP_MESSAGE_TYPE_OFFER (2)

View file

@ -91,9 +91,12 @@ static void arp_timer(void *arg);
#if LWIP_NETIF_HOSTNAME #if LWIP_NETIF_HOSTNAME
char lwip_host_name[NET_IF_NUM][LWIP_NETIF_HOSTNAME_SIZE] = { char lwip_host_name[NET_IF_NUM][LWIP_NETIF_HOSTNAME_SIZE] = {
DEF_HOSTNAME"0", { DEF_HOSTNAME"0" },
DEF_HOSTNAME"1", { DEF_HOSTNAME"1" }
DEF_HOSTNAME"2" #if NET_IF_NUM > 2
,{ DEF_HOSTNAME "2" }
#endif
}; };
#endif #endif

View file

@ -38,7 +38,7 @@
#include "lwip/err.h" #include "lwip/err.h"
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
static const char *err_strerr[] = { static const char *err_strerr[] = {
"Ok", /* ERR_OK 0 */ "Ok", /* ERR_OK 0 */

View file

@ -105,7 +105,7 @@ struct lwip_select_cb {
struct lwip_setgetsockopt_data { struct lwip_setgetsockopt_data {
/** socket struct for which to change options */ /** socket struct for which to change options */
struct lwip_sock *sock; struct lwip_sock *sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
/** socket index for which to change options */ /** socket index for which to change options */
int s; int s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
@ -1641,7 +1641,7 @@ lwip_getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
/* Now do the actual option processing */ /* Now do the actual option processing */
data.sock = sock; data.sock = sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
data.s = s; data.s = s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
data.level = level; data.level = level;
@ -1662,7 +1662,7 @@ static void
lwip_getsockopt_internal(void *arg) lwip_getsockopt_internal(void *arg)
{ {
struct lwip_sock *sock; struct lwip_sock *sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
int s; int s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
int level, optname; int level, optname;
@ -1673,7 +1673,7 @@ lwip_getsockopt_internal(void *arg)
data = (struct lwip_setgetsockopt_data*)arg; data = (struct lwip_setgetsockopt_data*)arg;
sock = data->sock; sock = data->sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
s = data->s; s = data->s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
level = data->level; level = data->level;
@ -2059,7 +2059,7 @@ lwip_setsockopt(int s, int level, int optname, const void *optval, socklen_t opt
/* Now do the actual option processing */ /* Now do the actual option processing */
data.sock = sock; data.sock = sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
data.s = s; data.s = s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
data.level = level; data.level = level;
@ -2080,7 +2080,7 @@ static void
lwip_setsockopt_internal(void *arg) lwip_setsockopt_internal(void *arg)
{ {
struct lwip_sock *sock; struct lwip_sock *sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
int s; int s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
int level, optname; int level, optname;
@ -2091,7 +2091,7 @@ lwip_setsockopt_internal(void *arg)
data = (struct lwip_setgetsockopt_data*)arg; data = (struct lwip_setgetsockopt_data*)arg;
sock = data->sock; sock = data->sock;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
s = data->s; s = data->s;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
level = data->level; level = data->level;

View file

@ -308,7 +308,7 @@ err_t
tcpip_apimsg(struct api_msg *apimsg) tcpip_apimsg(struct api_msg *apimsg)
{ {
struct tcpip_msg msg; struct tcpip_msg msg;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
/* catch functions that don't set err */ /* catch functions that don't set err */
apimsg->msg.err = ERR_VAL; apimsg->msg.err = ERR_VAL;
#endif #endif
@ -339,7 +339,7 @@ tcpip_apimsg(struct api_msg *apimsg)
err_t err_t
tcpip_apimsg_lock(struct api_msg *apimsg) tcpip_apimsg_lock(struct api_msg *apimsg)
{ {
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
/* catch functions that don't set err */ /* catch functions that don't set err */
apimsg->msg.err = ERR_VAL; apimsg->msg.err = ERR_VAL;
#endif #endif

View file

@ -1008,7 +1008,7 @@ dhcp_bind(struct netif *netif)
ip_addr_copy(gw_addr, dhcp->offered_gw_addr); ip_addr_copy(gw_addr, dhcp->offered_gw_addr);
/* gateway address not given? */ /* gateway address not given? */
if (ip_addr_isany(&gw_addr)) { if (gw_addr.addr == IPADDR_ANY) {
/* copy network address */ /* copy network address */
ip_addr_get_network(&gw_addr, &dhcp->offered_ip_addr, &sn_mask); ip_addr_get_network(&gw_addr, &dhcp->offered_ip_addr, &sn_mask);
/* use first host address on network as gateway */ /* use first host address on network as gateway */

View file

@ -77,7 +77,7 @@ void
icmp_input(struct pbuf *p, struct netif *inp) icmp_input(struct pbuf *p, struct netif *inp)
{ {
u8_t type; u8_t type;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
u8_t code; u8_t code;
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
struct icmp_echo_hdr *iecho; struct icmp_echo_hdr *iecho;
@ -96,7 +96,7 @@ icmp_input(struct pbuf *p, struct netif *inp)
} }
type = *((u8_t *)p->payload); type = *((u8_t *)p->payload);
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
code = *(((u8_t *)p->payload)+1); code = *(((u8_t *)p->payload)+1);
#endif /* LWIP_DEBUG */ #endif /* LWIP_DEBUG */
switch (type) { switch (type) {

View file

@ -161,7 +161,7 @@ igmp_init(void)
IP4_ADDR(&allrouters, 224, 0, 0, 2); IP4_ADDR(&allrouters, 224, 0, 0, 2);
} }
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
/** /**
* Dump global IGMP groups list * Dump global IGMP groups list
*/ */

View file

@ -128,8 +128,9 @@ struct netif *
ip_route(ip_addr_t *dest) ip_route(ip_addr_t *dest)
{ {
struct netif *netif; struct netif *netif;
#if CONFIG_ETHERNET
struct netif *last_netif = NULL; struct netif *last_netif = NULL;
#endif
#ifdef LWIP_HOOK_IP4_ROUTE #ifdef LWIP_HOOK_IP4_ROUTE
netif = LWIP_HOOK_IP4_ROUTE(dest); netif = LWIP_HOOK_IP4_ROUTE(dest);
if (netif != NULL) { if (netif != NULL) {
@ -498,7 +499,7 @@ ip_input(struct pbuf *p, struct netif *inp)
/* broadcast or multicast packet source address? Compliant with RFC 1122: 3.2.1.3 */ /* broadcast or multicast packet source address? Compliant with RFC 1122: 3.2.1.3 */
#if IP_ACCEPT_LINK_LAYER_ADDRESSING #if IP_ACCEPT_LINK_LAYER_ADDRESSING
/* DHCP servers need 0.0.0.0 to be allowed as source address (RFC 1.1.2.2: 3.2.1.3/a) */ /* DHCP servers need 0.0.0.0 to be allowed as source address (RFC 1.1.2.2: 3.2.1.3/a) */
if (check_ip_src && !ip_addr_isany(&current_iphdr_src)) if (check_ip_src && current_iphdr_src.addr != IPADDR_ANY)
#endif /* IP_ACCEPT_LINK_LAYER_ADDRESSING */ #endif /* IP_ACCEPT_LINK_LAYER_ADDRESSING */
{ if ((ip_addr_isbroadcast(&current_iphdr_src, inp)) || { if ((ip_addr_isbroadcast(&current_iphdr_src, inp)) ||
(ip_addr_ismulticast(&current_iphdr_src))) { (ip_addr_ismulticast(&current_iphdr_src))) {

View file

@ -140,7 +140,7 @@ static const u16_t memp_num[MEMP_MAX] = {
}; };
/** This array holds a textual description of each pool. */ /** This array holds a textual description of each pool. */
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
static const char *memp_desc[MEMP_MAX] = { static const char *memp_desc[MEMP_MAX] = {
#define LWIP_MEMPOOL(name,num,size,desc) (desc), #define LWIP_MEMPOOL(name,num,size,desc) (desc),
#include "lwip/memp_std.h" #include "lwip/memp_std.h"

View file

@ -50,7 +50,7 @@ struct stats_ lwip_stats;
void stats_init(void) void stats_init(void)
{ {
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
#if MEMP_STATS #if MEMP_STATS
const char * memp_names[] = { const char * memp_names[] = {
#define LWIP_MEMPOOL(name,num,size,desc) desc, #define LWIP_MEMPOOL(name,num,size,desc) desc,

View file

@ -187,7 +187,7 @@ etharp_free_entry(int i)
} }
/* recycle entry for re-use */ /* recycle entry for re-use */
arp_table[i].state = ETHARP_STATE_EMPTY; arp_table[i].state = ETHARP_STATE_EMPTY;
#ifdef LWIP_DEBUG #if defined(LWIP_DEBUG) && (LWIP_DEBUG != 0)
/* for debugging, clean out the complete entry */ /* for debugging, clean out the complete entry */
arp_table[i].ctime = 0; arp_table[i].ctime = 0;
arp_table[i].netif = NULL; arp_table[i].netif = NULL;

View file

@ -163,8 +163,7 @@ PACK_STRUCT_END
# include "arch/epstruct.h" # include "arch/epstruct.h"
#endif #endif
//#define toupper(CH) \ #define toupper(CH) (((CH) >= 'a' && (CH) <= 'z') ? ((CH) - 'a' + 'A') : (CH))
// (((CH) >= 'a' && (CH) <= 'z') ? ((CH) - 'a' + 'A') : (CH))
/** NetBIOS decoding name */ /** NetBIOS decoding name */
@ -226,7 +225,7 @@ netbios_recv(void *arg, struct udp_pcb *upcb, struct pbuf *p, ip_addr_t *addr,
if (current_netif != NULL && current_netif->num < NET_IF_NUM) { if (current_netif != NULL && current_netif->num < NET_IF_NUM) {
uint32 ip = current_netif->ip_addr.addr; uint32 ip = current_netif->ip_addr.addr;
char *curbiosname = netbios_name[current_netif->num]; char *curbiosname = netbios_name[current_netif->num];
if (curbiosname[0] != '\0' && ip != NULL if (curbiosname[0] != '\0' && ip != 0
/* we only answer if we got a default interface */ /* we only answer if we got a default interface */
&& (((ip ^ addr->addr) & current_netif->netmask.addr) == 0)) { // запрет ответа другой подсети && (((ip ^ addr->addr) & current_netif->netmask.addr) == 0)) { // запрет ответа другой подсети
#if DEBUGSOO > 3 #if DEBUGSOO > 3

View file

@ -1,6 +1,7 @@
#ifndef __NETBIOS_H__ #ifndef __NETBIOS_H__
#define __NETBIOS_H__ #define __NETBIOS_H__
#include "autoconf.h"
#include "lwip/opt.h" #include "lwip/opt.h"
/** default port number for "NetBIOS Name service */ /** default port number for "NetBIOS Name service */
@ -9,9 +10,9 @@
/** size of a NetBIOS name */ /** size of a NetBIOS name */
#define NETBIOS_NAME_LEN 16 #define NETBIOS_NAME_LEN 16
#ifndef NET_IF_NUM //#ifndef NET_IF_NUM
#define NET_IF_NUM 2 //#define NET_IF_NUM 2
#endif //#endif
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {

View file

@ -159,7 +159,7 @@ void sntp_get_lasttime(long *sec, long *usec, unsigned int *tick)
time_t sntp_gen_system_time(int timezone) time_t sntp_gen_system_time(int timezone)
{ {
struct tm current_tm; // struct tm current_tm;
unsigned int update_tick; unsigned int update_tick;
long update_sec, update_usec, current_sec = 0; long update_sec, update_usec, current_sec = 0;

View file

@ -74,7 +74,7 @@ static int inHandlerMode (void)
#if configSignalManagementSupport // the older FreeRTOS version didn't support Signal Management functions #if configSignalManagementSupport // the older FreeRTOS version didn't support Signal Management functions
static void add_thread_signal_map (osThreadId thread_id, EventGroupHandle_t signals) static void add_thread_signal_map (osThreadId thread_id, EventGroupHandle_t signals)
{ {
int dummy; int dummy = 0;
// uint32_t i; // uint32_t i;
ThreadSignalRec *prec_entity; ThreadSignalRec *prec_entity;
@ -135,7 +135,7 @@ static EventGroupHandle_t find_signal_by_thread (osThreadId thread_id)
{ {
EventGroupHandle_t signals_hdl=NULL; EventGroupHandle_t signals_hdl=NULL;
// uint32_t i; // uint32_t i;
int dummy; int dummy = 0;
ThreadSignalRec *prec_entity; ThreadSignalRec *prec_entity;
if (inHandlerMode()) { if (inHandlerMode()) {
@ -185,7 +185,7 @@ static EventGroupHandle_t remove_thread_signal_map (osThreadId thread_id)
{ {
EventGroupHandle_t signals_hdl=NULL; EventGroupHandle_t signals_hdl=NULL;
// uint32_t i; // uint32_t i;
int dummy; int dummy = 0;
ThreadSignalRec *prec_entity; ThreadSignalRec *prec_entity;
ThreadSignalRec *pprev_entity; ThreadSignalRec *pprev_entity;
@ -989,7 +989,7 @@ osPoolId osPoolCreate (const osPoolDef_t *pool_def)
/// \note MUST REMAIN UNCHANGED: \b osPoolAlloc shall be consistent in every CMSIS-RTOS. /// \note MUST REMAIN UNCHANGED: \b osPoolAlloc shall be consistent in every CMSIS-RTOS.
void *osPoolAlloc (osPoolId pool_id) void *osPoolAlloc (osPoolId pool_id)
{ {
int dummy; int dummy = 0;
void *p = NULL; void *p = NULL;
uint32_t i; uint32_t i;
uint32_t index; uint32_t index;
@ -1047,7 +1047,7 @@ void *osPoolCAlloc (osPoolId pool_id)
/// \note MUST REMAIN UNCHANGED: \b osPoolFree shall be consistent in every CMSIS-RTOS. /// \note MUST REMAIN UNCHANGED: \b osPoolFree shall be consistent in every CMSIS-RTOS.
osStatus osPoolFree (osPoolId pool_id, void *block) osStatus osPoolFree (osPoolId pool_id, void *block)
{ {
int dummy; int dummy = 0;
uint32_t index; uint32_t index;
if (pool_id == NULL) { if (pool_id == NULL) {

View file

@ -58,6 +58,7 @@ int freertos_ready_to_sleep() {
return wakelock == 0; return wakelock == 0;
} }
extern uint32_t osKernelSysTick (void);
/* /*
* It is called when freertos is going to sleep. * It is called when freertos is going to sleep.
* At this moment, all sleep conditons are satisfied. All freertos' sleep pre-processing are done. * At this moment, all sleep conditons are satisfied. All freertos' sleep pre-processing are done.
@ -65,7 +66,7 @@ int freertos_ready_to_sleep() {
* @param expected_idle_time : The time that FreeRTOS expect to sleep. * @param expected_idle_time : The time that FreeRTOS expect to sleep.
* If we set this value to 0 then FreeRTOS will do nothing in its sleep function. * If we set this value to 0 then FreeRTOS will do nothing in its sleep function.
**/ **/
void freertos_pre_sleep_processing(unsigned int *expected_idle_time) { void freertos_pre_sleep_processing(uint32_t *expected_idle_time) {
#ifdef CONFIG_SOC_PS_MODULE #ifdef CONFIG_SOC_PS_MODULE
@ -176,7 +177,7 @@ void freertos_pre_sleep_processing(unsigned int *expected_idle_time) {
#endif #endif
} }
void freertos_post_sleep_processing(unsigned int *expected_idle_time) { void freertos_post_sleep_processing(uint32_t *expected_idle_time) {
#ifndef configSYSTICK_CLOCK_HZ #ifndef configSYSTICK_CLOCK_HZ
*expected_idle_time = 1 + ( portNVIC_SYSTICK_CURRENT_VALUE_REG / ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) ); *expected_idle_time = 1 + ( portNVIC_SYSTICK_CURRENT_VALUE_REG / ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) );
#else #else
@ -257,8 +258,12 @@ uint32_t get_wakelock_status() {
} }
#if (configGENERATE_RUN_TIME_STATS == 1) #if (configGENERATE_RUN_TIME_STATS == 1)
extern int sprintf(char* str, const char* fmt, ...);
extern size_t strlen(const char *str);
void get_wakelock_hold_stats( char *pcWriteBuffer ) { void get_wakelock_hold_stats( char *pcWriteBuffer ) {
u32 i; int i;
u32 current_timestamp = osKernelSysTick(); u32 current_timestamp = osKernelSysTick();
*pcWriteBuffer = 0x00; *pcWriteBuffer = 0x00;
@ -269,15 +274,15 @@ void get_wakelock_hold_stats( char *pcWriteBuffer ) {
for (i=0; i<32; i++) { for (i=0; i<32; i++) {
if (last_wakelock_state[i] == 1) { if (last_wakelock_state[i] == 1) {
sprintf(pcWriteBuffer, "%x\t\t%d\r\n", i, hold_wakelock_time[i] + (current_timestamp - last_acquire_wakelock_time[i])); sprintf(pcWriteBuffer, "%x\t\t%u\r\n", i, (unsigned int)( hold_wakelock_time[i] + (current_timestamp - last_acquire_wakelock_time[i])));
} else { } else {
if (hold_wakelock_time[i] > 0) { if (hold_wakelock_time[i] > 0) {
sprintf(pcWriteBuffer, "%x\t\t%d\r\n", i, hold_wakelock_time[i]); sprintf(pcWriteBuffer, "%x\t\t%u\r\n", i, (unsigned int)hold_wakelock_time[i]);
} }
} }
pcWriteBuffer += strlen( pcWriteBuffer ); pcWriteBuffer += strlen( pcWriteBuffer );
} }
sprintf(pcWriteBuffer, "time passed: %d ms, system sleep %d ms\r\n", current_timestamp - base_sys_time, sys_sleep_time); sprintf(pcWriteBuffer, "time passed: %u ms, system sleep %u ms\r\n", (unsigned int)(current_timestamp - base_sys_time), (unsigned int)sys_sleep_time);
} }
void clean_wakelock_stat() { void clean_wakelock_stat() {

View file

@ -174,7 +174,7 @@ void cli(void);
#endif #endif
#define HALT() do { cli(); for(;;);} while(0) #define HALT() do { cli(); for(;;);} while(0)
//#undef ASSERT #undef ASSERT
#define ASSERT(x) do { \ #define ASSERT(x) do { \
if((x) == 0) \ if((x) == 0) \
printf("\n\rAssert(" #x ") failed on line %d in file %s", __LINE__, __FILE__); \ printf("\n\rAssert(" #x ") failed on line %d in file %s", __LINE__, __FILE__); \

View file

@ -162,7 +162,7 @@ typedef struct HeapRegion
* terminated by a HeapRegions_t structure that has a size of 0. The region * terminated by a HeapRegions_t structure that has a size of 0. The region
* with the lowest start address must appear first in the array. * with the lowest start address must appear first in the array.
*/ */
static void vPortDefineHeapRegions( const HeapRegion_t * const pxHeapRegions ) PRIVILEGED_FUNCTION; //static void vPortDefineHeapRegions( const HeapRegion_t * const pxHeapRegions ) PRIVILEGED_FUNCTION;
/* /*

View file

@ -689,6 +689,7 @@ __attribute__(( weak )) void vPortSetupTimerInterrupt( void )
#endif /* configASSERT_DEFINED */ #endif /* configASSERT_DEFINED */
/*-----------------------------------------------------------*/ /*-----------------------------------------------------------*/
#if configUSE_IDLE_HOOK #if configUSE_IDLE_HOOK
extern void WDGRefresh(void);
void vApplicationIdleHook( void ) void vApplicationIdleHook( void )
{ {
/* Use the idle task to place the CPU into a low power mode. Greater power /* Use the idle task to place the CPU into a low power mode. Greater power

View file

@ -202,6 +202,7 @@ HeapRegion_t xHeapRegions[] =
#endif #endif
#endif #endif
static void vPortDefineHeapRegions(const HeapRegion_t * const pxHeapRegions);
/*-----------------------------------------------------------*/ /*-----------------------------------------------------------*/
/* /*
Dump xBlock list Dump xBlock list
@ -501,7 +502,7 @@ static void vPortDefineHeapRegions(const HeapRegion_t * const pxHeapRegions) {
uint8 chip_id = HalGetChipId(); uint8 chip_id = HalGetChipId();
while (pxHeapRegion->xSizeInBytes > 0) { while (pxHeapRegion->xSizeInBytes > 0) {
if (pxHeapRegion->pucStartAddress if ((uint32_t)pxHeapRegion->pucStartAddress
> 0x20000000 && chip_id >= CHIP_ID_8711AN && chip_id <= CHIP_ID_8711AF) { > 0x20000000 && chip_id >= CHIP_ID_8711AN && chip_id <= CHIP_ID_8711AF) {
// pxHeapRegion->pucStartAddress = 0; // pxHeapRegion->pucStartAddress = 0;
// pxHeapRegion->xSizeInBytes = 0; // pxHeapRegion->xSizeInBytes = 0;
@ -584,6 +585,8 @@ static void vPortDefineHeapRegions(const HeapRegion_t * const pxHeapRegions) {
} }
extern void * rtl_memcpy(void *dst0, const void *src0, size_t len0);
void* pvPortReAlloc(void *pv, size_t xWantedSize) { void* pvPortReAlloc(void *pv, size_t xWantedSize) {
BlockLink_t *pxLink; BlockLink_t *pxLink;

View file

@ -82,6 +82,7 @@ task.h is included from an application file. */
#include "task.h" #include "task.h"
#include "timers.h" #include "timers.h"
#include "StackMacros.h" #include "StackMacros.h"
#include "tcm_heap.h"
/* Lint e961 and e750 are suppressed as a MISRA exception justified because the /* Lint e961 and e750 are suppressed as a MISRA exception justified because the
MPU ports require MPU_WRAPPERS_INCLUDED_FROM_API_FILE to be defined for the MPU ports require MPU_WRAPPERS_INCLUDED_FROM_API_FILE to be defined for the

View file

@ -34,6 +34,7 @@ static void device_mutex_init(RT_DEV_LOCK_E device)
} }
//====================================================== //======================================================
#if 0 // unused-function
static void device_mutex_free(RT_DEV_LOCK_E device) static void device_mutex_free(RT_DEV_LOCK_E device)
{ {
if(DEVICE_MUTEX_IS_INIT(device)){ if(DEVICE_MUTEX_IS_INIT(device)){
@ -47,7 +48,7 @@ static void device_mutex_free(RT_DEV_LOCK_E device)
rtw_exit_critical(&lock, &irqL); rtw_exit_critical(&lock, &irqL);
} }
} }
#endif
//====================================================== //======================================================
void device_mutex_lock(RT_DEV_LOCK_E device) void device_mutex_lock(RT_DEV_LOCK_E device)
{ {

View file

@ -49,11 +49,12 @@
//#define RtlKmalloc(size, flag) pvPortMallocAligned(size, 0) //#define RtlKmalloc(size, flag) pvPortMallocAligned(size, 0)
#define RtlKmalloc(size, flag) pvPortMalloc(size) #define RtlKmalloc(size, flag) pvPortMalloc(size)
#define RtlKfree(pv) vPortFreeAligned(pv) #define RtlKfree(pv) vPortFree(pv)
#ifdef CONFIG_TIMER_MODULE #ifdef CONFIG_TIMER_MODULE
extern _LONG_CALL_ unsigned int HalDelayUs(unsigned int us);
#define __Delay(t) HalDelayUs(t) #define __Delay(t) HalDelayUs(t)
#else #else
static __inline__ u32 __Delay(u32 us) static __inline__ u32 __Delay(u32 us)
@ -66,7 +67,7 @@ static __inline__ u32 __Delay(u32 us)
#define Mdelay(t) __Delay(t*1000) #define Mdelay(t) __Delay(t*1000)
#define Udelay(t) __Delay(t) #define Udelay(t) __Delay(t)
#undef ASSERT
#define ASSERT(_bool_) do { } while (0) #define ASSERT(_bool_) do { } while (0)
//#define panic_printk DiagPrintf //#define panic_printk DiagPrintf

View file

@ -57,10 +57,9 @@ void tcm_heap_dump(void)
{ {
#if CONFIG_DEBUG_LOG > 1 #if CONFIG_DEBUG_LOG > 1
if(!g_heap_inited) tcm_heap_init(); if(!g_heap_inited) tcm_heap_init();
MemChunk *chunk, *prev; MemChunk *chunk;
struct Heap* h = &g_tcm_heap; struct Heap* h = &g_tcm_heap;
int count = 0; int count = 0;
int free_mem;
DBG_8195A("TCM Free Heap Memory List:\n"); DBG_8195A("TCM Free Heap Memory List:\n");
for (chunk = h->FreeList; chunk; chunk = chunk->next) { for (chunk = h->FreeList; chunk; chunk = chunk->next) {
@ -68,6 +67,7 @@ void tcm_heap_dump(void)
} }
/* /*
MemChunk *prev;
for (prev = (MemChunk *)&h->FreeList, chunk = h->FreeList; for (prev = (MemChunk *)&h->FreeList, chunk = h->FreeList;
chunk; chunk;
prev = chunk, chunk = chunk->next) prev = chunk, chunk = chunk->next)

View file

@ -1,6 +1,7 @@
#ifndef _BITBAND_IO_H_ #ifndef _BITBAND_IO_H_
#define _BITBAND_IO_H_ #define _BITBAND_IO_H_
#include "PinNames.h"
#include "hal_platform.h" #include "hal_platform.h"
#include "hal_api.h" #include "hal_api.h"
#include "hal_gpio.h" #include "hal_gpio.h"
@ -10,12 +11,34 @@
#define BITBAND_SRAM_BASE 0x12000000 #define BITBAND_SRAM_BASE 0x12000000
#define BITBAND_SRAM(a,b) (BITBAND_SRAM_BASE + (a-BITBAND_SRAM_REF)*32 + (b*4)) // Convert SRAM address #define BITBAND_SRAM(a,b) (BITBAND_SRAM_BASE + (a-BITBAND_SRAM_REF)*32 + (b*4)) // Convert SRAM address
#define BITBAND_ADDR(a,b) (0x02000000 + (a & 0xF0000000) + (a - (a & 0xF0000000)) * 32 + ((b) * 4)) // Convert address ? /*
* in hal_platform.h
#define BITBAND_REG_BASE 0x40001000
*/
/*
* in rtl8195a_gpio.h
*
#define BITBAND_PORTA_DR 0x00 // data register
#define BITBAND_PORTA_DDR 0x04 // data direction
#define BITBAND_PORTA_CTRL 0x08 // data source control, we should keep it as default: data source from software
#define BITBAND_PORTB_DR 0x0c // data register
#define BITBAND_PORTB_DDR 0x10 // data direction
#define BITBAND_PORTB_CTRL 0x14 // data source control, we should keep it as default: data source from software
#define BITBAND_PORTC_DR 0x18 // data register
#define BITBAND_PORTC_DDR 0x1c // data direction
#define BITBAND_PORTC_CTRL 0x20 // data source control, we should keep it as default: data source from software
#define BITBAND_EXT_PORTA 0x50 // GPIO IN read or OUT read back
#define BITBAND_EXT_PORTB 0x54 // GPIO IN read or OUT read back
#define BITBAND_EXT_PORTC 0x58 // GPIO IN read or OUT read back
*/
#define BITBAND_PERI_REF 0x40000000 #define BITBAND_PERI_REF 0x40000000
#define BITBAND_PERI_BASE 0x42000000 #define BITBAND_PERI_BASE 0x42000000
#define BITBAND_PERI(a,b) (BITBAND_PERI_BASE + (a - BITBAND_PERI_REF) * 32 + ((b) * 4)) // Convert PERI address #define BITBAND_PERI(a,b) (BITBAND_PERI_BASE + (a-BITBAND_PERI_REF)*32 + (b*4)) // Convert PERI address
#define ucBITBAND_PERI(a,b) *((volatile unsigned char *)BITBAND_PERI(a,b)) #define ucBITBAND_PERI(a,b) *((volatile unsigned char *)BITBAND_PERI(a,b))
#define uiBITBAND_PERI(a,b) *((volatile unsigned int *)BITBAND_PERI(a,b)) #define uiBITBAND_PERI(a,b) *((volatile unsigned int *)BITBAND_PERI(a,b))
@ -121,10 +144,10 @@
#define BITBAND_K5 ucBITBAND_PERI(GPIO_REG_BASE+GPIO_PORTC_DR,25) //Port = 2, bit = 25, K5 #define BITBAND_K5 ucBITBAND_PERI(GPIO_REG_BASE+GPIO_PORTC_DR,25) //Port = 2, bit = 25, K5
#define BITBAND_K6 ucBITBAND_PERI(GPIO_REG_BASE+GPIO_PORTC_DR,26) //Port = 2, bit = 26, K6 #define BITBAND_K6 ucBITBAND_PERI(GPIO_REG_BASE+GPIO_PORTC_DR,26) //Port = 2, bit = 26, K6
volatile u8 * BitBandAddr(void *addr, u8 bit); volatile uint8_t * BitBandAddr(void *addr, uint8_t bit);
volatile u8 * BitBandPeriAddr(void *addr, u8 bit); volatile uint8_t * BitBandPeriAddr(void *addr, uint8_t bit);
volatile u8 * GetOutPinBitBandAddr(PinName pin); volatile uint8_t * GetOutPinBitBandAddr(PinName pin);
volatile u8 * GetInpPinBitBandAddr(PinName pin); volatile uint8_t * GetInPinBitBandAddr(PinName pin);
volatile u8 * HardSetPin(PinName pin, PinDirection pdir, PinMode pmode, u8 val); volatile uint8_t * HardSetPin(PinName pin, HAL_GPIO_PIN_MODE pmode, uint8_t val);
#endif // _BITBAND_IO_H_ #endif // _BITBAND_IO_H_

View file

@ -74,7 +74,7 @@ typedef struct _LOG_UART_ADAPTER_ {
typedef struct _COMMAND_TABLE_ { typedef struct _COMMAND_TABLE_ {
const u8* cmd; const u8* cmd;
u16 ArgvCnt; u16 ArgvCnt;
u32 (*func)(u16 argc, u8* argv[]); void (*func)(int argc, char * argv[]); // u32 (*func)(u16 argc, u8* argv[]);
const u8* msg; const u8* msg;
} COMMAND_TABLE, *PCOMMAND_TABLE; } COMMAND_TABLE, *PCOMMAND_TABLE;

View file

@ -116,7 +116,7 @@ HAL_CUT_B_RAM_DATA_SECTION u32 rand_x = 123456789; // 10000be4
0, \ 0, \
"", \ "", \
0, \ 0, \
0x0437DC, \ (void *)0x0437DC, \
0, \ 0, \
_NULL, \ _NULL, \
_NULL, \ _NULL, \

View file

@ -257,12 +257,12 @@ LOCAL int BOOT_RAM_TEXT_SECTION SetSpicBitMode(uint8 BitMode) {
} }
void BOOT_RAM_TEXT_SECTION InitSpicFlashType(struct spic_table_flash_type *ptable_flash) { void BOOT_RAM_TEXT_SECTION InitSpicFlashType(struct spic_table_flash_type *ptable_flash) {
u8 * ptrb = &ptable_flash->cmd; uint8 * ptrb = (uint8 *)&ptable_flash->cmd;
volatile u32 * ptrreg = (volatile u32 *)(SPI_FLASH_CTRL_BASE + REG_SPIC_READ_FAST_SINGLE);// 0x400060E0 volatile uint32 * ptrreg = (volatile uint32 *)(SPI_FLASH_CTRL_BASE + REG_SPIC_READ_FAST_SINGLE);// 0x400060E0
HAL_SPI_WRITE32(REG_SPIC_SSIENR, 0); // Disable SPI_FLASH User Mode HAL_SPI_WRITE32(REG_SPIC_SSIENR, 0); // Disable SPI_FLASH User Mode
do { do {
*ptrreg++ = *ptrb++; *ptrreg++ = *ptrb++;
} while(ptrb < (u8 *)(&ptable_flash->fsize)); } while(ptrb < (uint8 *)(&ptable_flash->fsize));
ptrreg[0] = ptable_flash->contrl; ptrreg[0] = ptable_flash->contrl;
ptrreg[1] = ptable_flash->validcmd[SpicOneBitMode]; ptrreg[1] = ptable_flash->validcmd[SpicOneBitMode];
ptrreg[2] = ptable_flash->fsize; ptrreg[2] = ptable_flash->fsize;
@ -387,6 +387,7 @@ typedef enum {
SEG_ID_MAX SEG_ID_MAX
} _SEG_ID; } _SEG_ID;
#if CONFIG_DEBUG_LOG > 1
LOCAL const char * const txt_tab_seg[] = { LOCAL const char * const txt_tab_seg[] = {
"UNK", // 0 "UNK", // 0
"SRAM", // 1 "SRAM", // 1
@ -397,6 +398,7 @@ LOCAL const char * const txt_tab_seg[] = {
"CPU", // 6 "CPU", // 6
"ROM" // 7 "ROM" // 7
}; };
#endif
LOCAL const uint32 tab_seg_def[] = { 0x10000000, 0x10070000, 0x1fff0000, LOCAL const uint32 tab_seg_def[] = { 0x10000000, 0x10070000, 0x1fff0000,
0x20000000, 0x30000000, 0x30200000, 0x40000000, 0x40800000, 0x98000000, 0x20000000, 0x30000000, 0x30200000, 0x40000000, 0x40800000, 0x98000000,
@ -404,7 +406,7 @@ LOCAL const uint32 tab_seg_def[] = { 0x10000000, 0x10070000, 0x1fff0000,
LOCAL uint32 BOOT_RAM_TEXT_SECTION get_seg_id(uint32 addr, int32 size) { LOCAL uint32 BOOT_RAM_TEXT_SECTION get_seg_id(uint32 addr, int32 size) {
uint32 ret = SEG_ID_ERR; uint32 ret = SEG_ID_ERR;
uint32 * ptr = &tab_seg_def; uint32 * ptr = (uint32 *) &tab_seg_def;
if (size > 0) { if (size > 0) {
do { do {
ret++; ret++;
@ -447,7 +449,7 @@ LOCAL uint32 BOOT_RAM_TEXT_SECTION load_segs(uint32 faddr, PIMG2HEAD hdr,
segnum, faddr, txt_tab_seg[seg_id], hdr->seg.ldaddr, segnum, faddr, txt_tab_seg[seg_id], hdr->seg.ldaddr,
hdr->seg.size); hdr->seg.size);
#endif #endif
fnextaddr += flashcpy(fnextaddr, hdr->seg.ldaddr, hdr->seg.size); fnextaddr += flashcpy(fnextaddr, (void *)hdr->seg.ldaddr, hdr->seg.size);
} else if (seg_id) { } else if (seg_id) {
#if CONFIG_DEBUG_LOG > 2 #if CONFIG_DEBUG_LOG > 2
DBG_8195A("Skip Flash seg%d: 0x%08x -> %s: 0x%08x, size: %d\n", segnum, DBG_8195A("Skip Flash seg%d: 0x%08x -> %s: 0x%08x, size: %d\n", segnum,
@ -457,7 +459,7 @@ LOCAL uint32 BOOT_RAM_TEXT_SECTION load_segs(uint32 faddr, PIMG2HEAD hdr,
} else { } else {
break; break;
} }
fnextaddr += flashcpy(fnextaddr, &hdr->seg, sizeof(IMGSEGHEAD)); fnextaddr += flashcpy(fnextaddr, (void *) &hdr->seg, sizeof(IMGSEGHEAD));
segnum++; segnum++;
} }
return fnextaddr; return fnextaddr;
@ -476,7 +478,7 @@ LOCAL int BOOT_RAM_TEXT_SECTION loadUserImges(int imgnum) {
faddr = (faddr + FLASH_SECTOR_SIZE - 1) & (~(FLASH_SECTOR_SIZE - 1)); faddr = (faddr + FLASH_SECTOR_SIZE - 1) & (~(FLASH_SECTOR_SIZE - 1));
uint32 img_id = load_img2_head(faddr, &hdr); uint32 img_id = load_img2_head(faddr, &hdr);
if ((img_id >> 8) > 4 || (uint8) img_id != 0) { if ((img_id >> 8) > 4 || (uint8) img_id != 0) {
faddr = load_segs(faddr + 0x10, &hdr.seg, imagenum == imgnum); faddr = load_segs(faddr + 0x10, &hdr, imagenum == imgnum);
if (imagenum == imgnum) { if (imagenum == imgnum) {
// DBG_8195A("Image%d: %s\n", imgnum, hdr.name); // DBG_8195A("Image%d: %s\n", imgnum, hdr.name);
break; break;
@ -544,7 +546,7 @@ LOCAL void BOOT_RAM_TEXT_SECTION RtlConsolRam(void) {
pUartLogCtl->pTmpLogBuf->UARTLogBuf[0] = '?'; pUartLogCtl->pTmpLogBuf->UARTLogBuf[0] = '?';
pUartLogCtl->pTmpLogBuf->BufCount = 1; pUartLogCtl->pTmpLogBuf->BufCount = 1;
pUartLogCtl->ExecuteCmd = 1; pUartLogCtl->ExecuteCmd = 1;
RtlConsolTaskRom(pUartLogCtl); RtlConsolTaskRom((void *)pUartLogCtl);
} }
/* Enter Image 1.5 */ /* Enter Image 1.5 */

View file

@ -26,6 +26,15 @@ extern void xPortPendSVHandler(void);
extern void xPortSysTickHandler(void); extern void xPortSysTickHandler(void);
extern void vPortSVCHandler(void); extern void vPortSVCHandler(void);
extern void rtl_libc_init(void); extern void rtl_libc_init(void);
extern _LONG_CALL_ void HalCpuClkConfig(unsigned char CpuType);
extern void PSHalInitPlatformLogUart(void);
extern _LONG_CALL_ void UartLogCmdExecute(PUART_LOG_CTL pUartLogCtlExe);
extern void HalReInitPlatformTimer(void);
extern void SystemCoreClockUpdate (void);
extern void En32KCalibration(void);
extern void SdrCtrlInit(void);
extern void InitSoCPM(void);
extern u32 SdrControllerInit(void);
//extern void ShowRamBuildInfo(void); // app_start.c: VOID ShowRamBuildInfo(VOID) //extern void ShowRamBuildInfo(void); // app_start.c: VOID ShowRamBuildInfo(VOID)
//void HalNMIHandler_Patch(void); //void HalNMIHandler_Patch(void);
void SDIO_Device_Off(void); void SDIO_Device_Off(void);
@ -97,7 +106,7 @@ __weak int main(void) {
DiagPrintf("\r<RTL>"); DiagPrintf("\r<RTL>");
while (1) { while (1) {
while (pUartLogCtl->ExecuteCmd != 1); while (pUartLogCtl->ExecuteCmd != 1);
UartLogCmdExecute(pUartLogCtl); UartLogCmdExecute((PUART_LOG_CTL) pUartLogCtl);
DiagPrintf("\r<RTL>"); DiagPrintf("\r<RTL>");
pUartLogCtl->ExecuteCmd = 0; pUartLogCtl->ExecuteCmd = 0;
} }

View file

@ -245,7 +245,6 @@ HAL_Status HalSsiInitRtl8195a_Patch(VOID *Adaptor)
u32 IRQ_UNKNOWN = 999; u32 IRQ_UNKNOWN = 999;
u32 Ctrlr0Value = 0; u32 Ctrlr0Value = 0;
u32 Ctrlr1Value = 0; u32 Ctrlr1Value = 0;
u32 SerValue = 0;
u32 BaudrValue = 0; u32 BaudrValue = 0;
u32 TxftlrValue = 0; u32 TxftlrValue = 0;
u32 RxftlrValue = 0; u32 RxftlrValue = 0;
@ -318,8 +317,7 @@ HAL_Status HalSsiInitRtl8195a_Patch(VOID *Adaptor)
HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR1)); HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR1));
} }
SerValue = BIT_SER_SER(1 << (pHalSsiAdaptor->SlaveSelectEnable)); SSI_DBG_INIT("[1] Set SSI%d REG_DW_SSI_SER Value: %X\n", Index, BIT_SER_SER(1 << (pHalSsiAdaptor->SlaveSelectEnable)));
SSI_DBG_INIT("[1] Set SSI%d REG_DW_SSI_SER Value: %X\n", Index, SerValue);
//HAL_SSI_WRITE32(Index, REG_DW_SSI_SER, SerValue); //HAL_SSI_WRITE32(Index, REG_DW_SSI_SER, SerValue);
HalSsiSetSlaveEnableRegisterRtl8195a(Adaptor, pHalSsiAdaptor->SlaveSelectEnable); HalSsiSetSlaveEnableRegisterRtl8195a(Adaptor, pHalSsiAdaptor->SlaveSelectEnable);
@ -617,7 +615,6 @@ HAL_Status HalSsiSetFormatRtl8195a(VOID *Adaptor)
u32 RxftlrValue = 0; u32 RxftlrValue = 0;
u8 Index = pHalSsiAdaptor->Index; u8 Index = pHalSsiAdaptor->Index;
u8 Role = pHalSsiAdaptor->Role; u8 Role = pHalSsiAdaptor->Role;
u32 Spi_mode = 0;
if (Index > 2) { if (Index > 2) {
DBG_SSI_ERR("HalSsiSetFormatRtl8195a: Invalid SSI Idx %d\r\n", Index); DBG_SSI_ERR("HalSsiSetFormatRtl8195a: Invalid SSI Idx %d\r\n", Index);
@ -639,10 +636,9 @@ HAL_Status HalSsiSetFormatRtl8195a(VOID *Adaptor)
HAL_SSI_WRITE32(Index, REG_DW_SSI_CTRLR0, Ctrlr0Value); HAL_SSI_WRITE32(Index, REG_DW_SSI_CTRLR0, Ctrlr0Value);
Spi_mode = (HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR0) >>6) & 0x3;
SSI_DBG_INIT("[2] SSI%d REG_DW_SSI_CTRLR0(%X) = %X, SPI Mode = %X\n", Index, SSI_DBG_INIT("[2] SSI%d REG_DW_SSI_CTRLR0(%X) = %X, SPI Mode = %X\n", Index,
SSI0_REG_BASE + (SSI_REG_OFF * Index) + REG_DW_SSI_CTRLR0, SSI0_REG_BASE + (SSI_REG_OFF * Index) + REG_DW_SSI_CTRLR0,
HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR0), Spi_mode); HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR0), (HAL_SSI_READ32(Index, REG_DW_SSI_CTRLR0) >>6) & 0x3);
//The tx threshold and rx threshold value will be reset after the spi changes its role //The tx threshold and rx threshold value will be reset after the spi changes its role
/* REG_DW_SSI_TXFTLR */ /* REG_DW_SSI_TXFTLR */
TxftlrValue = BIT_TXFTLR_TFT(pHalSsiAdaptor->TxThresholdLevel); TxftlrValue = BIT_TXFTLR_TFT(pHalSsiAdaptor->TxThresholdLevel);
@ -741,7 +737,7 @@ HAL_Status HalSsiIntReadRtl8195a(VOID *Adapter, VOID *RxData, u32 Length)
{ {
PHAL_SSI_ADAPTOR pHalSsiAdapter = (PHAL_SSI_ADAPTOR) Adapter; PHAL_SSI_ADAPTOR pHalSsiAdapter = (PHAL_SSI_ADAPTOR) Adapter;
u32 RxFifoThresholdLevel; u32 RxFifoThresholdLevel;
u8 Index = pHalSsiAdapter->Index; // u8 Index = pHalSsiAdapter->Index;
DBG_SSI_INFO("HalSsiIntReadRtl8195a: Idx=%d, RxData=0x%x, Len=0x%x\r\n", Index, RxData, Length); DBG_SSI_INFO("HalSsiIntReadRtl8195a: Idx=%d, RxData=0x%x, Len=0x%x\r\n", Index, RxData, Length);
// if (HalSsiBusyRtl8195a(Adapter)) { // if (HalSsiBusyRtl8195a(Adapter)) {

View file

@ -12,13 +12,14 @@
#include "rtl8195a_uart.h" #include "rtl8195a_uart.h"
#include "hal_uart.h" #include "hal_uart.h"
#include "hal_gdma.h" #include "hal_gdma.h"
#include "strproc.h"
u8 u8
HalRuartGetChipVerRtl8195a(VOID) HalRuartGetChipVerRtl8195a(VOID)
{ {
u8 chip_ver; u8 chip_ver;
chip_ver = (HAL_READ32(SYSTEM_CTRL_BASE, 0x01F0) >> 4) & 0x0f; chip_ver = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_SYSTEM_CFG0) >> 4) & 0x0f; // 0x400001F0 RTL8710AF = 0x41000220
return chip_ver; return chip_ver;
} }
@ -151,9 +152,8 @@ HalRuartGenBaudRateRtl8195a(
u32 min_divisor=0; u32 min_divisor=0;
u32 min_err=0xffffffff; u32 min_err=0xffffffff;
u32 uart_ovsr; u32 uart_ovsr;
u32 uart_ovsr_mod; u32 min_uart_ovsr = 0; // ovsr with mini err
u32 min_uart_ovsr; // ovsr with mini err u32 min_uart_ovsr_mod = 0;
u32 min_uart_ovsr_mod;
u64 uart_clock; u64 uart_clock;
u32 divisor_temp; u32 divisor_temp;
u32 max_jitter_temp; u32 max_jitter_temp;
@ -200,7 +200,7 @@ HalRuartGenBaudRateRtl8195a(
min_uart_ovsr = uart_ovsr/100; min_uart_ovsr = uart_ovsr/100;
min_uart_ovsr_mod = uart_ovsr%100; min_uart_ovsr_mod = uart_ovsr%100;
} else if (err_temp == min_err) { } else if (err_temp == min_err) {
uart_ovsr_mod = uart_ovsr%100; u32 uart_ovsr_mod = uart_ovsr%100;
// we perfer OVSR bigger and adj bits smaller // we perfer OVSR bigger and adj bits smaller
if (((uart_ovsr/100) >= min_uart_ovsr) && (uart_ovsr_mod < min_uart_ovsr_mod)) { if (((uart_ovsr/100) >= min_uart_ovsr) && (uart_ovsr_mod < min_uart_ovsr_mod)) {
min_err = err_temp; min_err = err_temp;
@ -369,7 +369,7 @@ HalRuartSetBaudRateRtl8195a(
u8 chip_ver; u8 chip_ver;
// get chip version // get chip version
chip_ver = HalRuartGetChipVerRtl8195a(); chip_ver = HalRuartGetChipVerRtl8195a(); // RTL8710AF = 2
#endif #endif
if (pHalRuartAdapter->WordLen == RUART_WLS_8BITS) { if (pHalRuartAdapter->WordLen == RUART_WLS_8BITS) {
@ -1248,7 +1248,7 @@ HalRuartMultiBlkDmaRecvRtl8195a(
} }
/** /**
* Stop non-blocking UART RX * Stop non-blocking UART TX
* *
* *
* @return VOID * @return VOID
@ -1283,7 +1283,7 @@ HalRuartStopRecvRtl8195a_Patch(
if (NULL != pUartGdmaConfig) { if (NULL != pUartGdmaConfig) {
PHAL_GDMA_ADAPTER pHalGdmaAdapter; PHAL_GDMA_ADAPTER pHalGdmaAdapter;
PHAL_GDMA_OP pHalGdmaOp; PHAL_GDMA_OP pHalGdmaOp;
u8 IsrTypeMap;
pHalGdmaAdapter = (PHAL_GDMA_ADAPTER)pUartGdmaConfig->pRxHalGdmaAdapter; pHalGdmaAdapter = (PHAL_GDMA_ADAPTER)pUartGdmaConfig->pRxHalGdmaAdapter;
pHalGdmaOp = (PHAL_GDMA_OP)pUartGdmaConfig->pHalGdmaOp; pHalGdmaOp = (PHAL_GDMA_OP)pUartGdmaConfig->pHalGdmaOp;
@ -1293,7 +1293,8 @@ HalRuartStopRecvRtl8195a_Patch(
// Clean Auto Reload Bit // Clean Auto Reload Bit
pHalGdmaOp->HalGdmaChCleanAutoDst((VOID*)pHalGdmaAdapter); pHalGdmaOp->HalGdmaChCleanAutoDst((VOID*)pHalGdmaAdapter);
// Clear Pending ISR // Clear Pending ISR
IsrTypeMap = pHalGdmaOp->HalGdmaChIsrClean((VOID*)pHalGdmaAdapter); // u8 IsrTypeMap =
pHalGdmaOp->HalGdmaChIsrClean((VOID*)pHalGdmaAdapter);
pHalGdmaOp->HalGdmaChDis((VOID*)(pHalGdmaAdapter)); pHalGdmaOp->HalGdmaChDis((VOID*)(pHalGdmaAdapter));
DMA_Dar = HalGdmaQueryDArRtl8195a((VOID*)pHalGdmaAdapter); DMA_Dar = HalGdmaQueryDArRtl8195a((VOID*)pHalGdmaAdapter);
@ -1358,7 +1359,7 @@ HalRuartStopSendRtl8195a_Patch(
if (NULL != pUartGdmaConfig) { if (NULL != pUartGdmaConfig) {
PHAL_GDMA_ADAPTER pHalGdmaAdapter; PHAL_GDMA_ADAPTER pHalGdmaAdapter;
PHAL_GDMA_OP pHalGdmaOp; PHAL_GDMA_OP pHalGdmaOp;
u8 IsrTypeMap;
pHalGdmaAdapter = (PHAL_GDMA_ADAPTER)pUartGdmaConfig->pTxHalGdmaAdapter; pHalGdmaAdapter = (PHAL_GDMA_ADAPTER)pUartGdmaConfig->pTxHalGdmaAdapter;
pHalGdmaOp = (PHAL_GDMA_OP)pUartGdmaConfig->pHalGdmaOp; pHalGdmaOp = (PHAL_GDMA_OP)pUartGdmaConfig->pHalGdmaOp;
@ -1368,7 +1369,8 @@ HalRuartStopSendRtl8195a_Patch(
// Clean Auto Reload Bit // Clean Auto Reload Bit
pHalGdmaOp->HalGdmaChCleanAutoDst((VOID*)pHalGdmaAdapter); pHalGdmaOp->HalGdmaChCleanAutoDst((VOID*)pHalGdmaAdapter);
// Clear Pending ISR // Clear Pending ISR
IsrTypeMap = pHalGdmaOp->HalGdmaChIsrClean((VOID*)pHalGdmaAdapter); // u8 IsrTypeMap =
pHalGdmaOp->HalGdmaChIsrClean((VOID*)pHalGdmaAdapter);
pHalGdmaOp->HalGdmaChDis((VOID*)(pHalGdmaAdapter)); pHalGdmaOp->HalGdmaChDis((VOID*)(pHalGdmaAdapter));
DMA_Sar = HalGdmaQuerySArRtl8195a((VOID*)pHalGdmaAdapter); DMA_Sar = HalGdmaQuerySArRtl8195a((VOID*)pHalGdmaAdapter);

View file

@ -1,54 +1,68 @@
#include "PinNames.h"
#include "bitband_io.h" #include "bitband_io.h"
//#include "rtl8195a_gpio.h"
volatile u8 * BitBandAddr(void *addr, u8 bit) { #define BITBAND_ADDR(a,b) (0x02000000 + (a & 0xF0000000) + (a - (a & 0xF0000000)) * 32 + ((b) * 4)) // Convert address ?
return (volatile u8 *)(BITBAND_ADDR((u32)addr, bit));
volatile uint8_t * BitBandAddr(void *addr, uint8_t bit) {
uint32_t ret = BITBAND_ADDR((u32)addr, bit);
return (volatile uint8_t *) ret;
} }
volatile u8 * BitBandPeriAddr(void *addr, u8 bit) { volatile uint8_t * BitBandPeriAddr(void *addr, uint8_t bit) {
return (volatile u8 *)(BITBAND_PERI((u32)addr, bit)); return (volatile uint8_t *)(BITBAND_PERI((u32)addr, bit));
} }
volatile u8 * GetOutPinBitBandAddr(PinName pin) { volatile uint8_t * GetOutPinBitBandAddr(PinName pin) {
u32 paddr = NULL; volatile uint8_t * paddr = 0;
u32 ippin = HAL_GPIO_GetIPPinName_8195a(pin); uint32_t ippin = HAL_GPIO_GetIPPinName_8195a(pin);
if(ippin != 0xff) { if(ippin < 0xff) {
// paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4); // paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4);
paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_PORTB_DR * (ippin >> 5)), ippin & 0x1f); paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_PORTB_DR * (ippin >> 5)), ippin & 0x1f);
} }
return paddr; return paddr;
} }
volatile u8 * GetInPinBitBandAddr(PinName pin) { volatile uint8_t * GetInPinBitBandAddr(PinName pin) {
volatile u8 * paddr = NULL; volatile uint8_t * paddr = NULL;
u32 ippin = HAL_GPIO_GetIPPinName_8195a(pin); uint32_t ippin = HAL_GPIO_GetIPPinName_8195a(pin);
if(ippin != 0xff) { if(ippin < 0xff) {
// paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4); // paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4);
paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_EXT_PORTA + (ippin >> 5) * 4), ippin & 0x1f); paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_EXT_PORTA + (ippin >> 5) * 4), ippin & 0x1f);
} }
return paddr; return paddr;
} }
volatile u8 * HardSetPin(PinName pin, PinDirection pdir, PinMode pmode, u8 val) extern _LONG_CALL_ u32 GPIO_FuncOn_8195a(VOID);
extern void wait_us(int us);
volatile uint8_t * HardSetPin(PinName pin, HAL_GPIO_PIN_MODE pmode, uint8_t val)
{ {
volatile u8 *paddr = NULL; volatile uint8_t *paddr = NULL;
u32 ippin = HAL_GPIO_GetIPPinName_8195a(pin); uint32_t ippin = HAL_GPIO_GetIPPinName_8195a(pin);
if(ippin != 0xff) { if(ippin < 0xff) {
// paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4); if(_pHAL_Gpio_Adapter == NULL) {
paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_PORTB_DR * (ippin >> 5)), ippin & 0x1f); extern HAL_GPIO_ADAPTER gBoot_Gpio_Adapter;
_pHAL_Gpio_Adapter = &gBoot_Gpio_Adapter;
} }
if(paddr && _pHAL_Gpio_Adapter) {
if(_pHAL_Gpio_Adapter->Gpio_Func_En == 0) GPIO_FuncOn_8195a(); if(_pHAL_Gpio_Adapter->Gpio_Func_En == 0) GPIO_FuncOn_8195a();
paddr[0] = val; // data register wait_us(100);
paddr[(GPIO_PORTB_DDR - GPIO_PORTB_DR) * 32] = pdir; // data direction // delayMicroseconds(100);
#if 1 // if use HAL_Gpio_Adapter // paddr = 0x42000000 + (0x40001000 + 0x0c * (ippin >> 5) - 0x40000000) * 32 + ((ippin & 0x1f) * 4);
uint32 * p = &_pHAL_Gpio_Adapter->Local_Gpio_Dir[ippin >> 5]; #if CONFIG_DEBUG_LOG > 3
if(pdir) *p |= 1 << (ippin & 0x1f); GpioFunctionChk(ippin, ENABLE);
else *p &= ~(1 << (ippin & 0x1f));
#endif #endif
paddr[(GPIO_PORTB_CTRL - GPIO_PORTB_DR) * 32] = 0; // data source control, we should keep it as default: data source from software GPIO_PullCtrl_8195a(ippin, HAL_GPIO_HIGHZ); // Make the pin pull control default as High-Z
HAL_GPIO_PullCtrl_8195a(pin, pmode); // set GPIO_PULL_CTRLx paddr = BitBandPeriAddr((void *)(GPIO_REG_BASE + GPIO_PORTB_DR * (ippin >> 5)), ippin & 0x1f);
*paddr = val; // data register
HAL_GPIO_PIN gpio;
gpio.pin_name = ippin;
gpio.pin_mode = pmode;
HAL_GPIO_Init_8195a(&gpio);
*paddr = val; // data register
// paddr[(GPIO_PORTB_DDR - GPIO_PORTB_DR) * 32] = pmode == DOUT_PUSH_PULL; // data direction
// GPIO_PullCtrl_8195a(ippin, pmode); // set GPIO_PULL_CTRLx
// paddr[(GPIO_PORTB_CTRL - GPIO_PORTB_DR) * 32] = 0; // data source control, we should keep it as default: data source from software
} }
return paddr; return paddr;
} }

View file

@ -533,16 +533,16 @@ ADCISRHandle(
PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL; PSAL_ADC_MNGT_ADPT pSalADCMngtAdpt = NULL;
PHAL_ADC_INIT_DAT pHalADCInitDat = NULL; PHAL_ADC_INIT_DAT pHalADCInitDat = NULL;
PHAL_ADC_OP pHalADCOP = NULL; PHAL_ADC_OP pHalADCOP = NULL;
PSAL_ADC_USER_CB pSalADCUserCB = NULL; // PSAL_ADC_USER_CB pSalADCUserCB = NULL;
u8 ADCIrqIdx; // u8 ADCIrqIdx;
/* To get the SAL_I2C_MNGT_ADPT pointer, and parse the rest pointers */ /* To get the SAL_I2C_MNGT_ADPT pointer, and parse the rest pointers */
pSalADCHNDPriv = CONTAINER_OF(pSalADCHND, SAL_ADC_HND_PRIV, SalADCHndPriv); pSalADCHNDPriv = CONTAINER_OF(pSalADCHND, SAL_ADC_HND_PRIV, SalADCHndPriv);
pSalADCMngtAdpt = CONTAINER_OF(pSalADCHNDPriv->ppSalADCHnd, SAL_ADC_MNGT_ADPT, pSalHndPriv); pSalADCMngtAdpt = CONTAINER_OF(pSalADCHNDPriv->ppSalADCHnd, SAL_ADC_MNGT_ADPT, pSalHndPriv);
pHalADCInitDat = pSalADCMngtAdpt->pHalInitDat; pHalADCInitDat = pSalADCMngtAdpt->pHalInitDat;
pHalADCOP = pSalADCMngtAdpt->pHalOp; pHalADCOP = pSalADCMngtAdpt->pHalOp;
ADCIrqIdx = pHalADCInitDat->ADCIdx; // ADCIrqIdx = pHalADCInitDat->ADCIdx;
pSalADCUserCB = pSalADCHND->pUserCB; // pSalADCUserCB = pSalADCHND->pUserCB;
DBG_8195A_ADC_LVL(HAL_ADC_LVL,"ADC INTR STS:%x\n",pHalADCOP->HalADCReadReg(pHalADCInitDat, REG_ADC_INTR_STS)); DBG_8195A_ADC_LVL(HAL_ADC_LVL,"ADC INTR STS:%x\n",pHalADCOP->HalADCReadReg(pHalADCInitDat, REG_ADC_INTR_STS));
#else #else

View file

@ -34,7 +34,7 @@ void HalReInitPlatformTimer(void)
TimerAdapter.IrqDis = 1; TimerAdapter.IrqDis = 1;
TimerAdapter.TimerId = 1; TimerAdapter.TimerId = 1;
HalTimerOpInit_Patch(&HalTimerOp); HalTimerOpInit_Patch(&HalTimerOp);
HAL_TIMER_OP x; // HAL_TIMER_OP x;
HalTimerOp.HalTimerInit(&TimerAdapter); HalTimerOp.HalTimerInit(&TimerAdapter);
HalTimerOp.HalTimerEn(1); HalTimerOp.HalTimerEn(1);
} }

View file

@ -150,11 +150,13 @@ unsigned int rand_x = 123456789;
*/ */
#ifdef CONFIG_SDR_EN #ifdef CONFIG_SDR_EN
#ifndef __GNUC__
//#pragma arm section code = ".hal.sdrc.text" //#pragma arm section code = ".hal.sdrc.text"
#pragma arm section rodata = ".rodata.hal.sdrc" #pragma arm section rodata = ".rodata.hal.sdrc"
//, rwdata = ".hal.sdrc.data" //, rwdata = ".hal.sdrc.data"
//, zidata = ".hal.sdrc.bss" //, zidata = ".hal.sdrc.bss"
//#pragma arm section bss = ".hal.sdrc.bss" //#pragma arm section bss = ".hal.sdrc.bss"
#endif
#ifdef CONFIG_SDR_VERIFY #ifdef CONFIG_SDR_VERIFY
enum{ enum{
@ -448,13 +450,10 @@ DramInit (
u32 CrTwr, DramMaxWr, DramWr; u32 CrTwr, DramMaxWr, DramWr;
u32 CrTrtw = 0, CrTrtwT = 0; u32 CrTrtw = 0, CrTrtwT = 0;
u32 DrmaPeriod; u32 DrmaPeriod;
DRAM_TYPE DdrType; DRAM_TYPE DdrType = DRAM_SDR;
DRAM_DQ_WIDTH DqWidth; DRAM_DQ_WIDTH DqWidth;
DRAM_COLADDR_WTH Page; DRAM_COLADDR_WTH Page;
u32 DfiRate; u32 DfiRate;
volatile struct ms_rxi310_portmap *ms_ctrl_0_map;
ms_ctrl_0_map = (struct ms_rxi310_portmap*) SDR_CTRL_BASE;
// ms_ctrl_0_map = ms_ctrl_0_map;
DfiRate = 1 << (u32) (DramInfo->DfiRate); DfiRate = 1 << (u32) (DramInfo->DfiRate);
DrmaPeriod = (DramInfo->DdrPeriodPs)*(DfiRate); // according DFI_RATE to setting DrmaPeriod = (DramInfo->DdrPeriodPs)*(DfiRate); // according DFI_RATE to setting
@ -658,6 +657,9 @@ DramInit (
// enter mem_mode // enter mem_mode
HAL_SDR_WRITE32(REG_SDR_CSR,0x600); HAL_SDR_WRITE32(REG_SDR_CSR,0x600);
#else #else
volatile struct ms_rxi310_portmap *ms_ctrl_0_map;
ms_ctrl_0_map = (struct ms_rxi310_portmap*) SDR_CTRL_BASE;
// ms_ctrl_0_map = ms_ctrl_0_map;
// WRAP_MISC setting // WRAP_MISC setting
ms_ctrl_0_map->misc = //0x12; ms_ctrl_0_map->misc = //0x12;
( (
@ -753,7 +755,8 @@ SdrCalibration(
DBG_8195A("%s()\n", __func__); DBG_8195A("%s()\n", __func__);
u32 RdPipe = 0, TapCnt = 0, Pass = 0, AvaWdsCnt = 0; u32 RdPipe = 0, TapCnt = 0, Pass = 0, AvaWdsCnt = 0;
u32 RdPipeCounter, RecNum[2], RecRdPipe[2];//, AvaWds[2][REC_NUM]; u32 RdPipeCounter, RecNum[2], RecRdPipe[2];//, AvaWds[2][REC_NUM];
BOOL RdPipeFlag, PassFlag = 0, Result; BOOL RdPipeFlag, Result;
// BOOL PassFlag = 0;
u8 flashtype = 0; u8 flashtype = 0;
flashtype = SpicInitParaAllClk[0][0].flashtype; flashtype = SpicInitParaAllClk[0][0].flashtype;
@ -829,7 +832,7 @@ SdrCalibration(
#endif #endif
RdPipeFlag = _FALSE; RdPipeFlag = _FALSE;
PassFlag = _FALSE; // PassFlag = _FALSE;
AvaWdsCnt = 0; AvaWdsCnt = 0;
for(TapCnt=0; TapCnt < (MAX_TAP_DLY+1); TapCnt++) { for(TapCnt=0; TapCnt < (MAX_TAP_DLY+1); TapCnt++) {
@ -853,7 +856,7 @@ SdrCalibration(
#endif #endif
Pass = MemTest(10000); Pass = MemTest(10000);
PassFlag = _FALSE; // PassFlag = _FALSE;
if(Pass==_TRUE) { // PASS if(Pass==_TRUE) { // PASS
@ -876,7 +879,7 @@ SdrCalibration(
break; break;
} }
PassFlag = _TRUE; // PassFlag = _TRUE;
DBG_SDR_INFO("Verify Pass => RdPipe:%d; TapCnt: %d\n", RdPipe, TapCnt); DBG_SDR_INFO("Verify Pass => RdPipe:%d; TapCnt: %d\n", RdPipe, TapCnt);
@ -1044,7 +1047,7 @@ Sdr_Rand2(
} }
*/ */
extern __attribute__ ((long_call)) unsigned int Rand(void);
HAL_SDRC_TEXT_SECTION HAL_SDRC_TEXT_SECTION
s32 s32
MemTest( MemTest(

View file

@ -373,6 +373,7 @@ WakeFromSLPPG(
); );
} }
// Предел 8355 ms!
VOID VOID
DurationScaleAndPeriodOP( DurationScaleAndPeriodOP(
IN u32 SDuration, IN u32 SDuration,
@ -432,7 +433,8 @@ CLKCal(
} }
else { else {
//anack //anack
RRTemp = (((2133/Rtemp) >> x) - 1); //pvvx: eror RTL8710AF? RRTemp = (((2133/Rtemp) >> x) - 1);
RRTemp = (2133/Rtemp) - 1;
} }
if ( x == 5 ) if ( x == 5 )
DiagPrintf("Using ana to cal is not allowed!\n"); DiagPrintf("Using ana to cal is not allowed!\n");
@ -516,7 +518,7 @@ SleepClkGatted(
//3 1.5 Enable low power mode //3 1.5 Enable low power mode
// 1.5.1 0x4000_0118[2] = 1 => for sleep mode // 1.5.1 0x4000_0118[2] = 1 => for sleep mode
Rtemp = 0x00000004;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000004; Rtemp = BIT_SYSON_PM_CMD_SLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000004;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 1.6 Wait CHIP enter low power mode //3 1.6 Wait CHIP enter low power mode
@ -535,7 +537,7 @@ VOID SleepPwrGatted(
u32 Rtemp = 0; u32 Rtemp = 0;
u32 ScaleTemp = 0; u32 ScaleTemp = 0;
u32 PeriodTemp = 0; u32 PeriodTemp = 0;
u32 CalTemp = 0; // u32 CalTemp = 0;
//Backup CPU CLK //Backup CPU CLK
BackupCPUClk(); BackupCPUClk();
@ -547,7 +549,7 @@ VOID SleepPwrGatted(
//3 1.1 Set TU timer timescale //3 1.1 Set TU timer timescale
//0x4000_0090[21:16] = 6'h1F //0x4000_0090[21:16] = 6'h1F
//0x4000_0090[15] = 1'b0 => Disable timer //0x4000_0090[15] = 1'b0 => Disable timer
CalTemp = (CLKCal(ANACK) << 16); // CalTemp = (CLKCal(ANACK) << 16);
Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL) Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL)
& (~((BIT_MASK_SYS_DSTDY_TIM_SCAL << BIT_SHIFT_SYS_DSTDY_TIM_SCAL) | (BIT_MASK_SYS_ANACK_TU_TIME << BIT_SHIFT_SYS_ANACK_TU_TIME)))) & (~((BIT_MASK_SYS_DSTDY_TIM_SCAL << BIT_SHIFT_SYS_DSTDY_TIM_SCAL) | (BIT_MASK_SYS_ANACK_TU_TIME << BIT_SHIFT_SYS_ANACK_TU_TIME))))
| ScaleTemp; | ScaleTemp;
@ -580,7 +582,7 @@ VOID SleepPwrGatted(
//3 1.5 Enable low power mode //3 1.5 Enable low power mode
// 1.5.1 0x4000_0118[2] = 1 => for sleep mode // 1.5.1 0x4000_0118[2] = 1 => for sleep mode
Rtemp = 0x00000004;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000004; Rtemp = BIT_SYSON_PM_CMD_SLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000004;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 1.6 Wait CHIP enter low power mode //3 1.6 Wait CHIP enter low power mode
@ -602,7 +604,7 @@ DStandby(
u32 Rtemp = 0; u32 Rtemp = 0;
u32 ScaleTemp = 0; u32 ScaleTemp = 0;
u32 PeriodTemp = 0; u32 PeriodTemp = 0;
u32 CalTemp = 0; // u32 CalTemp = 0;
//Backup CPU CLK //Backup CPU CLK
BackupCPUClk(); BackupCPUClk();
@ -615,7 +617,7 @@ DStandby(
//3 1.1 Set TU timer timescale //3 1.1 Set TU timer timescale
//0x4000_0090[21:16] = 6'h1F //0x4000_0090[21:16] = 6'h1F
//0x4000_0090[15] = 1'b0 => Disable timer //0x4000_0090[15] = 1'b0 => Disable timer
CalTemp = (CLKCal(ANACK) << 16); // CalTemp = (CLKCal(ANACK) << 16);
Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL) Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL)
& (~((BIT_MASK_SYS_DSTDY_TIM_SCAL << BIT_SHIFT_SYS_DSTDY_TIM_SCAL) | (BIT_MASK_SYS_ANACK_TU_TIME << BIT_SHIFT_SYS_ANACK_TU_TIME)))) & (~((BIT_MASK_SYS_DSTDY_TIM_SCAL << BIT_SHIFT_SYS_DSTDY_TIM_SCAL) | (BIT_MASK_SYS_ANACK_TU_TIME << BIT_SHIFT_SYS_ANACK_TU_TIME))))
| ScaleTemp; | ScaleTemp;
@ -648,7 +650,7 @@ DStandby(
//3 1.5 Enable low power mode //3 1.5 Enable low power mode
// [0x4000_0118[1] = 1 => for deep standby mode] // [0x4000_0118[1] = 1 => for deep standby mode]
Rtemp = 0x00000002; Rtemp = BIT_SYSON_PM_CMD_DSTBY;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 1.6 Wait CHIP enter low power mode //3 1.6 Wait CHIP enter low power mode
@ -673,8 +675,6 @@ DSleep(
u32 UTemp = 0; u32 UTemp = 0;
u32 MaxTemp = 0; u32 MaxTemp = 0;
u32 Reada335 = 0;
//2 Deep Sleep mode: //2 Deep Sleep mode:
//3 2.1 Set TU timer timescale //3 2.1 Set TU timer timescale
@ -724,16 +724,15 @@ DSleep(
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CTRL, Rtemp);
HalDelayUs(1000); HalDelayUs(1000);
Reada335 = HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CAL_CTRL);
#if CONFIG_DEBUG_LOG > 3 #if CONFIG_DEBUG_LOG > 3
DiagPrintf("a33 timer : 0x%x\n", Reada335); DiagPrintf("a33 timer : 0x%x\n", HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CAL_CTRL));
#endif #endif
HalDelayUs(8000); HalDelayUs(8000);
//3 2.2.3 //3 2.2.3
//2.3 Enable low power mode: 0x4000_0118[0] = 1'b1; //2.3 Enable low power mode: 0x4000_0118[0] = 1'b1;
Rtemp = 0x00000001;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001; Rtemp = BIT_SYSON_PM_CMD_DSLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//2.4 Wait CHIP enter deep sleep mode //2.4 Wait CHIP enter deep sleep mode
@ -1418,6 +1417,9 @@ SetSYSTimer(
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL, Rtemp);
} }
/*
* SDuration < 8355 ms!
*/
VOID VOID
SleepCG( SleepCG(
IN u8 Option, IN u8 Option,
@ -1446,7 +1448,8 @@ SleepCG(
Rtemp = 0x74003B00; //0x74003900; Rtemp = 0x74003B00; //0x74003900;
} }
else { else {
Rtemp = 0x74000900; Rtemp = 0x74000900; // BIT_SYSON_PMOPT_NORM_XTAL_EN | BIT_SYSON_PMOPT_NORM_SYSPLL_EN | BIT_SYSON_PMOPT_NORM_SYSCLK_SEL | BIT_SYSON_PMOPT_NORM_EN_PWM
// | BIT_SYSON_PMOPT_SLP_LPLDO_SEL | BIT_SYSON_PMOPT_SLP_EN_SOC
} }
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp);
@ -1465,49 +1468,49 @@ SleepCG(
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_ANA_TIM_CTRL, Rtemp);
//Enable wake event //Enable wake event
WakeEvent |= BIT0; WakeEvent |= BIT0; // BIT_SYSON_WEVT_SYSTIM_MSK
} }
if (Option & SLP_GTIMER) { if (Option & SLP_GTIMER) {
//Enable wake event //Enable wake event
WakeEvent |= BIT1; WakeEvent |= BIT1; // BIT_SYSON_WEVT_GTIM_MSK
} }
if (Option & SLP_GPIO) { if (Option & SLP_GPIO) {
//Enable wake event //Enable wake event
WakeEvent |= BIT4; WakeEvent |= BIT4; // BIT_SYSON_WEVT_GPIO_MSK
} }
if (Option & SLP_WL) { if (Option & SLP_WL) {
//Enable wake event //Enable wake event
WakeEvent |= BIT8; WakeEvent |= BIT8; // BIT_SYSON_WEVT_WLAN_MSK
} }
if (Option & SLP_NFC) { if (Option & SLP_NFC) {
//Enable wake event //Enable wake event
WakeEvent |= BIT28; WakeEvent |= BIT28; // BIT_SYSON_WEVT_A33_MSK
} }
if (Option & SLP_SDIO) { if (Option & SLP_SDIO) {
//Enable wake event //Enable wake event
WakeEvent |= BIT14; WakeEvent |= BIT14; // BIT_SYSON_WEVT_SDIO_MSK
} }
if (Option & SLP_USB) { if (Option & SLP_USB) {
//Enable wake event //Enable wake event
//WakeEvent |= BIT16; //WakeEvent |= BIT16; // BIT_SYSON_WEVT_USB_MSK
} }
if (Option & SLP_TIMER33) { if (Option & SLP_TIMER33) {
//Enable wake event //Enable wake event
WakeEvent |= BIT28; WakeEvent |= BIT28; // BIT_SYSON_WEVT_A33_MSK
} }
/* /*
while(1) { while(1) {
@ -1533,7 +1536,7 @@ SleepCG(
if (SDREn) SDRSleep(); if (SDREn) SDRSleep();
#endif #endif
Rtemp = 0x00000004; Rtemp = BIT_SYSON_PM_CMD_SLP;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 Wait CHIP enter low power mode //3 Wait CHIP enter low power mode
@ -1565,7 +1568,7 @@ SleepPG(
//3 2 Configure power state option: //3 2 Configure power state option:
// 2.1 power mode option: // 2.1 power mode option:
Rtemp = 0x74000100; Rtemp = 0x74000100; // BIT_SYSON_PMOPT_SLP_LPLDO_SEL
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp);
// 2.2 sleep power mode option1 // 2.2 sleep power mode option1
@ -1648,7 +1651,7 @@ SleepPG(
LDO25M_CTRL(OFF); LDO25M_CTRL(OFF);
#endif #endif
Rtemp = 0x00000004; Rtemp = BIT_SYSON_PM_CMD_SLP;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 Wait CHIP enter low power mode //3 Wait CHIP enter low power mode
@ -1701,7 +1704,7 @@ DeepStandby(
//3 2 Configure power state option: //3 2 Configure power state option:
// 2.1 deep standby power mode option: // 2.1 deep standby power mode option:
Rtemp = 0x74000100; Rtemp = 0x74000100; // BIT_SYSON_PMOPT_SLP_LPLDO_SEL
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_OPTION, Rtemp);
// 2.2 sleep power mode option1 // 2.2 sleep power mode option1
@ -1737,19 +1740,19 @@ DeepStandby(
if (Option & DSTBY_GPIO){ if (Option & DSTBY_GPIO){
if (GpioOption & BIT0) { if (GpioOption & BIT0) { // PA_5
DSTBYGpioCtrl(BIT0, (GpioOption & BIT4)); DSTBYGpioCtrl(BIT0, (GpioOption & BIT4));
} }
if (GpioOption & BIT1) { if (GpioOption & BIT1) { // PC_7
DSTBYGpioCtrl(BIT1, (GpioOption & BIT5)); DSTBYGpioCtrl(BIT1, (GpioOption & BIT5));
} }
if (GpioOption & BIT2) { if (GpioOption & BIT2) { // PD_5
DSTBYGpioCtrl(BIT2, (GpioOption & BIT6)); DSTBYGpioCtrl(BIT2, (GpioOption & BIT6));
} }
if (GpioOption & BIT3) { if (GpioOption & BIT3) { // PE_3
DSTBYGpioCtrl(BIT3, (GpioOption & BIT7)); DSTBYGpioCtrl(BIT3, (GpioOption & BIT7));
} }
@ -1773,10 +1776,10 @@ DeepStandby(
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_GPIO_SHTDN_CTRL, 0x0); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_GPIO_SHTDN_CTRL, 0x0);
Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN) & 0xBFFFFFFF); Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN) & (~BIT_SYS_PWRON_TRAP_SHTDN_N)); // 0xBFFFFFFF, ~BIT(30)
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN, Rtemp);
Rtemp = 0x00000002; Rtemp = BIT_SYSON_PM_CMD_DSTBY;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//3 Wait CHIP enter low power mode //3 Wait CHIP enter low power mode
@ -1799,7 +1802,7 @@ DeepSleep(
u32 UTemp = 0; u32 UTemp = 0;
u32 MaxTemp = 0; u32 MaxTemp = 0;
//??? HAL_WRITE32(0x60008000, 0x80006180, PS_MASK); HAL_WRITE32(0x60008000, 0x80006180, PS_MASK);
//1.1.1 Enable REGU access interface 0x4000_0094[31] = 1 //1.1.1 Enable REGU access interface 0x4000_0094[31] = 1
Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CTRL) | 0x80000000); Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_DSLP_TIM_CTRL) | 0x80000000);
@ -1885,7 +1888,7 @@ DeepSleep(
Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN) & 0xBFFFFFFF); Rtemp = (HAL_READ32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN) & 0xBFFFFFFF);
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_FUNC_EN, Rtemp);
Rtemp = 0x00000001;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001; Rtemp = BIT_SYSON_PM_CMD_DSLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//2.4 Wait CHIP enter deep sleep mode //2.4 Wait CHIP enter deep sleep mode
@ -1916,7 +1919,7 @@ DSleep_GPIO(
//2.2.2 //2.2.2
//2.3 Enable low power mode: 0x4000_0118[0] = 1'b1; //2.3 Enable low power mode: 0x4000_0118[0] = 1'b1;
Rtemp = 0x00000001;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001; Rtemp = BIT_SYSON_PM_CMD_DSLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//2.4 Wait CHIP enter deep sleep mode //2.4 Wait CHIP enter deep sleep mode
@ -1989,7 +1992,7 @@ DSleep_Timer(
//3 2.3 //3 2.3
//2.3 Enable low power mode: 0x4000_0118[0] = 1'b1; //2.3 Enable low power mode: 0x4000_0118[0] = 1'b1;
Rtemp = 0x00000001;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001; Rtemp = BIT_SYSON_PM_CMD_DSLP;//HAL_READ32(SYSTEM_CTRL_BASE, REG_SYSON_PWRMGT_CTRL) | 0x00000001;
HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp); HAL_WRITE32(SYSTEM_CTRL_BASE, REG_SYS_PWRMGT_CTRL, Rtemp);
//2.4 Wait CHIP enter deep sleep mode //2.4 Wait CHIP enter deep sleep mode

View file

@ -527,7 +527,7 @@ HalSsiInit(VOID *Data)
{ {
HAL_Status ret; HAL_Status ret;
PHAL_SSI_ADAPTOR pHalSsiAdapter = (PHAL_SSI_ADAPTOR) Data; PHAL_SSI_ADAPTOR pHalSsiAdapter = (PHAL_SSI_ADAPTOR) Data;
u32 Function; u32 Function = SPI0;
u8 PinmuxSelect; u8 PinmuxSelect;
u8 Index; u8 Index;

View file

@ -1021,7 +1021,7 @@ HalRuartDmaSend(
u32 BlockSize; u32 BlockSize;
HAL_Status ret; HAL_Status ret;
PUART_DMA_CONFIG pUartGdmaConfig; PUART_DMA_CONFIG pUartGdmaConfig;
PHAL_GDMA_ADAPTER pHalGdmaAdapter; // PHAL_GDMA_ADAPTER pHalGdmaAdapter;
if (((Length & 0x03)==0) && if (((Length & 0x03)==0) &&
(((u32)(pTxBuf) & 0x03)==0)) { (((u32)(pTxBuf) & 0x03)==0)) {
@ -1078,7 +1078,7 @@ HalRuartDmaRecv(
// u32 BlockSize; // u32 BlockSize;
HAL_Status ret; HAL_Status ret;
PUART_DMA_CONFIG pUartGdmaConfig; PUART_DMA_CONFIG pUartGdmaConfig;
PHAL_GDMA_ADAPTER pHalGdmaAdapter; // PHAL_GDMA_ADAPTER pHalGdmaAdapter;
if (Length < 4096) { if (Length < 4096) {
#if CONFIG_CHIP_E_CUT #if CONFIG_CHIP_E_CUT

View file

@ -13,6 +13,7 @@
#include "rtl8195a.h" #include "rtl8195a.h"
#include "rtl_bios_data.h" #include "rtl_bios_data.h"
#include "osdep_api.h" #include "osdep_api.h"
#include "osdep_service.h"
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1) #if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
#include "freertos_pmu.h" #include "freertos_pmu.h"
#else #else
@ -44,7 +45,7 @@ IN u8 EchoFlag);
//_LONG_CALL_ extern void UartLogCmdExecute(IN PUART_LOG_CTL pUartLogCtlExe); //_LONG_CALL_ extern void UartLogCmdExecute(IN PUART_LOG_CTL pUartLogCtlExe);
//====================================================== //======================================================
extern PCOMMAND_TABLE UartLogRamCmdTable[]; extern PCOMMAND_TABLE UartLogRamCmdTable[];
extern UartLogRamCmdTableSize; extern int UartLogRamCmdTableSize;
//====================================================== //======================================================
//<Function>: UartLogIrqHandleRam //<Function>: UartLogIrqHandleRam
//<Usage >: To deal with Uart-Log RX IRQ //<Usage >: To deal with Uart-Log RX IRQ
@ -61,7 +62,7 @@ void UartLogIrqHandleRam(void * Data) {
if (UartReceiveData == 0) { if (UartReceiveData == 0) {
goto exit; goto exit;
} }
PUART_LOG_CTL p = pUartLogCtl; PUART_LOG_CTL p = (PUART_LOG_CTL) pUartLogCtl;
//KB_ESC chk is for cmd history, it's a special case here. //KB_ESC chk is for cmd history, it's a special case here.
if (UartReceiveData == KB_ASCII_ESC) { if (UartReceiveData == KB_ASCII_ESC) {
// Esc detection is only valid in the first stage of boot sequence (few seconds) // Esc detection is only valid in the first stage of boot sequence (few seconds)
@ -102,7 +103,7 @@ void UartLogIrqHandleRam(void * Data) {
if (p->pTmpLogBuf != NULL) { if (p->pTmpLogBuf != NULL) {
p->ExecuteCmd = _TRUE; p->ExecuteCmd = _TRUE;
if (p->TaskRdy) { if (p->TaskRdy) {
RtlUpSemaFromISR((_Sema *) &pUartLogCtl->Sema); rtw_up_sema_from_isr((_Sema *) &pUartLogCtl->Sema);
} }
} else { } else {
ArrayInitialize((u8 *) pUartLogCtl->pTmpLogBuf->UARTLogBuf, ArrayInitialize((u8 *) pUartLogCtl->pTmpLogBuf->UARTLogBuf,
@ -130,7 +131,7 @@ int GetArgvRam(IN u8 *pstr, u8** argv) {
int arvc = 0; int arvc = 0;
// u8** argv = ArgvArray; // u8** argv = ArgvArray;
u8* p = pstr; u8* p = pstr;
u8 t, n = ' '; u8 t = 0, n = ' ';
int m = 0; int m = 0;
while(*p != 0 while(*p != 0
&& *p != '\r' && *p != '\r'
@ -200,7 +201,7 @@ int GetArgvRam(IN u8 *pstr, u8** argv) {
//<Notes >: //<Notes >:
//====================================================== //======================================================
MON_RAM_TEXT_SECTION void RtlConsolTaskRam(void *Data) { MON_RAM_TEXT_SECTION void RtlConsolTaskRam(void *Data) {
PUART_LOG_CTL p = pUartLogCtl; PUART_LOG_CTL p = (PUART_LOG_CTL) pUartLogCtl;
#ifdef USE_ROM_CONSOLE // show Help #ifdef USE_ROM_CONSOLE // show Help
p->pTmpLogBuf->UARTLogBuf[0] = '?'; p->pTmpLogBuf->UARTLogBuf[0] = '?';
p->pTmpLogBuf->BufCount = 1; p->pTmpLogBuf->BufCount = 1;
@ -208,7 +209,7 @@ MON_RAM_TEXT_SECTION void RtlConsolTaskRam(void *Data) {
#endif #endif
do { do {
p->TaskRdy = _TRUE; p->TaskRdy = _TRUE;
RtlDownSema(&p->Sema); rtw_down_sema(&p->Sema);
if (p->ExecuteCmd) { if (p->ExecuteCmd) {
// UartLogCmdExecute(pUartLogCtl); // UartLogCmdExecute(pUartLogCtl);
int argc = GetArgvRam(p->pTmpLogBuf->UARTLogBuf, ArgvArray); int argc = GetArgvRam(p->pTmpLogBuf->UARTLogBuf, ArgvArray);
@ -225,9 +226,9 @@ MON_RAM_TEXT_SECTION void RtlConsolTaskRam(void *Data) {
flg = 0; flg = 0;
if(pcmd->ArgvCnt < argc) { if(pcmd->ArgvCnt < argc) {
#ifdef USE_ROM_CONSOLE #ifdef USE_ROM_CONSOLE
pcmd->func(argc-1, &ArgvArray[1]); pcmd->func(argc-1, (char **) &ArgvArray[1]);
#else #else
pcmd->func(argc, &ArgvArray); pcmd->func(argc, (char **) &ArgvArray);
#endif #endif
} else { } else {
#ifdef USE_ROM_CONSOLE #ifdef USE_ROM_CONSOLE
@ -291,7 +292,7 @@ MON_RAM_TEXT_SECTION void console_init(void) {
#endif #endif
pUartLogCtl->RevdNo = UART_LOG_HISTORY_LEN; pUartLogCtl->RevdNo = UART_LOG_HISTORY_LEN;
// Create a Semaphone // Create a Semaphone
RtlInitSema(&pUartLogCtl->Sema, 1); rtw_init_sema((_sema *)&pUartLogCtl->Sema, 1);
// executing boot sequence // executing boot sequence
pUartLogCtl->ExecuteCmd = _FALSE; pUartLogCtl->ExecuteCmd = _FALSE;
pUartLogCtl->ExecuteEsc = _TRUE; //don't check Esc anymore pUartLogCtl->ExecuteEsc = _TRUE; //don't check Esc anymore
@ -316,7 +317,7 @@ extern char str_rom_57ch3Dch0A[]; // "==========================================
_WEAK void console_help(int argc, char *argv[]) { // Help _WEAK void console_help(int argc, char *argv[]) { // Help
DiagPrintf("CONSOLE COMMAND SET:\n"); DiagPrintf("CONSOLE COMMAND SET:\n");
DiagPrintf(&str_rom_57ch3Dch0A[25]); // DiagPrintf("==============================\n"); DiagPrintf(&str_rom_57ch3Dch0A[25]); // DiagPrintf("==============================\n");
PCOMMAND_TABLE pcmdtab = UartLogRamCmdTable; PCOMMAND_TABLE pcmdtab = (PCOMMAND_TABLE) UartLogRamCmdTable;
while(pcmdtab->cmd) { while(pcmdtab->cmd) {
#ifdef USE_ROM_CONSOLE #ifdef USE_ROM_CONSOLE
DiagPrintf(pcmdtab->msg); DiagPrintf(pcmdtab->msg);
@ -327,7 +328,8 @@ _WEAK void console_help(int argc, char *argv[]) { // Help
} }
DiagPrintf(&str_rom_57ch3Dch0A[25]); // DiagPrintf("==============================\n"); DiagPrintf(&str_rom_57ch3Dch0A[25]); // DiagPrintf("==============================\n");
} }
LOCAL void print_on(int argc, char *argv[])
void print_on(int argc, char *argv[])
{ {
print_off = argv[1][0]!='1'; print_off = argv[1][0]!='1';
} }

View file

@ -105,6 +105,22 @@ extern _LONG_CALL_ double __rtl_dsub_v1_00(double a, double b);
extern _LONG_CALL_ double __rtl_dmul_v1_00(double a, double b); extern _LONG_CALL_ double __rtl_dmul_v1_00(double a, double b);
extern _LONG_CALL_ double __rtl_ddiv_v1_00(double a, double b); extern _LONG_CALL_ double __rtl_ddiv_v1_00(double a, double b);
// --- ???
extern _LONG_CALL_ float __rtl_dtof_v1_00(double d);
extern _LONG_CALL_ int __rtl_dtoui_v1_00(double d);
extern _LONG_CALL_ float __rtl_itof_v1_00(int val);
extern _LONG_CALL_ char *__rtl_ltoa_v1_00(int value, char *string, int radix);
extern _LONG_CALL_ char *__rtl_ultoa_v1_00(unsigned int value, char *string, int radix);
extern _LONG_CALL_ int __rtl_ftol_v1_00(float f);
extern _LONG_CALL_ int __rtl_ftod_v1_00(float f);
extern _LONG_CALL_ float __rtl_fadd_v1_00(float a, float b);
extern _LONG_CALL_ float __rtl_fsub_v1_00(float a, float b);
extern _LONG_CALL_ float __rtl_fmul_v1_00(float a, float b);
extern _LONG_CALL_ float __rtl_fdiv_v1_00(float a, float b);
extern _LONG_CALL_ int __rtl_dcmple_v1_00(double a, double b);
extern _LONG_CALL_ int __rtl_fcmplt_v1_00(float a, float b);
extern _LONG_CALL_ int __rtl_fcmpgt_v1_00(float a, float b);
// --- ???
// //
// mprec // mprec

View file

@ -22,7 +22,9 @@
#define strsep __rtl_strsep_v1_00 #define strsep __rtl_strsep_v1_00
#define strtok __rtl_strtok_v1_00 #define strtok __rtl_strtok_v1_00
static char toupper(char ch) { extern int isdigit (int c);
static int toupper(int ch) {
return ((ch >= 'a' && ch <= 'z') ? ch - 'a' + 'A' : ch); return ((ch >= 'a' && ch <= 'z') ? ch - 'a' + 'A' : ch);
}; };
@ -371,7 +373,7 @@ llatob(u_quad_t *vp, char *p, int base)
char * char *
btoa(char *dst, u_int value, int base) btoa(char *dst, u_int value, int base)
{ {
char buf[34], digit; char buf[34], digit = 0;
int i, j, rem, neg; int i, j, rem, neg;
if (value == 0) { if (value == 0) {
@ -417,7 +419,7 @@ btoa(char *dst, u_int value, int base)
char * char *
llbtoa(char *dst, u_quad_t value, int base) llbtoa(char *dst, u_quad_t value, int base)
{ {
char buf[66], digit; char buf[66], digit = 0;
int i, j, rem, neg; int i, j, rem, neg;
if (value == 0) { if (value == 0) {
@ -536,7 +538,7 @@ c_vsprintf (char *d, const char *s, va_list ap)
const char *t; const char *t;
char *p, *dst, tmp[40]; char *p, *dst, tmp[40];
unsigned int n; unsigned int n;
int fmt, trunc, haddot, width, base, longlong; int fmt, trunc, haddot, width, base = 0, longlong;
double dbl; double dbl;
#ifndef NEWFP #ifndef NEWFP
EP ex; EP ex;
@ -1072,11 +1074,14 @@ int c_printf(const char *fmt, ...)
#endif // ENAC_FLOAT #endif // ENAC_FLOAT
extern _LONG_CALL_ROM_ void HalSerialPutcRtl8195a(char c);
int puts (const char *s) int puts (const char *s)
{ {
while(*s) { while(*s) {
HalSerialPutcRtl8195a(*s++); HalSerialPutcRtl8195a(*s++);
} }
return 0; // -1 -> EOF
} }
void vTaskDelete(void *); void vTaskDelete(void *);

View file

@ -170,7 +170,6 @@ int rtl_vprintf(const char *fmt, va_list param) {
int rtl_vsnprintf(char *str, size_t size, const char *fmt, va_list param) { int rtl_vsnprintf(char *str, size_t size, const char *fmt, va_list param) {
int result; int result;
int w; int w;
int v11;
FILE f; FILE f;
#if CHECK_LIBC_INIT #if CHECK_LIBC_INIT
if (!libc_has_init) { if (!libc_has_init) {

View file

@ -122,6 +122,6 @@ void init_rom_libgloss_ram_map(void) {
rom_libgloss_ram_map.libgloss_open = ram_libgloss_open; rom_libgloss_ram_map.libgloss_open = ram_libgloss_open;
rom_libgloss_ram_map.libgloss_read = ram_libgloss_read; rom_libgloss_ram_map.libgloss_read = ram_libgloss_read;
rom_libgloss_ram_map.libgloss_write = ram_libgloss_write; rom_libgloss_ram_map.libgloss_write = ram_libgloss_write;
rom_libgloss_ram_map.libgloss_sbrk = ram_libgloss_sbrk; rom_libgloss_ram_map.libgloss_sbrk = (void*)ram_libgloss_sbrk;
} }

View file

@ -67,9 +67,12 @@ unsigned long long __aeabi_llsr(unsigned long long val, unsigned int shift);
extern struct _reent * _rtl_impure_ptr; extern struct _reent * _rtl_impure_ptr;
#if CHECK_LIBC_INIT
extern char libc_has_init; extern char libc_has_init;
#endif
extern char print_off; extern char print_off;
#undef snprintf
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
// Function // Function
//----- snprintf() //----- snprintf()
@ -107,7 +110,9 @@ int snprintf(char *str, size_t size, const char *fmt, ...) {
return result; return result;
} }
#ifndef ENAC_FLOAT #ifndef ENAC_FLOAT
#undef sprintf
//----- sprintf() //----- sprintf()
int sprintf(char *str, const char *fmt, ...) { int sprintf(char *str, const char *fmt, ...) {
FILE f; FILE f;
@ -131,6 +136,7 @@ int sprintf(char *str, const char *fmt, ...) {
return result; return result;
} }
#undef printf
//----- printf() //----- printf()
int printf(const char *fmt, ...) { int printf(const char *fmt, ...) {
#if CHECK_LIBC_INIT #if CHECK_LIBC_INIT
@ -151,6 +157,7 @@ int printf(const char *fmt, ...) {
else return 0; else return 0;
} }
#undef vprintf
//----- vprintf() //----- vprintf()
int vprintf(const char * fmt, __VALIST param) { int vprintf(const char * fmt, __VALIST param) {
#if CHECK_LIBC_INIT #if CHECK_LIBC_INIT
@ -165,11 +172,11 @@ int vprintf(const char * fmt, __VALIST param) {
} }
#endif // ENAC_FLOAT #endif // ENAC_FLOAT
#undef vsnprintf
//----- vsnprintf() //----- vsnprintf()
int vsnprintf(char *str, size_t size, const char *fmt, __VALIST param) { int vsnprintf(char *str, size_t size, const char *fmt, __VALIST param) {
int result; int result;
int w; int w;
int v11;
FILE f; FILE f;
#if CHECK_LIBC_INIT #if CHECK_LIBC_INIT
if (!libc_has_init) { if (!libc_has_init) {
@ -199,6 +206,7 @@ int vsnprintf(char *str, size_t size, const char *fmt, __VALIST param) {
return result; return result;
} }
#undef vfprintf
//----- vfprintf() //----- vfprintf()
int vfprintf(FILE *fp, const char *fmt0, va_list ap) { int vfprintf(FILE *fp, const char *fmt0, va_list ap) {
#if CHECK_LIBC_INIT #if CHECK_LIBC_INIT
@ -209,86 +217,103 @@ int vfprintf(FILE *fp, const char *fmt0, va_list ap) {
return __rtl_vfprintf_r_v1_00(_rtl_impure_ptr, fp, fmt0, ap); return __rtl_vfprintf_r_v1_00(_rtl_impure_ptr, fp, fmt0, ap);
} }
#undef memchr
//----- memchr() //----- memchr()
void * memchr(const void * src_void , int c , size_t length) { void * memchr(const void * src_void , int c , size_t length) {
return __rtl_memchr_v1_00(src_void, c, length); return __rtl_memchr_v1_00(src_void, c, length);
} }
#undef memcmp
//----- memcmp() //----- memcmp()
int memcmp(const void *m1, const void *m2, size_t n) { int memcmp(const void *m1, const void *m2, size_t n) {
return __rtl_memcmp_v1_00(m1, m2, n); return __rtl_memcmp_v1_00(m1, m2, n);
} }
#undef memcpy
//----- memcpy() //----- memcpy()
void * memcpy(void *dst0, const void *src0, size_t len0) { void * memcpy(void *dst0, const void *src0, size_t len0) {
return __rtl_memcpy_v1_00(dst0, src0, len0); return __rtl_memcpy_v1_00(dst0, src0, len0);
} }
#undef memmove
//----- memmove() //----- memmove()
void * memmove(void *dst_void, const void *src_void, size_t length) { void * memmove(void *dst_void, const void *src_void, size_t length) {
return __rtl_memmove_v1_00(dst_void, src_void, length); return __rtl_memmove_v1_00(dst_void, src_void, length);
} }
#undef memset
//----- memset() //----- memset()
void * memset(void *m, int c, size_t n) { void * memset(void *m, int c, size_t n) {
return __rtl_memset_v1_00(m, c, n); return __rtl_memset_v1_00(m, c, n);
} }
#undef strcat
//----- strcat() //----- strcat()
char * strcat(char *s1, const char *s2) { char * strcat(char *s1, const char *s2) {
return (char *) __rtl_strcat_v1_00(s1, s2); return (char *) __rtl_strcat_v1_00(s1, s2);
} }
#undef strchr
//----- strchr() //----- strchr()
char * strchr(const char *s1, int i) { char * strchr(const char *s1, int i) {
return (char *) __rtl_strchr_v1_00(s1, i); return (char *) __rtl_strchr_v1_00(s1, i);
} }
#undef strcmp
//----- strcmp() //----- strcmp()
int strcmp(const char *s1, const char *s2) { int strcmp(const char *s1, const char *s2) {
return __rtl_strcmp_v1_00(s1, s2); return __rtl_strcmp_v1_00(s1, s2);
} }
#undef strcpy
//----- strcpy() //----- strcpy()
char * strcpy(char *dst0, const char *src0) { char * strcpy(char *dst0, const char *src0) {
return (char *) __rtl_strcpy_v1_00(dst0, src0); return (char *) __rtl_strcpy_v1_00(dst0, src0);
} }
#undef strlen
//----- strlen() //----- strlen()
size_t strlen(const char *str) { size_t strlen(const char *str) {
return __rtl_strlen_v1_00(str); return __rtl_strlen_v1_00(str);
} }
#undef strncat
//----- strncat() //----- strncat()
char * strncat(char *s1, const char *s2, size_t n) { char * strncat(char *s1, const char *s2, size_t n) {
return (char *) __rtl_strncat_v1_00(s1, s2, n); return (char *) __rtl_strncat_v1_00(s1, s2, n);
} }
#undef strncmp
//----- strncmp() //----- strncmp()
int strncmp(const char *s1, const char *s2, size_t n) { int strncmp(const char *s1, const char *s2, size_t n) {
return __rtl_strncmp_v1_00(s1, s2, n); return __rtl_strncmp_v1_00(s1, s2, n);
} }
#undef strncpy
//----- strncpy() //----- strncpy()
char * strncpy(char *dst0, const char *src0, size_t count) { char * strncpy(char *dst0, const char *src0, size_t count) {
return (char *) __rtl_strncpy_v1_00(dst0, src0, count); return (char *) __rtl_strncpy_v1_00(dst0, src0, count);
} }
#undef strstr
//----- strstr() //----- strstr()
char * strstr(const char *searchee, const char *lookfor) { char * strstr(const char *searchee, const char *lookfor) {
return (char *) __rtl_strstr_v1_00(searchee, lookfor); return (char *) __rtl_strstr_v1_00(searchee, lookfor);
} }
#undef strsep
//----- strsep() //----- strsep()
char * strsep(char **source_ptr, const char *delim) { char * strsep(char **source_ptr, const char *delim) {
return (char *) __rtl_strsep_v1_00(source_ptr, delim); return (char *) __rtl_strsep_v1_00(source_ptr, delim);
} }
#undef strtok
//----- strtok() //----- strtok()
char * strtok(char *s, const char *delim) { char * strtok(char *s, const char *delim) {
return (char *) __rtl_strtok_v1_00(s, delim); return (char *) __rtl_strtok_v1_00(s, delim);
} }
extern _LONG_CALL_ROM_ int _vsscanf(const char *buf, const char *fmt, va_list args);
#undef sscanf
int sscanf(const char *buf, const char *fmt, ...) { int sscanf(const char *buf, const char *fmt, ...) {
va_list args; va_list args;
int i; int i;
@ -300,7 +325,7 @@ int sscanf(const char *buf, const char *fmt, ...) {
return i; return i;
} }
char toupper(char ch) { int toupper(int ch) {
return ((ch >= 'a' && ch <= 'z') ? ch - 'a' + 'A' : ch); return ((ch >= 'a' && ch <= 'z') ? ch - 'a' + 'A' : ch);
}; };
@ -366,7 +391,7 @@ void longjmp(__jmp_buf buf, long value)
extern __attribute__ ((long_call)) unsigned int Rand(void); extern __attribute__ ((long_call)) unsigned int Rand(void);
unsigned int rand(void) int rand(void)
{ {
return Rand(); return Rand();
} }
@ -534,3 +559,8 @@ int __aeabi_fcmpgt(float a, float b)
{ {
return __rtl_fcmpgt_v1_00(a, b); return __rtl_fcmpgt_v1_00(a, b);
} }
extern _LONG_CALL_ void __aeabi_memset(void *dest, size_t n, int c); // { memset(dest, c, n); }
void __aeabi_memclr(void *dest, size_t n) { __aeabi_memset(dest, n, 0); }
void __aeabi_memclr4(void *dest, size_t n) { __aeabi_memset(dest, n, 0); }

View file

@ -4,6 +4,7 @@
*/ */
#include "basic_types.h" #include "basic_types.h"
#include "rt_lib_rom.h"
//------------------------------------------------------------------------- //-------------------------------------------------------------------------
// Function declarations // Function declarations

View file

@ -20,25 +20,28 @@ float rtl_sin_f32(float a);
// int __rtl_cos_f32_v1_00(); // int __rtl_cos_f32_v1_00();
// int __rtl_sin_f32_v1_00(); // int __rtl_sin_f32_v1_00();
extern _LONG_CALL_ float __rtl_fabsf_v1_00(float a);
//----- rtl_fabsf() //----- rtl_fabsf()
float rtl_fabsf(float a) float rtl_fabsf(float a)
{ {
return __rtl_fabsf_v1_00(a); return __rtl_fabsf_v1_00(a);
} }
extern _LONG_CALL_ int __rtl_fabs_v1_00(double a);
//----- rtl_fabs() //----- rtl_fabs()
int rtl_fabs(double a) int rtl_fabs(double a)
{ {
return __rtl_fabs_v1_00(a); return __rtl_fabs_v1_00(a);
} }
extern _LONG_CALL_ float __rtl_cos_f32_v1_00(float a);
//----- rtl_cos_f32() //----- rtl_cos_f32()
float rtl_cos_f32(float a) float rtl_cos_f32(float a)
{ {
return __rtl_cos_f32_v1_00(a); return __rtl_cos_f32_v1_00(a);
} }
extern _LONG_CALL_ float __rtl_sin_f32_v1_00(float a);
//----- rtl_sin_f32() //----- rtl_sin_f32()
float rtl_sin_f32(float a) float rtl_sin_f32(float a)
{ {

View file

@ -19,9 +19,11 @@
# FLAGS # FLAGS
# ------------------------------------------------------------------- # -------------------------------------------------------------------
CFLAGS = -DM3 -DCONFIG_PLATFORM_8195A -DGCC_ARMCM3 -DARDUINO_SDK -DF_CPU=166666666L -DNDEBUG CFLAGS = -DM3 -DCONFIG_PLATFORM_8195A -DGCC_ARMCM3 -DARDUINO_SDK -DF_CPU=166666666L -DNDEBUG
CFLAGS += -mcpu=cortex-m3 -mthumb -g2 -Os -std=gnu99 -Wall -Werror CFLAGS += -mcpu=cortex-m3 -mthumb -g2 -Os -std=gnu99
CFLAGS += -fno-common -fmessage-length=0 -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-short-enums -fsigned-char CFLAGS += -fno-common -fmessage-length=0 -ffunction-sections -fdata-sections -fomit-frame-pointer -fno-short-enums -fsigned-char
CFLAGS += -w -Wno-pointer-sign CFLAGS += -Wall -Werror
CFLAGS += -Wno-old-style-declaration -Wno-pointer-sign -Wno-strict-aliasing
CFLAGS += -Wno-variadic-macros -Wno-empty-body
ifdef USE_GCC_LIB ifdef USE_GCC_LIB
LFLAGS = -mcpu=cortex-m3 -mthumb -g -Os -nostartfiles --specs=nano.specs LFLAGS = -mcpu=cortex-m3 -mthumb -g -Os -nostartfiles --specs=nano.specs
else else
@ -39,6 +41,10 @@ else
all: LIBS +=_platform_new _wlan _p2p _wps _websocket _sdcard _xmodem _mdns all: LIBS +=_platform_new _wlan _p2p _wps _websocket _sdcard _xmodem _mdns
mp: LIBS +=_platform_new _wlan_mp _wps _p2p _websocket _sdcard _xmodem _mdns mp: LIBS +=_platform_new _wlan_mp _wps _p2p _websocket _sdcard _xmodem _mdns
endif endif
ifdef USE_UVC
all: LIBS +=_rtsp _usbh
mp: LIBS +=_rtsp _usbh
endif
# m c nosys gcc # m c nosys gcc
PATHLIBS = sdk/component/soc/realtek/8195a/misc/bsp/lib/common/gcc PATHLIBS = sdk/component/soc/realtek/8195a/misc/bsp/lib/common/gcc
LDFILE = rlx8195A-symbol-v04-img2.ld LDFILE = rlx8195A-symbol-v04-img2.ld
@ -81,11 +87,14 @@ INCLUDES += sdk/component/common/drivers/wlan/realtek/src/hal/OUTSRC
INCLUDES += sdk/component/common/drivers/sdio/realtek/sdio_host/inc INCLUDES += sdk/component/common/drivers/sdio/realtek/sdio_host/inc
INCLUDES += sdk/component/soc/realtek/8195a/fwlib/ram_lib/wlan/realtek/wlan_ram_map/rom INCLUDES += sdk/component/soc/realtek/8195a/fwlib/ram_lib/wlan/realtek/wlan_ram_map/rom
INCLUDES += sdk/component/common/network/ssl/ssl_ram_map/rom INCLUDES += sdk/component/common/network/ssl/ssl_ram_map/rom
#INCLUDES += sdk/component/common/media/codec ifdef USE_UVC
#INCLUDES += sdk/component/common/drivers/usb_class/host/uvc/inc INCLUDES += sdk/component/common/media/codec
#INCLUDES += sdk/component/common/drivers/usb_class/device INCLUDES += sdk/component/common/video/v4l2/inc
#INCLUDES += sdk/component/common/drivers/usb_class/device/class INCLUDES += sdk/component/common/drivers/usb_class/host/uvc/inc
#INCLUDES += sdk/component/soc/realtek/8195a/fwlib/ram_lib/usb_otg/include INCLUDES += sdk/component/common/drivers/usb_class/device
INCLUDES += sdk/component/common/drivers/usb_class/device/class
INCLUDES += sdk/component/soc/realtek/8195a/fwlib/ram_lib/usb_otg/include
endif
# Source file list # Source file list
# ------------------------------------------------------------------- # -------------------------------------------------------------------

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.

File diff suppressed because it is too large Load diff

View file

@ -85,18 +85,14 @@ extern uint32_t SystemCoreClock;
* See http://www.freertos.org/a00110.html. * See http://www.freertos.org/a00110.html.
*----------------------------------------------------------*/ *----------------------------------------------------------*/
#define configUSE_STACK_TCM_HEAP 1 // RTL871xAx/RTL8195Ax Stack priority used TCM HEAP #define configUSE_STACK_TCM_HEAP 5 // RTL871xAx/RTL8195Ax Stack priority used TCM HEAP
#define configUSE_PREEMPTION 1 #define configUSE_PREEMPTION 1
#define configUSE_IDLE_HOOK 1 #define configUSE_IDLE_HOOK 1
#define configUSE_TICK_HOOK 0 #define configUSE_TICK_HOOK 0
#define configCPU_CLOCK_HZ ( SystemCoreClock ) #define configCPU_CLOCK_HZ ( SystemCoreClock )
#define configTICK_RATE_HZ ( ( uint32_t ) 1000 ) #define configTICK_RATE_HZ ( ( uint32_t ) 1000 )
#define configMINIMAL_STACK_SIZE ( ( unsigned short ) 70 ) #define configMINIMAL_STACK_SIZE ( ( unsigned short ) 70 )
#ifdef CONFIG_UVC
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 110 * 1024 ) ) // use HEAP5
#else
#define configTOTAL_HEAP_SIZE ( ( size_t ) ( 90 * 1024 ) ) // use HEAP5 #define configTOTAL_HEAP_SIZE ( ( size_t ) ( 90 * 1024 ) ) // use HEAP5
#endif
#define configMAX_TASK_NAME_LEN ( 10 ) #define configMAX_TASK_NAME_LEN ( 10 )
#define configUSE_TRACE_FACILITY 0 #define configUSE_TRACE_FACILITY 0
#define configUSE_16_BIT_TICKS 0 #define configUSE_16_BIT_TICKS 0
@ -112,10 +108,11 @@ extern uint32_t SystemCoreClock;
#define configUSE_COUNTING_SEMAPHORES 1 #define configUSE_COUNTING_SEMAPHORES 1
#define configUSE_ALTERNATIVE_API 0 #define configUSE_ALTERNATIVE_API 0
#define configCHECK_FOR_STACK_OVERFLOW 2 #define configCHECK_FOR_STACK_OVERFLOW 0
#define configUSE_RECURSIVE_MUTEXES 1 #define configUSE_RECURSIVE_MUTEXES 1
#define configQUEUE_REGISTRY_SIZE 0 #define configQUEUE_REGISTRY_SIZE 0
#define configGENERATE_RUN_TIME_STATS 1 #define configGENERATE_RUN_TIME_STATS 1
#if configGENERATE_RUN_TIME_STATS #if configGENERATE_RUN_TIME_STATS
#define configUSE_STATS_FORMATTING_FUNCTIONS 1 #define configUSE_STATS_FORMATTING_FUNCTIONS 1
#define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() //( ulHighFrequencyTimerTicks = 0UL ) #define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() //( ulHighFrequencyTimerTicks = 0UL )
@ -137,8 +134,8 @@ extern uint32_t SystemCoreClock;
#if (__IASMARM__ != 1) #if (__IASMARM__ != 1)
extern void freertos_pre_sleep_processing(unsigned int *expected_idle_time); extern void freertos_pre_sleep_processing(uint32_t *expected_idle_time);
extern void freertos_post_sleep_processing(unsigned int *expected_idle_time); extern void freertos_post_sleep_processing(uint32_t *expected_idle_time);
extern int freertos_ready_to_sleep(); extern int freertos_ready_to_sleep();
/* Enable tickless power saving. */ /* Enable tickless power saving. */
@ -210,4 +207,6 @@ See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
//#define RTK_MODE_TIMER //#define RTK_MODE_TIMER
#define INCLUDE_uxTaskGetStackHighWaterMark 1
#endif /* FREERTOS_CONFIG_H */ #endif /* FREERTOS_CONFIG_H */

View file

@ -8,8 +8,8 @@
#ifndef _INC_FEEP_CONFIG_H_ #ifndef _INC_FEEP_CONFIG_H_
#define _INC_FEEP_CONFIG_H_ #define _INC_FEEP_CONFIG_H_
#define FEEP_ID_WIFI_CFG 0x5730 // id:'0W', type: struct wlan_fast_reconnect //#define FEEP_ID_WIFI_CFG 0x5730 // id:'0W', type: struct wlan_fast_reconnect
#define FEEP_ID_WIFI_AP_CFG 0x5731 // id:'1W', type: struct rtw_wifi_config_t //#define FEEP_ID_WIFI_AP_CFG 0x5731 // id:'1W', type: struct rtw_wifi_config_t
#define FEEP_ID_UART_CFG 0x5530 // id:'0U', type: UART_LOG_CONF #define FEEP_ID_UART_CFG 0x5530 // id:'0U', type: UART_LOG_CONF
#define FEEP_ID_LWIP_CFG 0x4C30 // id:'0L', type: struct atcmd_lwip_conf #define FEEP_ID_LWIP_CFG 0x4C30 // id:'0L', type: struct atcmd_lwip_conf
#define FEEP_ID_DHCP_CFG 0x4430 // id:'0D', type: struct #define FEEP_ID_DHCP_CFG 0x4430 // id:'0D', type: struct

View file

@ -167,6 +167,7 @@ a lot of data that needs to be copied, this should be set high. */
* LWIP_AUTOIP==1: Enable AUTOIP module. * LWIP_AUTOIP==1: Enable AUTOIP module.
*/ */
#define LWIP_AUTOIP 0 //Realtek modified (0->1) #define LWIP_AUTOIP 0 //Realtek modified (0->1)
/* ---------- DHCP options ---------- */ /* ---------- DHCP options ---------- */
/* Define LWIP_DHCP to 1 if you want DHCP configuration of /* Define LWIP_DHCP to 1 if you want DHCP configuration of
interfaces. DHCP is not implemented in lwIP 0.5.1, however, so interfaces. DHCP is not implemented in lwIP 0.5.1, however, so
@ -184,6 +185,7 @@ a lot of data that needs to be copied, this should be set high. */
/* Support Multicast */ /* Support Multicast */
#define LWIP_IGMP 1 #define LWIP_IGMP 1
extern __attribute__ ((long_call)) unsigned int Rand(void); extern __attribute__ ((long_call)) unsigned int Rand(void);
#define LWIP_RAND() Rand() #define LWIP_RAND() Rand()

View file

@ -8,7 +8,9 @@
/* #undef EXPERIMENTAL */ /* #undef EXPERIMENTAL */
/* Define to disable debugging assertions. */ /* Define to disable debugging assertions. */
#ifndef NDEBUG
#define NDEBUG #define NDEBUG
#endif
/* Define to optimize for accuracy over speed. */ /* Define to optimize for accuracy over speed. */
/* #undef OPT_ACCURACY */ /* #undef OPT_ACCURACY */

View file

@ -718,7 +718,7 @@ struct mad_stream {
enum mad_error error; /* error code (see above) */ enum mad_error error; /* error code (see above) */
}; };
enum { enum _MAD_OPTION{
MAD_OPTION_IGNORECRC = 0x0001, /* ignore CRC errors */ MAD_OPTION_IGNORECRC = 0x0001, /* ignore CRC errors */
MAD_OPTION_HALFSAMPLERATE = 0x0002 /* generate PCM at 1/2 sample rate */ MAD_OPTION_HALFSAMPLERATE = 0x0002 /* generate PCM at 1/2 sample rate */
# if 0 /* not yet implemented */ # if 0 /* not yet implemented */

View file

@ -83,7 +83,7 @@ struct mad_stream {
enum mad_error error; /* error code (see above) */ enum mad_error error; /* error code (see above) */
}; };
enum { enum e_MAD_OPTION_{
MAD_OPTION_IGNORECRC = 0x0001, /* ignore CRC errors */ MAD_OPTION_IGNORECRC = 0x0001, /* ignore CRC errors */
MAD_OPTION_HALFSAMPLERATE = 0x0002 /* generate PCM at 1/2 sample rate */ MAD_OPTION_HALFSAMPLERATE = 0x0002 /* generate PCM at 1/2 sample rate */
# if 0 /* not yet implemented */ # if 0 /* not yet implemented */

View file

@ -1,5 +1,5 @@
/* /*
* * Automatically generated by make menuconfig: don't edit
*/ */
#define AUTOCONF_INCLUDED #define AUTOCONF_INCLUDED
@ -12,10 +12,11 @@
/* /*
* Target Platform Selection * Target Platform Selection
*/ */
#define CONFIG_WITHOUT_MONITOR 1
#define CONFIG_USE_TCM_HEAP 1 #define CONFIG_USE_TCM_HEAP 1
#define configUSE_STACK_TCM_HEAP 5 // min priority use tcm ? #define configUSE_STACK_TCM_HEAP 5 // min priority use tcm ?
#define CONFIG_WITHOUT_MONITOR 1
#undef CONFIG_RTL8195A #undef CONFIG_RTL8195A
#define CONFIG_RTL8195A 1 #define CONFIG_RTL8195A 1
#undef CONFIG_FPGA #undef CONFIG_FPGA
@ -134,8 +135,8 @@
#define CONFIG_CRYPTO_NORMAL 1 #define CONFIG_CRYPTO_NORMAL 1
#undef CONFIG_CRYPTO_TEST #undef CONFIG_CRYPTO_TEST
#define CONFIG_CRYPTO_MODULE 1 #define CONFIG_CRYPTO_MODULE 1
#define CONFIG_CRYPTO_STARTUP 0 #define CONFIG_CRYPTO_STARTUP 1
#define CONFIG_MII_EN 1 #define CONFIG_MII_EN 0 //1
#define CONFIG_PWM_EN 1 #define CONFIG_PWM_EN 1
#define CONFIG_PWM_NORMAL 1 #define CONFIG_PWM_NORMAL 1
#undef CONFIG_PWM_TEST #undef CONFIG_PWM_TEST
@ -155,7 +156,7 @@
#undef CONFIG_SPIC_TEST #undef CONFIG_SPIC_TEST
#define CONFIG_SPIC_MODULE 1 #define CONFIG_SPIC_MODULE 1
#define CONFIG_ADC_EN 1 #define CONFIG_ADC_EN 1
//#define CONFIG_DAC_EN 1 #define CONFIG_DAC_EN 1
#define CONFIG_NOR_FLASH 1 #define CONFIG_NOR_FLASH 1
#undef CONFIG_SPI_FLASH #undef CONFIG_SPI_FLASH
#undef CONFIG_NAND_FLASH #undef CONFIG_NAND_FLASH

View file

@ -8,7 +8,7 @@
#define __PLATFORM_OPTS_H__ #define __PLATFORM_OPTS_H__
/*For MP mode setting*/ /*For MP mode setting*/
#define SUPPORT_MP_MODE 1 #define SUPPORT_MP_MODE 0
/** /**
* For AT cmd Log service configurations * For AT cmd Log service configurations
@ -39,7 +39,7 @@
* For FreeRTOS tickless configurations * For FreeRTOS tickless configurations
*/ */
#define FREERTOS_PMU_TICKLESS_PLL_RESERVED 0 // In sleep mode, 0: close PLL clock, 1: reserve PLL clock #define FREERTOS_PMU_TICKLESS_PLL_RESERVED 0 // In sleep mode, 0: close PLL clock, 1: reserve PLL clock
#define FREERTOS_PMU_TICKLESS_SUSPEND_SDRAM 1 // In sleep mode, 1: suspend SDRAM, 0: no act #define FREERTOS_PMU_TICKLESS_SUSPEND_SDRAM 0 // In sleep mode, 1: suspend SDRAM, 0: no act
/******************************************************************************/ /******************************************************************************/
@ -53,6 +53,7 @@
/** /**
* For Wlan configurations * For Wlan configurations
*/ */
#define CONFIG_WLAN 1 #define CONFIG_WLAN 1
#if CONFIG_WLAN #if CONFIG_WLAN
#define CONFIG_LWIP_LAYER 1 #define CONFIG_LWIP_LAYER 1
@ -86,7 +87,7 @@
#endif #endif
/* For Simple Link */ /* For Simple Link */
#define CONFIG_INCLUDE_SIMPLE_CONFIG 1 #define CONFIG_INCLUDE_SIMPLE_CONFIG 0
/*For wowlan service settings*/ /*For wowlan service settings*/
#define CONFIG_WOWLAN_SERVICE 0 #define CONFIG_WOWLAN_SERVICE 0
@ -157,4 +158,15 @@
#define USE_FLASH_EEP 1 #define USE_FLASH_EEP 1
#define CONFIG_WLAN_CONNECT_CB 1 #define CONFIG_WLAN_CONNECT_CB 1
//#define CONFIG_FATFS_EN 1 // FatFs & SD
#ifdef CONFIG_FATFS_EN
// fatfs version
#define FATFS_R_10C
// fatfs disk interface
#define FATFS_DISK_USB 0
#define FATFS_DISK_SD 1
#undef CONFIG_SDIO_HOST_EN
#define CONFIG_SDIO_HOST_EN 1
#endif #endif
#endif //__PLATFORM_OPTS_H__

View file

@ -1,114 +0,0 @@
/*
*
*
*/
#ifndef _INCLUDE_ESP_COMP_H_
#define _INCLUDE_ESP_COMP_H_
#include "platform_autoconf.h"
#define ICACHE_FLASH_ATTR
#define ICACHE_RODATA_ATTR
#define DATA_IRAM_ATTR
#define os_printf(...) rtl_printf(__VA_ARGS__)
#define os_printf_plus(...) rtl_printf(__VA_ARGS__)
#define os_sprintf_fd(...) rtl_sprintf(__VA_ARGS__)
#define ets_sprintf(...) rtl_sprintf(__VA_ARGS__)
/*
#define os_malloc pvPortMalloc
#define os_zalloc pvPortZalloc
#define os_calloc pvPortCalloc
#define os_realloc pvPortRealloc
*/
#undef os_free
#define os_free vPortFree
#define system_get_free_heap_size xPortGetFreeHeapSize
#undef os_realloc
#define os_realloc pvPortReAlloc
#define os_bzero rtl_bzero
#define os_delay_us wait_us // HalDelayUs
//#define os_install_putc1 rtl_install_putc1
//#define os_install_putc2 rtl_install_putc2
//#define os_intr_lock rtl_intr_lock
//#define os_intr_unlock rtl_intr_unlock
//#define os_isr_attach rtl_isr_attach
//#define os_isr_mask rtl_isr_mask
//#define os_isr_unmask rtl_isr_unmask
#define os_memcmp rtl_memcmp
#define os_memcpy rtl_memcpy
#define ets_memcpy rtl_memcpy
#define os_memmove rtl_memmove
#define os_memset rtl_memset
#define os_putc rtl_putc
//#define os_str2macaddr rtl_str2macaddr
//#define os_strcat strcat
#define os_strchr rtl_strchr
#define os_strrchr rtl_strrchr
#define os_strcmp rtl_strcmp
#define os_strcpy rtl_strcpy
#define os_strlen rtl_strlen
#define os_strncmp rtl_strncmp
#define os_strncpy rtl_strncpy
#define os_strstr rtl_strstr
#define os_random Rand
//extern uint32 phy_get_rand(void);
#define system_get_os_print() 1
#ifdef USE_US_TIMER
#define os_timer_arm_us(a, b, c) rtl_timer_arm_new(a, b, c)
#endif
//#define os_timer_arm(a, b, c) rtl_timer_arm_new(a, b, c)
//#define os_timer_disarm rtl_timer_disarm
//#define os_timer_init rtl_timer_init
//#define os_timer_setfn rtl_timer_setfn
//#define os_timer_done rtl_timer_done
//#define os_timer_handler_isr rtl_timer_handler_isr
//#define os_update_cpu_frequency rtl_update_cpu_frequency
//#define os_sprintf ets_sprintf
#define spi_flash_real_size() (1<<(flashobj.SpicInitPara.id[2]-1))
#define ip4_addr1(ipaddr) (((u8_t*)(ipaddr))[0])
#define ip4_addr2(ipaddr) (((u8_t*)(ipaddr))[1])
#define ip4_addr3(ipaddr) (((u8_t*)(ipaddr))[2])
#define ip4_addr4(ipaddr) (((u8_t*)(ipaddr))[3])
/* These are cast to u16_t, with the intent that they are often arguments
* to printf using the U16_F format from cc.h. */
#define ip4_addr1_16(ipaddr) ((u16_t)ip4_addr1(ipaddr))
#define ip4_addr2_16(ipaddr) ((u16_t)ip4_addr2(ipaddr))
#define ip4_addr3_16(ipaddr) ((u16_t)ip4_addr3(ipaddr))
#define ip4_addr4_16(ipaddr) ((u16_t)ip4_addr4(ipaddr))
#define IP2STR(ipaddr) ip4_addr1_16(ipaddr), \
ip4_addr2_16(ipaddr), \
ip4_addr3_16(ipaddr), \
ip4_addr4_16(ipaddr)
#define IPSTR "%d.%d.%d.%d"
/* CONFIG_DEBUG_LOG:
=0 Off all diag/debug msg,
=1 Only errors,
=2 errors + warning, (default)
=3 errors + warning + info,
=4 errors + warning + info + debug,
=5 full */
#if CONFIG_DEBUG_LOG > 3
#define DEBUGSOO (CONFIG_DEBUG_LOG - 1)
#elif CONFIG_DEBUG_LOG > 1
#define DEBUGSOO 2
#else
#define DEBUGSOO CONFIG_DEBUG_LOG
#endif
#endif // _INCLUDE_ESP_COMP_H_

View file

@ -5,9 +5,9 @@
#ifndef _INC_RTL_LIBC_ #ifndef _INC_RTL_LIBC_
#define _INC_RTL_LIBC_ #define _INC_RTL_LIBC_
//#undef malloc #undef malloc
#define malloc(size) pvPortMalloc(size) #define malloc(size) pvPortMalloc(size)
//#undef free #undef free
#define free(pbuf) vPortFree(pbuf) #define free(pbuf) vPortFree(pbuf)
#define atoi(str) prvAtoi(str) #define atoi(str) prvAtoi(str)

View file

@ -15,7 +15,7 @@
#define DEF_WIFI_COUNTRY RTW_COUNTRY_RU // Регион использования WiFi... #define DEF_WIFI_COUNTRY RTW_COUNTRY_RU // Регион использования WiFi...
#define DEF_WIFI_TX_PWR RTW_TX_PWR_PERCENTAGE_25 // RTW_TX_PWR_PERCENTAGE_75 // RTW_TX_PWR_PERCENTAGE_100 #define DEF_WIFI_TX_PWR RTW_TX_PWR_PERCENTAGE_25 // RTW_TX_PWR_PERCENTAGE_75 // RTW_TX_PWR_PERCENTAGE_100
#define DEF_WIFI_BGN RTW_NETWORK_BGN // rtw_network_mode_t #define DEF_WIFI_BGN RTW_NETWORK_BGN // rtw_network_mode_t
#define DEF_WIFI_ADAPTIVITY RTW_ADAPTIVITY_NORMAL // RTW_ADAPTIVITY_DISABLE/RTW_ADAPTIVITY_NORMAL/RTW_ADAPTIVITY_CARRIER_SENSE #define DEF_WIFI_ADAPTIVITY RTW_ADAPTIVITY_DISABLE // RTW_ADAPTIVITY_NORMAL // RTW_ADAPTIVITY_DISABLE/RTW_ADAPTIVITY_NORMAL/RTW_ADAPTIVITY_CARRIER_SENSE
/* Опции загрузки конфигов по старту */ /* Опции загрузки конфигов по старту */
//#define DEF_LOAD_CFG 0 // старт в назначенном режиме по умолчанию //#define DEF_LOAD_CFG 0 // старт в назначенном режиме по умолчанию
@ -33,7 +33,7 @@
RTW_SECURITY_WPA_TKIP_PSK - WPA Security RTW_SECURITY_WPA_TKIP_PSK - WPA Security
RTW_SECURITY_WPA2_AES_PSK - WPA2 Security using AES cipher RTW_SECURITY_WPA2_AES_PSK - WPA2 Security using AES cipher
RTW_SECURITY_WPA2_MIXED_PSK - WPA2 Security using AES and/or TKIP ciphers */ RTW_SECURITY_WPA2_MIXED_PSK - WPA2 Security using AES and/or TKIP ciphers */
#define DEF_AP_SECURITY RTW_SECURITY_WPA2_AES_PSK // WEP security is NOT IMPLEMENTED. It is NOT SECURE! #define DEF_AP_SECURITY RTW_ENCRYPTION_WPA2_MIXED // WEP security is NOT IMPLEMENTED. It is NOT SECURE!
#define DEF_AP_BEACON 100 // 100...6000 ms #define DEF_AP_BEACON 100 // 100...6000 ms
#define DEF_AP_CHANNEL 1 // 1..14 #define DEF_AP_CHANNEL 1 // 1..14
#define DEF_AP_CHANNEL 1 // 1..14 #define DEF_AP_CHANNEL 1 // 1..14
@ -47,7 +47,7 @@
//==== Interface 1 - wlan1 = STA ========== //==== Interface 1 - wlan1 = STA ==========
#define DEF_ST_SSID "HOMEAP" // Имя SSID AP (роутера) для присоединения по умолчанию (первый старт) #define DEF_ST_SSID "HOMEAP" // Имя SSID AP (роутера) для присоединения по умолчанию (первый старт)
#define DEF_ST_PASSWORD "0123456789" // Пароль AP (роутера) для присоединения по умолчанию (первый старт) #define DEF_ST_PASSWORD "0123456789" // Пароль AP (роутера) для присоединения по умолчанию (первый старт)
#define DEF_ST_SECURITY RTW_SECURITY_WPA_WPA2_MIXED // Тип Security #define DEF_ST_SECURITY RTW_ENCRYPTION_WPA2_MIXED // Тип Security
#define DEF_ST_BSSID { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } // If bssid set is not ff.ff.ff.ff.ff.ff, #define DEF_ST_BSSID { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } // If bssid set is not ff.ff.ff.ff.ff.ff,
#define DEF_ST_USE_BSSID 0 // station will connect to the router with both ssid[] and bssid[] matched. #define DEF_ST_USE_BSSID 0 // station will connect to the router with both ssid[] and bssid[] matched.
#define DEF_ST_CHANNEL 1 // 1..14 #define DEF_ST_CHANNEL 1 // 1..14

View file

@ -32,6 +32,8 @@ speed.
#include "osdep_api.h" #include "osdep_api.h"
#include "i2s_api.h" #include "i2s_api.h"
#include "driver/i2s_freertos.h" #include "driver/i2s_freertos.h"
#include "rtl_lib.h"
#include "rtl8195a/rtl_libc.h"
#define USE_RTL_I2S_API 0 // speed #define USE_RTL_I2S_API 0 // speed
@ -103,7 +105,7 @@ int i2sInit(int mask, int bufsize, int word_len) { // word_len = WL_16b or WL_24
DBG_8195A("I2S%d: Not heap buffer %d bytes!\n", i, sizeof(i2s_t) + page_size * I2S_DMA_PAGE_NUM); DBG_8195A("I2S%d: Not heap buffer %d bytes!\n", i, sizeof(i2s_t) + page_size * I2S_DMA_PAGE_NUM);
return 0; return 0;
} }
rtl_memset(pi2s_new, 0, sizeof(i2s_t)); memset(pi2s_new, 0, sizeof(i2s_t));
u8 * i2s_tx_buf = (u8 *) pvPortMalloc(page_size * I2S_DMA_PAGE_NUM); u8 * i2s_tx_buf = (u8 *) pvPortMalloc(page_size * I2S_DMA_PAGE_NUM);
if (i2s_tx_buf == NULL) { if (i2s_tx_buf == NULL) {
vPortFree(pi2s_new); vPortFree(pi2s_new);
@ -135,12 +137,13 @@ int i2sInit(int mask, int bufsize, int word_len) { // word_len = WL_16b or WL_24
else i2s_init(pi2s_obj, I2S1_SCLK_PIN, I2S1_WS_PIN, I2S1_SD_PIN); else i2s_init(pi2s_obj, I2S1_SCLK_PIN, I2S1_WS_PIN, I2S1_SD_PIN);
i2s_set_param(pi2s_obj, pi2s_obj->channel_num, pi2s_obj->sampling_rate, pi2s_obj->word_length); i2s_set_param(pi2s_obj, pi2s_obj->channel_num, pi2s_obj->sampling_rate, pi2s_obj->word_length);
i2s_set_dma_buffer(pi2s_obj, i2s_tx_buf, NULL, I2S_DMA_PAGE_NUM, page_size); i2s_set_dma_buffer(pi2s_obj, i2s_tx_buf, NULL, I2S_DMA_PAGE_NUM, page_size);
i2s_tx_irq_handler(pi2s_obj, i2s_test_tx_complete, (uint32_t)pi2s_obj); i2s_tx_irq_handler(pi2s_obj, (i2s_irq_handler)i2s_test_tx_complete, (uint32_t)pi2s_obj);
// i2s_rx_irq_handler(pi2s_obj, (i == 0)? (i2s_irq_handler)i2s1_test_rx_complete : (i2s_irq_handler)i2s2_test_rx_complete, i); // TX only! // i2s_rx_irq_handler(pi2s_obj, (i == 0)? (i2s_irq_handler)i2s1_test_rx_complete : (i2s_irq_handler)i2s2_test_rx_complete, i); // TX only!
i2s_enable(pi2s_obj); i2s_enable(pi2s_obj);
DBG_8195A("I2S%d: Alloc DMA buf %d bytes (%d x %d samples %d bits)\n", i, page_size * I2S_DMA_PAGE_NUM, I2S_DMA_PAGE_NUM, bufsize, (word_len == WL_16b)? 32 : 96); DBG_8195A("I2S%d: Alloc DMA buf %d bytes (%d x %d samples %d bits)\n", i, page_size * I2S_DMA_PAGE_NUM, I2S_DMA_PAGE_NUM, bufsize, (word_len == WL_16b)? 32 : 96);
} }
} }
return 1;
} }
//Set the I2S sample rate, in HZ //Set the I2S sample rate, in HZ
@ -265,6 +268,7 @@ u32 i2sPushPWMSamples(u32 sample) {
} }
} }
portEXIT_CRITICAL(); portEXIT_CRITICAL();
return sample;
} }
#endif #endif

View file

@ -582,6 +582,7 @@ void synth_full(struct mad_synth *, struct mad_frame const *,
* NAME: synth->full() * NAME: synth->full()
* DESCRIPTION: perform full frequency PCM synthesis * DESCRIPTION: perform full frequency PCM synthesis
*/ */
extern void render_sample_block(short int *short_sample_buff, int no_samples);
static static
void synth_full(struct mad_synth *synth, struct mad_frame const *frame, void synth_full(struct mad_synth *synth, struct mad_frame const *frame,
unsigned int nch, unsigned int ns) unsigned int nch, unsigned int ns)
@ -608,7 +609,7 @@ void synth_full(struct mad_synth *synth, struct mad_frame const *frame,
for (ch = 0; ch < nch; ++ch) for (ch = 0; ch < nch; ++ch)
{ {
sbsample = &frame->sbsample[ch]; sbsample = (void *)&frame->sbsample[ch];
filter = &synth->filter[ch]; filter = &synth->filter[ch];
pcm1 = short_sample_buff[ch]; pcm1 = short_sample_buff[ch];
@ -732,7 +733,7 @@ void synth_full(struct mad_synth *synth, struct mad_frame const *frame,
/* Render di un blocco */ /* Render di un blocco */
if(nch < 2) memcpy(short_sample_buff[1], short_sample_buff[0], sizeof(short_sample_buff[0])); if(nch < 2) memcpy(short_sample_buff[1], short_sample_buff[0], sizeof(short_sample_buff[0]));
render_sample_block(short_sample_buff, sizeof(short_sample_buff[0])/sizeof(short int)); render_sample_block((short int *) short_sample_buff, sizeof(short_sample_buff[0])/sizeof(short int));
phase = (phase + 1) % 16; phase = (phase + 1) % 16;
@ -745,11 +746,12 @@ void synth_full(struct mad_synth *synth, struct mad_frame const *frame,
* DESCRIPTION: perform half frequency PCM synthesis * DESCRIPTION: perform half frequency PCM synthesis
*/ */
static static
void synth_half(struct mad_synth *synth, struct mad_frame const *frame, void synth_half(struct mad_synth *synth, struct mad_frame *frame,
unsigned int nch, unsigned int ns) unsigned int nch, unsigned int ns)
{ {
unsigned int phase, ch, s, sb, pe, po; unsigned int phase, ch, s, sb, pe, po;
short int *pcm1, *pcm1v, *pcm2v; // short int *pcm1;
short int *pcm1v, *pcm2v;
mad_fixed_t (*filter)[2][2][16][8]; mad_fixed_t (*filter)[2][2][16][8];
mad_fixed_t (*sbsample)[36][32]; mad_fixed_t (*sbsample)[36][32];
register mad_fixed_t (*fe)[8], (*fx)[8], (*fo)[8]; register mad_fixed_t (*fe)[8], (*fx)[8], (*fo)[8];
@ -772,7 +774,8 @@ void synth_half(struct mad_synth *synth, struct mad_frame const *frame,
{ {
sbsample = &frame->sbsample[ch]; sbsample = &frame->sbsample[ch];
filter = &synth->filter[ch]; filter = &synth->filter[ch];
pcm1 = pcm1v = short_sample_buff; // pcm1 =
pcm1v = (short int *)short_sample_buff;
dct32((*sbsample)[s], phase >> 1, dct32((*sbsample)[s], phase >> 1,
(*filter)[0][phase & 1], (*filter)[1][phase & 1]); (*filter)[0][phase & 1], (*filter)[1][phase & 1]);
@ -894,14 +897,15 @@ void synth_half(struct mad_synth *synth, struct mad_frame const *frame,
/* Render di un blocco */ /* Render di un blocco */
if(nch < 2) memcpy(short_sample_buff[1], short_sample_buff[0], sizeof(short_sample_buff[0])); if(nch < 2) memcpy(short_sample_buff[1], short_sample_buff[0], sizeof(short_sample_buff[0]));
render_sample_block(short_sample_buff, sizeof(short_sample_buff[0])/sizeof(short int)); render_sample_block((short int *)short_sample_buff, sizeof(short_sample_buff[0])/sizeof(short int));
pcm1 = pcm1v + 8; // pcm1 = pcm1v + 8;
phase = (phase + 1) % 16; phase = (phase + 1) % 16;
} /* for di blocco */ } /* for di blocco */
} }
extern void set_dac_sample_rate(int rate, int chls);
/* /*
* NAME: synth->frame() * NAME: synth->frame()
* DESCRIPTION: perform PCM synthesis of frame subband samples * DESCRIPTION: perform PCM synthesis of frame subband samples
@ -925,7 +929,7 @@ void mad_synth_frame(struct mad_synth *synth, struct mad_frame const *frame)
if (frame->options & MAD_OPTION_HALFSAMPLERATE) { if (frame->options & MAD_OPTION_HALFSAMPLERATE) {
synth->pcm.samplerate /= 2; synth->pcm.samplerate /= 2;
synth->pcm.length /= 2; synth->pcm.length /= 2;
synth_frame = synth_half; synth_frame = (void *)synth_half;
} }
set_dac_sample_rate(synth->pcm.samplerate, nch); set_dac_sample_rate(synth->pcm.samplerate, nch);

View file

@ -41,7 +41,7 @@ LOCAL void fATST(int argc, char *argv[]) {
#if 0 //CONFIG_DEBUG_LOG > 1 #if 0 //CONFIG_DEBUG_LOG > 1
dump_mem_block_list(); dump_mem_block_list();
tcm_heap_dump(); tcm_heap_dump();
#endif; #endif
printf("\n"); printf("\n");
#if (configGENERATE_RUN_TIME_STATS == 1) #if (configGENERATE_RUN_TIME_STATS == 1)
char *cBuffer = pvPortMalloc(512); char *cBuffer = pvPortMalloc(512);
@ -132,7 +132,7 @@ void dump_bytes(uint32 addr, int size)
while (size) { while (size) {
if (symbs_line > size) symbs_line = size; if (symbs_line > size) symbs_line = size;
printf("%08X ", addr); printf("%08X ", addr);
copy_align4_to_align1(buf, addr, symbs_line); copy_align4_to_align1(buf, (void *)addr, symbs_line);
print_hex_dump(buf, symbs_line, ' '); print_hex_dump(buf, symbs_line, ' ');
int i; int i;
for(i = 0 ; i < symbs_line ; i++) { for(i = 0 ; i < symbs_line ; i++) {
@ -151,6 +151,7 @@ void dump_bytes(uint32 addr, int size)
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
// Dump byte register // Dump byte register
//------------------------------------------------------------------------------ //------------------------------------------------------------------------------
extern _LONG_CALL_ u32 Strtoul(IN const u8 *nptr, IN u8 **endptr, IN u32 base);
LOCAL void fATSB(int argc, char *argv[]) LOCAL void fATSB(int argc, char *argv[])
{ {
int size = 16; int size = 16;

View file

@ -3,13 +3,16 @@
* FileName: user_main.c * FileName: user_main.c
* *
*******************************************************************************/ *******************************************************************************/
#include "platform_autoconf.h"
#include "autoconf.h"
#include "rtl8195a/rtl_common.h" #include "rtl8195a/rtl_common.h"
#include "rtl8195a.h" #include "rtl8195a.h"
#include "hal_log_uart.h" #include "hal_log_uart.h"
#include "FreeRTOS.h" #include "FreeRTOS.h"
#include "task.h" #include "task.h"
//#include "diag.h" #include "diag.h"
#include "osdep_service.h" #include "osdep_service.h"
#include "device_lock.h" #include "device_lock.h"
#include "semphr.h" #include "semphr.h"
@ -33,6 +36,7 @@
#include "user/playerconfig.h" #include "user/playerconfig.h"
#include "user/atcmd_user.h" #include "user/atcmd_user.h"
#include "main.h" #include "main.h"
#include "flash_eep.h"
#include "wifi_api.h" #include "wifi_api.h"
#include "rtl8195a/rtl_libc.h" #include "rtl8195a/rtl_libc.h"
@ -88,7 +92,7 @@ LOCAL int mp3_cfg_read(void)
// Called by the NXP modifications of libmad. It passes us (for the mono synth) // Called by the NXP modifications of libmad. It passes us (for the mono synth)
// 32 16-bit samples. // 32 16-bit samples.
void render_sample_block(short *short_sample_buff, int no_samples) { void render_sample_block(short int *short_sample_buff, int no_samples) {
int i; int i;
for (i = 0; i < no_samples; i++) { for (i = 0; i < no_samples; i++) {
int x = oversampling; int x = oversampling;
@ -122,6 +126,8 @@ void set_dac_sample_rate(int rate, int chls) {
oversampling = i2sSetRate(-1, rate); oversampling = i2sSetRate(-1, rate);
} }
extern int RamFifoLen(void);
static enum mad_flow input(struct mad_stream *stream) { static enum mad_flow input(struct mad_stream *stream) {
int n, i; int n, i;
int rem; //, fifoLen; int rem; //, fifoLen;
@ -203,9 +209,9 @@ LOCAL void tskmad(void *pvParameters) {
sizeof(struct mad_stream) + sizeof(struct mad_frame) + sizeof(struct mad_synth) + READBUFSZ, sizeof(struct mad_stream) + sizeof(struct mad_frame) + sizeof(struct mad_synth) + READBUFSZ,
mad_bufs); mad_bufs);
#endif #endif
struct mad_stream *stream = mad_bufs; struct mad_stream *stream = (struct mad_stream *)mad_bufs;
struct mad_frame *frame = &mad_bufs[sizeof(struct mad_stream)]; struct mad_frame *frame = (struct mad_frame *) &mad_bufs[sizeof(struct mad_stream)];
struct mad_synth *synth = &mad_bufs[sizeof(struct mad_stream) struct mad_synth *synth = (struct mad_synth *) &mad_bufs[sizeof(struct mad_stream)
+ sizeof(struct mad_frame)]; + sizeof(struct mad_frame)];
readBuf = &mad_bufs[sizeof(struct mad_stream) + sizeof(struct mad_frame) readBuf = &mad_bufs[sizeof(struct mad_stream) + sizeof(struct mad_frame)
+ sizeof(struct mad_synth)]; + sizeof(struct mad_synth)];
@ -374,6 +380,8 @@ LOCAL int http_head_read(unsigned char *buf, int len, int ff) {
return ret; return ret;
} }
extern void RamFifoClose(void);
//Reader task. This will try to read data from a TCP socket into the SPI fifo buffer. //Reader task. This will try to read data from a TCP socket into the SPI fifo buffer.
LOCAL void tskreader(void *pvParameters) { LOCAL void tskreader(void *pvParameters) {
char wbuf[SOCK_READ_BUF]; char wbuf[SOCK_READ_BUF];
@ -503,6 +511,8 @@ void connect_start(void) {
#endif #endif
} }
extern int tcm_heap_freeSpace(void);
extern void console_init(void);
/* RAM/TCM/Heaps info */ /* RAM/TCM/Heaps info */
void ShowMemInfo(void) void ShowMemInfo(void)
{ {
@ -525,13 +535,15 @@ LOCAL void user_init_thrd(void) {
vTaskDelete(NULL); vTaskDelete(NULL);
} }
extern void WDGStart(void);
extern int rtl_cryptoEngine_init(void);
/** /**
* @brief Main program. * @brief Main program.
* @param None * @param None
* @retval None * @retval None
*/ */
void main(void) int main(void)
{ {
#if DEBUG_MAIN_LEVEL > 3 #if DEBUG_MAIN_LEVEL > 3
ConfigDebugErr = -1; ConfigDebugErr = -1;
@ -560,7 +572,7 @@ void main(void)
#endif #endif
/* wlan & user_start intialization */ /* wlan & user_start intialization */
xTaskCreate(user_init_thrd, "user_init", 1024, NULL, tskIDLE_PRIORITY + 0 + PRIORITIE_OFFSET, NULL); xTaskCreate((TaskFunction_t) user_init_thrd, "user_init", 1024, NULL, tskIDLE_PRIORITY + 0 + PRIORITIE_OFFSET, NULL);
/*Enable Schedule, Start Kernel*/ /*Enable Schedule, Start Kernel*/
#if defined(CONFIG_KERNEL) && !TASK_SCHEDULER_DISABLED #if defined(CONFIG_KERNEL) && !TASK_SCHEDULER_DISABLED
@ -600,7 +612,7 @@ LOCAL void fATWS(int argc, char *argv[]){
} }
else if(argv[1][0] == 'S') { // strcmp(argv[1], "save") == 0 else if(argv[1][0] == 'S') { // strcmp(argv[1], "save") == 0
printf("%s: %s,%d\n", argv[0], mp3_serv.url, mp3_serv.port); printf("%s: %s,%d\n", argv[0], mp3_serv.url, mp3_serv.port);
if(flash_write_cfg(&mp3_serv, ID_FEEP_MP3, strlen(mp3_serv.port) + strlen(mp3_serv.url))) if(flash_write_cfg(&mp3_serv, ID_FEEP_MP3, sizeof(mp3_serv.port) + strlen((const char *)mp3_serv.url)))
printf("ATWS: saved\n", mp3_serv.url, mp3_serv.port); printf("ATWS: saved\n", mp3_serv.url, mp3_serv.port);
return; return;
} }

View file

@ -7,16 +7,22 @@
#include <autoconf.h> #include <autoconf.h>
#include "FreeRTOS.h" #include "FreeRTOS.h"
#include "freertos_pmu.h"
#include "diag.h" #include "diag.h"
#include "wifi_api.h"
#include "wifi_conf.h"
#include "rtl8195a/rtl_libc.h"
#include "hal_platform.h" #include "hal_platform.h"
#include "freertos_pmu.h"
#include "section_config.h" #include "section_config.h"
#include "hal_diag.h" #include "hal_diag.h"
#include "lwip/netif.h" #include "lwip/netif.h"
#include "wifi_api.h"
#include "wifi_conf.h"
#include "rtl8195a/rtl_libc.h"
#if CONFIG_WLAN_CONNECT_CB
extern void connect_close(void);
extern void connect_start(void);
#endif
extern struct netif xnetif[NET_IF_NUM]; extern struct netif xnetif[NET_IF_NUM];
@ -71,6 +77,7 @@ LOCAL void fATPN(int argc, char *argv[]){
else wifi_st_cfg.reconnect_pause = 5; else wifi_st_cfg.reconnect_pause = 5;
show_wifi_st_cfg(); show_wifi_st_cfg();
#if CONFIG_WLAN_CONNECT_CB #if CONFIG_WLAN_CONNECT_CB
extern void connect_close(void);
connect_close(); connect_close();
#endif #endif
wifi_run(wifi_run_mode | RTW_MODE_STA); wifi_run(wifi_run_mode | RTW_MODE_STA);
@ -143,11 +150,13 @@ LOCAL void fATWR(int argc, char *argv[]){
#if CONFIG_WLAN_CONNECT_CB #if CONFIG_WLAN_CONNECT_CB
// Close connections // Close connections
LOCAL void fATOF(int argc, char *argv[]){ LOCAL void fATOF(int argc, char *argv[]){
(void)argc; (void)argv;
connect_close(); connect_close();
} }
// Open connections // Open connections
LOCAL void fATON(int argc, char *argv[]){ LOCAL void fATON(int argc, char *argv[]){
(void)argc; (void)argv;
connect_start(); connect_start();
} }
#endif #endif
@ -168,6 +177,8 @@ LOCAL void fATWI(int argc, char *argv[]) {
wifi_cfg.mode = atoi(argv[2]); wifi_cfg.mode = atoi(argv[2]);
} }
} }
#else
(void)argc; (void)argv;
#endif #endif
rtw_wifi_setting_t Setting; rtw_wifi_setting_t Setting;
if((wifi_run_mode & RTW_MODE_AP) if((wifi_run_mode & RTW_MODE_AP)
@ -191,12 +202,19 @@ LOCAL void fATWI(int argc, char *argv[]) {
printf("\nWIFI ST config:\n"); printf("\nWIFI ST config:\n");
printf(&str_rom_57ch3Dch0A[25]); // "================================\n" printf(&str_rom_57ch3Dch0A[25]); // "================================\n"
show_wifi_st_cfg(); show_wifi_st_cfg();
printf("\nWIFI AP clients:\n");
printf(&str_rom_57ch3Dch0A[25]); // "================================\n"
#if SDK_VER_NUM >= 0x4000
show_wifi_ap_clients();
#endif
printf("\n"); printf("\n");
} }
extern uint8_t rtw_power_percentage_idx; extern uint8_t rtw_power_percentage_idx;
extern int rltk_set_tx_power_percentage(rtw_tx_pwr_percentage_t power_percentage_idx);
LOCAL void fATWT(int argc, char *argv[]) { void fATWT(int argc, char *argv[]) {
(void) argc; (void) argv;
if(argc > 1) { if(argc > 1) {
int txpwr = atoi(argv[1]); int txpwr = atoi(argv[1]);
debug_printf("set tx power (%d)...\n", txpwr); debug_printf("set tx power (%d)...\n", txpwr);
@ -209,7 +227,10 @@ LOCAL void fATWT(int argc, char *argv[]) {
//-- Test tsf (64-bits counts, 1 us step) --- //-- Test tsf (64-bits counts, 1 us step) ---
#include "hal_com_reg.h" //#include "hal_com_reg.h"
#define WIFI_REG_BASE 0x40080000
#define REG_TSFTR 0x0560
#define REG_TSFTR1 0x0568 // HW Port 1 TSF Register
#define ReadTSF_Lo32() (*((volatile unsigned int *)(WIFI_REG_BASE + REG_TSFTR))) #define ReadTSF_Lo32() (*((volatile unsigned int *)(WIFI_REG_BASE + REG_TSFTR)))
#define ReadTSF_Hi32() (*((volatile unsigned int *)(WIFI_REG_BASE + REG_TSFTR1))) #define ReadTSF_Hi32() (*((volatile unsigned int *)(WIFI_REG_BASE + REG_TSFTR1)))
@ -219,13 +240,15 @@ LOCAL uint64_t get_tsf(void)
return *((uint64_t *)(WIFI_REG_BASE + REG_TSFTR)); return *((uint64_t *)(WIFI_REG_BASE + REG_TSFTR));
} }
LOCAL void fATSF(int argc, char *argv[]) void fATSF(int argc, char *argv[])
{ {
(void) argc; (void) argv;
uint64_t tsf = get_tsf(); uint64_t tsf = get_tsf();
printf("\nTSF: %08x%08x\n", (uint32_t)(tsf>>32), (uint32_t)(tsf)); printf("\nTSF: %08x%08x\n", (uint32_t)(tsf>>32), (uint32_t)(tsf));
} }
LOCAL void fATWP(int argc, char *argv[]) { void fATWP(int argc, char *argv[]) {
(void) argc; (void) argv;
int x = 0; int x = 0;
if(argc > 1) { if(argc > 1) {
x = atoi(argv[1]); x = atoi(argv[1]);
@ -244,9 +267,8 @@ LOCAL void fATWP(int argc, char *argv[]) {
printf("DTIM: %d\n", _wext_get_lps_dtim(0)); printf("DTIM: %d\n", _wext_get_lps_dtim(0));
} }
} }
/* -------- WiFi Scan ------------------------------- */ /* -------- WiFi Scan ------------------------------- */
LOCAL void scan_result_handler(internal_scan_handler_t* ap_scan_result) LOCAL rtw_result_t scan_result_handler(internal_scan_handler_t* ap_scan_result)
{ {
if (ap_scan_result) { if (ap_scan_result) {
if(ap_scan_result->scan_cnt) { if(ap_scan_result->scan_cnt) {
@ -268,15 +290,16 @@ LOCAL void scan_result_handler(internal_scan_handler_t* ap_scan_result)
record->SSID.val[record->SSID.len] = '\0'; record->SSID.val[record->SSID.len] = '\0';
printf("%s\n", record->SSID.val); printf("%s\n", record->SSID.val);
} }
} }
} else { } else {
printf("Scan networks: None!\n"); printf("Scan networks: None!\n");
} }
return RTW_SUCCESS;
} }
/* -------- WiFi Scan ------------------------------- */ /* -------- WiFi Scan ------------------------------- */
LOCAL void fATSN(int argc, char *argv[]) void fATSN(int argc, char *argv[])
{ {
(void) argc; (void) argv;
api_wifi_scan(scan_result_handler); api_wifi_scan(scan_result_handler);
} }
@ -315,7 +338,7 @@ MON_RAM_TAB_SECTION COMMAND_TABLE console_cmd_wifi_api[] = {
{"P2P_DISCCONNECT", 0, cmd_p2p_disconnect, ": p2p disconnect"}, {"P2P_DISCCONNECT", 0, cmd_p2p_disconnect, ": p2p disconnect"},
{"P2P_CONNECT", 0, cmd_p2p_connect, ": p2p connect"}, {"P2P_CONNECT", 0, cmd_p2p_connect, ": p2p connect"},
#endif #endif
{"ATWR", 0, fATWR, ": WIFI Connect, Disconnect"}, {"ATWR", 0, fATWR, "=[mode]: WIFI Mode: 0 - off, 1 - ST, 2 - AP, 3 - ST+AP"},
#if CONFIG_WLAN_CONNECT_CB #if CONFIG_WLAN_CONNECT_CB
{"ATON", 0, fATON, ": Open connections"}, {"ATON", 0, fATON, ": Open connections"},
{"ATOFF", 0, fATOF, ": Close connections"}, {"ATOFF", 0, fATOF, ": Close connections"},
@ -323,7 +346,7 @@ MON_RAM_TAB_SECTION COMMAND_TABLE console_cmd_wifi_api[] = {
{"ATWI", 0, fATWI, ": WiFi Info"}, {"ATWI", 0, fATWI, ": WiFi Info"},
#if CONFIG_DEBUG_LOG > 3 #if CONFIG_DEBUG_LOG > 3
{"ATWT", 1, fATWT, "=<tx_power>: WiFi tx power: 0 - 100%, 1 - 75%, 2 - 50%, 3 - 25%, 4 - 12.5%"}, {"ATWT", 1, fATWT, "=<tx_power>: WiFi tx power: 0 - 100%, 1 - 75%, 2 - 50%, 3 - 25%, 4 - 12.5%"},
{"ATSF", 0, fATSF, ": Test TSF value"}, {"ATSF", 0, fATSF, ": Get TSF value"},
#endif #endif
// {"ATWP", 0, fATWP, "=[dtim]: 0 - WiFi ipc/lpc off, 1..10 - on + dtim"}, // {"ATWP", 0, fATWP, "=[dtim]: 0 - WiFi ipc/lpc off, 1..10 - on + dtim"},
{"ATSN", 0, fATSN, ": Scan networks"} {"ATSN", 0, fATSN, ": Scan networks"}

View file

@ -1,8 +1,8 @@
#============================================= #=============================================
# User defined # User defined
#============================================= #=============================================
#SDK_PATH ?= ../RTL00_WEB/USDK/ #SDK_PATH = ../RTL00_WEB/USDK/
SDK_PATH ?= RTL00_SDKV35a/ SDK_PATH = RTL00_SDKV35a/
#GCC_PATH = d:/MCU/GNU_Tools_ARM_Embedded/6.2017-q1-update/bin/# + or set in PATH #GCC_PATH = d:/MCU/GNU_Tools_ARM_Embedded/6.2017-q1-update/bin/# + or set in PATH
#GCC_PATH = d:/MCU/GNU_Tools_ARM_Embedded/5.2_2015q4/bin/# + or set in PATH #GCC_PATH = d:/MCU/GNU_Tools_ARM_Embedded/5.2_2015q4/bin/# + or set in PATH
#OPENOCD_PATH = d:/MCU/OpenOCD/bin/# + or set in PATH #OPENOCD_PATH = d:/MCU/OpenOCD/bin/# + or set in PATH