mirror of
https://github.com/pvvx/RTL00MP3.git
synced 2025-01-26 11:05:18 +00:00
update -Wall -Werror
This commit is contained in:
parent
2c29a376ba
commit
7cb9553f73
102 changed files with 3686 additions and 3504 deletions
|
@ -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>
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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__)
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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()
|
||||||
|
|
|
@ -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");
|
||||||
|
|
|
@ -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, ðernetif_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, ðernetif_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, ðernetif_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, ðernetif_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
|
||||||
|
|
|
@ -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_
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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");
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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};
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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()) {
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -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(¤t_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(¤t_iphdr_src, inp)) ||
|
{ if ((ip_addr_isbroadcast(¤t_iphdr_src, inp)) ||
|
||||||
(ip_addr_ismulticast(¤t_iphdr_src))) {
|
(ip_addr_ismulticast(¤t_iphdr_src))) {
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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" {
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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() {
|
||||||
|
|
|
@ -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__); \
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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_
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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, \
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -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)) {
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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(
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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';
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 *);
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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); }
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "basic_types.h"
|
#include "basic_types.h"
|
||||||
|
#include "rt_lib_rom.h"
|
||||||
|
|
||||||
//-------------------------------------------------------------------------
|
//-------------------------------------------------------------------------
|
||||||
// Function declarations
|
// Function declarations
|
||||||
|
|
|
@ -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)
|
||||||
{
|
{
|
||||||
|
|
|
@ -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.
4718
build/obj/build.nmap
4718
build/obj/build.nmap
File diff suppressed because it is too large
Load diff
|
@ -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 */
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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()
|
||||||
|
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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__
|
||||||
|
|
|
@ -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_
|
|
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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"}
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue