mirror of
https://github.com/cwyark/ameba-sdk-gcc-make.git
synced 2024-11-21 13:34:18 +00:00
first commit and add gitignore, README.md
This commit is contained in:
commit
760756ba2c
1861 changed files with 709236 additions and 0 deletions
2
.gitignore
vendored
Normal file
2
.gitignore
vendored
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
*.swp
|
||||||
|
.DS_Store
|
18
README.md
Normal file
18
README.md
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
### Realtek Ameba SDK for ARM-GCC and makefile ###
|
||||||
|
|
||||||
|
this repository is aiming to build the ameba sdk for ARM gcc and makefile
|
||||||
|
|
||||||
|
Current SDK version is v3.4b3
|
||||||
|
|
||||||
|
## How to use ##
|
||||||
|
|
||||||
|
make for your target elf and binary file
|
||||||
|
|
||||||
|
```bash
|
||||||
|
make
|
||||||
|
```
|
||||||
|
|
||||||
|
make deploy for upgrade binary file to your EVB
|
||||||
|
```bash
|
||||||
|
make deploy
|
||||||
|
```
|
196
component/common/api/at_cmd/atcmd_google.c
Executable file
196
component/common/api/at_cmd/atcmd_google.c
Executable file
|
@ -0,0 +1,196 @@
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "log_service.h"
|
||||||
|
#include "cmsis_os.h"
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
#include <lwip/sockets.h>
|
||||||
|
#include <lwip/tcpip.h>
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#include "google/google_nest.h"
|
||||||
|
#include <cJSON.h>
|
||||||
|
#include <platform_opts.h>
|
||||||
|
|
||||||
|
#define GN_PORT 443
|
||||||
|
|
||||||
|
|
||||||
|
#define _AT_GOOGLE_NEST_ "ATG0"
|
||||||
|
|
||||||
|
//functions that using Google Nest's API
|
||||||
|
void google_data_retrieve_cb(char *response_buf);
|
||||||
|
|
||||||
|
void googlenest_get(char *host_addr, char *host_file)
|
||||||
|
{
|
||||||
|
unsigned char buffer[512];
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
if(gn_get(&googlenest, googlenest_uri, buffer, sizeof(buffer)) == 0)
|
||||||
|
printf("\r\n\r\nGet data from googlenest: %s", buffer);
|
||||||
|
gn_close(&googlenest);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void google_data_retrieve_cb(char *response_buf) {
|
||||||
|
printf("\r\nResponse_buf:\r\n%s\r\n", response_buf);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void googlenest_stream(char *host_addr, char *host_file)
|
||||||
|
{
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
google_retrieve_data_hook_callback(google_data_retrieve_cb);
|
||||||
|
gn_stream(&googlenest, googlenest_uri);
|
||||||
|
gn_close(&googlenest);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void googlenest_delete(char *host_addr, char *host_file)
|
||||||
|
{
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
if(gn_delete(&googlenest, googlenest_uri) == 0)
|
||||||
|
printf("\r\n\r\nDelete the data is successful!");
|
||||||
|
gn_close(&googlenest);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void googlenest_put(char *host_addr, char *host_file, char *data)
|
||||||
|
{
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
if(gn_put(&googlenest, googlenest_uri, data) == 0)
|
||||||
|
printf("\r\n\r\nSaving data in firebase is successful!");
|
||||||
|
gn_close(&googlenest);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void googlenest_patch(char *host_addr, char *host_file, char *data)
|
||||||
|
{
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
if(gn_patch(&googlenest, googlenest_uri, data) == 0)
|
||||||
|
printf("\r\n\r\nUpdating data in firebase is successful!");
|
||||||
|
gn_close(&googlenest);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void googlenest_post(char *host_addr, char *host_file, char *data)
|
||||||
|
{
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = host_addr;
|
||||||
|
char *googlenest_uri = host_file;
|
||||||
|
unsigned char buffer[64];
|
||||||
|
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
if(gn_post(&googlenest, googlenest_uri, data, buffer, sizeof(buffer)) == 0)
|
||||||
|
printf("\r\n\r\nInserting data to firebase is successful!\r\n\r\nThe unique name for this list of data is: %s", buffer);
|
||||||
|
gn_close(&googlenest);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_googlenest(int argc, char **argv)
|
||||||
|
{
|
||||||
|
if(strcmp(argv[1], "get") == 0) {
|
||||||
|
if(argc != 4)
|
||||||
|
printf("\n\rUsage: gn get address file");
|
||||||
|
else {
|
||||||
|
googlenest_get(argv[2], argv[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(strcmp(argv[1], "delete") ==0){
|
||||||
|
if(argc != 4)
|
||||||
|
printf("\n\rUsage: gn delete address file");
|
||||||
|
else {
|
||||||
|
googlenest_delete(argv[2], argv[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(strcmp(argv[1], "put") ==0){
|
||||||
|
if(argc != 5)
|
||||||
|
printf("\n\rUsage: gn put address file data");
|
||||||
|
else {
|
||||||
|
googlenest_put(argv[2], argv[3], argv[4]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(strcmp(argv[1], "patch") ==0){
|
||||||
|
if(argc != 5)
|
||||||
|
printf("\n\rUsage: gn patch address file data");
|
||||||
|
else {
|
||||||
|
googlenest_patch(argv[2], argv[3], argv[4]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(strcmp(argv[1], "post") ==0){
|
||||||
|
if(argc != 5)
|
||||||
|
printf("\n\rUsage: gn post address file data");
|
||||||
|
else {
|
||||||
|
googlenest_post(argv[2], argv[3], argv[4]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(strcmp(argv[1], "stream") ==0){
|
||||||
|
if(argc != 4)
|
||||||
|
printf("\n\rUsage: gn stream address file");
|
||||||
|
else {
|
||||||
|
googlenest_stream(argv[2], argv[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\n\rUsage: gn method addr file (data)");
|
||||||
|
}
|
||||||
|
|
||||||
|
//AT Command function
|
||||||
|
|
||||||
|
void fATG0(void *arg){
|
||||||
|
int argc;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
printf("[ATG0]: _AT_WLAN_GOOGLENEST_\n\r");
|
||||||
|
if(!arg){
|
||||||
|
printf("[ATG0]Usage: ATWG=[method,address,file,data] or ATG0=[method,address,file]\n\r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
argv[0] = "gn";
|
||||||
|
if((argc = parse_param(arg, argv)) > 1){
|
||||||
|
cmd_googlenest(argc, argv);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("[ATG0]Usage: ATG0=[method,address,file,data] or ATG0=[method,address,file]\n\r");
|
||||||
|
}
|
||||||
|
|
||||||
|
#if CONFIG_GOOGLE_NEST
|
||||||
|
log_item_t at_google_items[ ] = {
|
||||||
|
|
||||||
|
{"ATG0", fATG0,}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
void at_google_init(void)
|
||||||
|
{
|
||||||
|
log_service_add_table(at_google_items, sizeof(at_google_items)/sizeof(at_google_items[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
log_module_init(at_google_init);
|
||||||
|
#endif
|
481
component/common/api/at_cmd/atcmd_sys.c
Executable file
481
component/common/api/at_cmd/atcmd_sys.c
Executable file
|
@ -0,0 +1,481 @@
|
||||||
|
#include <platform_stdlib.h>
|
||||||
|
#include <platform_opts.h>
|
||||||
|
#include <hal_adc.h>
|
||||||
|
#include <gpio_api.h> // mbed
|
||||||
|
#include <sys_api.h>
|
||||||
|
#include <rtl_lib.h>
|
||||||
|
//#include <build_info.h>
|
||||||
|
#include "analogin_api.h"
|
||||||
|
#include "log_service.h"
|
||||||
|
#include "atcmd_sys.h"
|
||||||
|
#include "osdep_api.h"
|
||||||
|
|
||||||
|
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
|
||||||
|
#include "freertos_pmu.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern u32 ConfigDebugErr;
|
||||||
|
extern u32 ConfigDebugInfo;
|
||||||
|
extern u32 ConfigDebugWarn;
|
||||||
|
extern u32 CmdDumpWord(IN u16 argc, IN u8 *argv[]);
|
||||||
|
extern u32 CmdWriteWord(IN u16 argc, IN u8 *argv[]);
|
||||||
|
#if SUPPORT_UART_YMODEM
|
||||||
|
extern int uart_ymodem(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
||||||
|
static char cBuffer[512];
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//-------- AT SYS commands ---------------------------------------------------------------
|
||||||
|
|
||||||
|
void fATSD(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_DUMP, AT_DBG_ALWAYS, "[ATSD]: _AT_SYSTEM_DUMP_REGISTER_");
|
||||||
|
if(!arg){
|
||||||
|
AT_DBG_MSG(AT_FLAG_DUMP, AT_DBG_ALWAYS, "[ATSD] Usage: ATSD=REGISTER");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(argc == 2 || argc == 3)
|
||||||
|
CmdDumpWord(argc-1, (unsigned char**)(argv+1));
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSE(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_EDIT, AT_DBG_ALWAYS, "[ATSE]: _AT_SYSTEM_EDIT_REGISTER_");
|
||||||
|
if(!arg){
|
||||||
|
AT_DBG_MSG(AT_FLAG_EDIT, AT_DBG_ALWAYS, "[ATSE] Usage: ATSE=REGISTER[VALUE]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(argc == 3)
|
||||||
|
CmdWriteWord(argc-1, (unsigned char**)(argv+1));
|
||||||
|
}
|
||||||
|
|
||||||
|
#if SUPPORT_UART_YMODEM
|
||||||
|
void fATSY(void *arg)
|
||||||
|
{
|
||||||
|
uart_ymodem();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if SUPPORT_MP_MODE
|
||||||
|
void fATSA(void *arg)
|
||||||
|
{
|
||||||
|
u32 tConfigDebugInfo = ConfigDebugInfo;
|
||||||
|
int argc = 0, channel;
|
||||||
|
char *argv[MAX_ARGC] = {0}, *ptmp;
|
||||||
|
u16 offset, gain;
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA]: _AT_SYSTEM_ADC_TEST_");
|
||||||
|
if(!arg){
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] Usage: ATSA=CHANNEL(0~2)");
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] Usage: ATSA=k_get");
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] Usage: ATSA=k_set[offet(hex),gain(hex)]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(strcmp(argv[1], "k_get") == 0){
|
||||||
|
sys_adc_calibration(0, &offset, &gain);
|
||||||
|
// AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] offset = 0x%04X, gain = 0x%04X", offset, gain);
|
||||||
|
}else if(strcmp(argv[1], "k_set") == 0){
|
||||||
|
if(argc != 4){
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] Usage: ATSA=k_set[offet(hex),gain(hex)]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
offset = strtoul(argv[2], &ptmp, 16);
|
||||||
|
gain = strtoul(argv[3], &ptmp, 16);
|
||||||
|
sys_adc_calibration(1, &offset, &gain);
|
||||||
|
// AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] offset = 0x%04X, gain = 0x%04X", offset, gain);
|
||||||
|
}else{
|
||||||
|
channel = atoi(argv[1]);
|
||||||
|
if(channel < 0 || channel > 2){
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] Usage: ATSA=CHANNEL(0~2)");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
analogin_t adc;
|
||||||
|
u16 adcdat;
|
||||||
|
|
||||||
|
// Remove debug info massage
|
||||||
|
ConfigDebugInfo = 0;
|
||||||
|
if(channel == 0)
|
||||||
|
analogin_init(&adc, AD_1);
|
||||||
|
else if(channel == 1)
|
||||||
|
analogin_init(&adc, AD_2);
|
||||||
|
else
|
||||||
|
analogin_init(&adc, AD_3);
|
||||||
|
adcdat = analogin_read_u16(&adc)>>4;
|
||||||
|
analogin_deinit(&adc);
|
||||||
|
// Recover debug info massage
|
||||||
|
ConfigDebugInfo = tConfigDebugInfo;
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_ADC, AT_DBG_ALWAYS, "[ATSA] A%d = 0x%04X", channel, adcdat);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSG(void *arg)
|
||||||
|
{
|
||||||
|
gpio_t gpio_test;
|
||||||
|
int argc = 0, val;
|
||||||
|
char *argv[MAX_ARGC] = {0}, port, num;
|
||||||
|
PinName pin = NC;
|
||||||
|
u32 tConfigDebugInfo = ConfigDebugInfo;
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSG]: _AT_SYSTEM_GPIO_TEST_");
|
||||||
|
if(!arg){
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSG] Usage: ATSG=PINNAME(ex:A0)");
|
||||||
|
return;
|
||||||
|
}else{
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(argc != 2){
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSG] Usage: ATSG=PINNAME(ex:A0)");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
port = argv[1][0];
|
||||||
|
num = argv[1][1];
|
||||||
|
if(port >= 'a' && port <= 'z')
|
||||||
|
port -= ('a' - 'A');
|
||||||
|
if(num >= 'a' && num <= 'z')
|
||||||
|
num -= ('a' - 'A');
|
||||||
|
switch(port){
|
||||||
|
case 'A':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PA_0; break; case '1': pin = PA_1; break; case '2': pin = PA_2; break; case '3': pin = PA_3; break;
|
||||||
|
case '4': pin = PA_4; break; case '5': pin = PA_5; break; case '6': pin = PA_6; break; case '7': pin = PA_7; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'B':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PB_0; break; case '1': pin = PB_1; break; case '2': pin = PB_2; break; case '3': pin = PB_3; break;
|
||||||
|
case '4': pin = PB_4; break; case '5': pin = PB_5; break; case '6': pin = PB_6; break; case '7': pin = PB_7; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'C':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PC_0; break; case '1': pin = PC_1; break; case '2': pin = PC_2; break; case '3': pin = PC_3; break;
|
||||||
|
case '4': pin = PC_4; break; case '5': pin = PC_5; break; case '6': pin = PC_6; break; case '7': pin = PC_7; break;
|
||||||
|
case '8': pin = PC_8; break; case '9': pin = PC_9; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'D':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PD_0; break; case '1': pin = PD_1; break; case '2': pin = PD_2; break; case '3': pin = PD_3; break;
|
||||||
|
case '4': pin = PD_4; break; case '5': pin = PD_5; break; case '6': pin = PD_6; break; case '7': pin = PD_7; break;
|
||||||
|
case '8': pin = PD_8; break; case '9': pin = PD_9; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'E':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PE_0; break; case '1': pin = PE_1; break; case '2': pin = PE_2; break; case '3': pin = PE_3; break;
|
||||||
|
case '4': pin = PE_4; break; case '5': pin = PE_5; break; case '6': pin = PE_6; break; case '7': pin = PE_7; break;
|
||||||
|
case '8': pin = PE_8; break; case '9': pin = PE_9; break; case 'A': pin = PE_A; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'F':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PF_0; break; case '1': pin = PF_1; break; case '2': pin = PF_2; break; case '3': pin = PF_3; break;
|
||||||
|
case '4': pin = PF_4; break; case '5': pin = PF_5; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'G':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PG_0; break; case '1': pin = PG_1; break; case '2': pin = PG_2; break; case '3': pin = PG_3; break;
|
||||||
|
case '4': pin = PG_4; break; case '5': pin = PG_5; break; case '6': pin = PG_6; break; case '7': pin = PG_7; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'H':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PH_0; break; case '1': pin = PH_1; break; case '2': pin = PH_2; break; case '3': pin = PH_3; break;
|
||||||
|
case '4': pin = PH_4; break; case '5': pin = PH_5; break; case '6': pin = PH_6; break; case '7': pin = PH_7; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'I':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PI_0; break; case '1': pin = PI_1; break; case '2': pin = PI_2; break; case '3': pin = PI_3; break;
|
||||||
|
case '4': pin = PI_4; break; case '5': pin = PI_5; break; case '6': pin = PI_6; break; case '7': pin = PI_7; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'J':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PJ_0; break; case '1': pin = PJ_1; break; case '2': pin = PJ_2; break; case '3': pin = PJ_3; break;
|
||||||
|
case '4': pin = PJ_4; break; case '5': pin = PJ_5; break; case '6': pin = PJ_6; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'K':
|
||||||
|
switch(num){
|
||||||
|
case '0': pin = PK_0; break; case '1': pin = PK_1; break; case '2': pin = PK_2; break; case '3': pin = PK_3; break;
|
||||||
|
case '4': pin = PK_4; break; case '5': pin = PK_5; break; case '6': pin = PK_6; break;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if(pin == NC){
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSG]: Invalid Pin Name");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
// Remove debug info massage
|
||||||
|
ConfigDebugInfo = 0;
|
||||||
|
// Initial input control pin
|
||||||
|
gpio_init(&gpio_test, pin);
|
||||||
|
gpio_dir(&gpio_test, PIN_INPUT); // Direction: Input
|
||||||
|
gpio_mode(&gpio_test, PullUp); // Pull-High
|
||||||
|
val = gpio_read(&gpio_test);
|
||||||
|
// Recover debug info massage
|
||||||
|
ConfigDebugInfo = tConfigDebugInfo;
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSG] %c%c = %d", port, num, val);
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSC(void *arg)
|
||||||
|
{
|
||||||
|
AT_DBG_MSG(AT_FLAG_OTA, AT_DBG_ALWAYS, "[ATSC]: _AT_SYSTEM_CLEAR_OTA_SIGNATURE_");
|
||||||
|
sys_clear_ota_signature();
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSR(void *arg)
|
||||||
|
{
|
||||||
|
AT_DBG_MSG(AT_FLAG_OTA, AT_DBG_ALWAYS, "[ATSR]: _AT_SYSTEM_RECOVER_OTA_SIGNATURE_");
|
||||||
|
sys_recover_ota_signature();
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSP(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
unsigned long timeout; // ms
|
||||||
|
unsigned long time_begin, time_current;
|
||||||
|
|
||||||
|
gpio_t gpiob_1;
|
||||||
|
int val_old, val_new;
|
||||||
|
|
||||||
|
int expected_zerocount, zerocount;
|
||||||
|
int test_result;
|
||||||
|
|
||||||
|
// parameter check
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: _AT_SYSTEM_POWER_PIN_TEST_");
|
||||||
|
if(!arg) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: Usage: ATSP=gpiob1[timeout,zerocount]");
|
||||||
|
} else {
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if (argc < 2) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: Usage: ATSP=gpiob1[timeout,zerocount]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( strcmp(argv[1], "gpiob1" ) == 0 ) {
|
||||||
|
if (argc < 4) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: Usage: ATSP=gpiob1[timeout,zerocount]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// init gpiob1 test
|
||||||
|
test_result = 0;
|
||||||
|
timeout = strtoul(argv[2], NULL, 10);
|
||||||
|
expected_zerocount = atoi(argv[3]);
|
||||||
|
zerocount = 0;
|
||||||
|
val_old = 1;
|
||||||
|
|
||||||
|
sys_log_uart_off();
|
||||||
|
|
||||||
|
gpio_init(&gpiob_1, PB_1);
|
||||||
|
gpio_dir(&gpiob_1, PIN_INPUT);
|
||||||
|
gpio_mode(&gpiob_1, PullDown);
|
||||||
|
|
||||||
|
// gpiob1 test ++
|
||||||
|
time_begin = time_current = xTaskGetTickCount();
|
||||||
|
while (time_current < time_begin + timeout) {
|
||||||
|
val_new = gpio_read(&gpiob_1);
|
||||||
|
|
||||||
|
if (val_new != val_old && val_new == 0) {
|
||||||
|
|
||||||
|
zerocount ++;
|
||||||
|
if (zerocount == expected_zerocount) {
|
||||||
|
test_result = 1;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
val_old = val_new;
|
||||||
|
time_current = xTaskGetTickCount();
|
||||||
|
}
|
||||||
|
// gpio test --
|
||||||
|
|
||||||
|
sys_log_uart_on();
|
||||||
|
|
||||||
|
if (test_result == 1) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: success");
|
||||||
|
} else {
|
||||||
|
AT_DBG_MSG(AT_FLAG_GPIO, AT_DBG_ALWAYS, "[ATSP]: fail, it only got %d zeros", zerocount);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
|
||||||
|
void fATSL(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
uint32_t lock_id;
|
||||||
|
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL]: _AT_SYS_WAKELOCK_TEST_");
|
||||||
|
|
||||||
|
if (!arg) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] Usage ATSL=[a/r/?][bitmask]");
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if (argc < 2) {
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] Usage ATSL=[a/r/?][bitmask]");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(argv[1][0]) {
|
||||||
|
case 'a': // acquire
|
||||||
|
{
|
||||||
|
if (argc == 3) {
|
||||||
|
lock_id = strtoul(argv[2], NULL, 16);
|
||||||
|
acquire_wakelock(lock_id);
|
||||||
|
}
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] wakelock:0x%08x", get_wakelock_status());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 'r': // release
|
||||||
|
{
|
||||||
|
if (argc == 3) {
|
||||||
|
lock_id = strtoul(argv[2], NULL, 16);
|
||||||
|
release_wakelock(lock_id);
|
||||||
|
}
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] wakelock:0x%08x", get_wakelock_status());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case '?': // get status
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] wakelock:0x%08x", get_wakelock_status());
|
||||||
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
||||||
|
get_wakelock_hold_stats((char *)cBuffer);
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "%s", cBuffer);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
|
||||||
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
||||||
|
case 'c': // clean wakelock info (for recalculate wakelock hold time)
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] clean wakelock stat");
|
||||||
|
clean_wakelock_stat();
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
default:
|
||||||
|
AT_DBG_MSG(AT_FLAG_OS, AT_DBG_ALWAYS, "[ATSL] Usage ATSL=[a/r/?][bitmask]");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
||||||
|
void fATSS(void *arg) // Show CPU stats
|
||||||
|
{
|
||||||
|
AT_PRINTK("[ATSS]: _AT_SYSTEM_CPU_STATS_");
|
||||||
|
vTaskGetRunTimeStats((char *)cBuffer);
|
||||||
|
AT_PRINTK("%s", cBuffer);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void fATSs(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
AT_PRINTK("[ATS@]: _AT_SYSTEM_DBG_SETTING_");
|
||||||
|
if(!arg){
|
||||||
|
AT_PRINTK("[ATS@] Usage: ATS@=[LEVLE,FLAG]");
|
||||||
|
}else{
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(argc == 3){
|
||||||
|
char *ptmp;
|
||||||
|
gDbgLevel = atoi(argv[1]);
|
||||||
|
gDbgFlag = strtoul(argv[2], &ptmp, 16);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AT_PRINTK("[ATS@] level = %d, flag = 0x%08X", gDbgLevel, gDbgFlag);
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSc(void *arg)
|
||||||
|
{
|
||||||
|
int argc = 0, config = 0;
|
||||||
|
char *argv[MAX_ARGC] = {0};
|
||||||
|
|
||||||
|
AT_PRINTK("[ATS!]: _AT_SYSTEM_CONFIG_SETTING_");
|
||||||
|
if(!arg){
|
||||||
|
AT_PRINTK("[ATS!] Usage: ATS!=[CONFIG(0,1,2),FLAG]");
|
||||||
|
}else{
|
||||||
|
argc = parse_param(arg, argv);
|
||||||
|
if(argc == 3){
|
||||||
|
char *ptmp;
|
||||||
|
config = atoi(argv[1]);
|
||||||
|
if(config == 0)
|
||||||
|
ConfigDebugErr = strtoul(argv[2], &ptmp, 16);
|
||||||
|
if(config == 1)
|
||||||
|
ConfigDebugInfo = strtoul(argv[2], &ptmp, 16);
|
||||||
|
if(config == 2)
|
||||||
|
ConfigDebugWarn = strtoul(argv[2], &ptmp, 16);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
AT_PRINTK("[ATS!] ConfigDebugErr = 0x%08X", ConfigDebugErr);
|
||||||
|
AT_PRINTK("[ATS!] ConfigDebugInfo = 0x%08X", ConfigDebugInfo);
|
||||||
|
AT_PRINTK("[ATS!] ConfigDebugWarn = 0x%08X", ConfigDebugWarn);
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSt(void *arg)
|
||||||
|
{
|
||||||
|
AT_PRINTK("[ATS#]: _AT_SYSTEM_TEST_");
|
||||||
|
}
|
||||||
|
|
||||||
|
void fATSx(void *arg)
|
||||||
|
{
|
||||||
|
AT_PRINTK("[ATS?]: _AT_SYSTEM_HELP_");
|
||||||
|
//AT_PRINTK("[ATS?]: COMPILE TIME: %s", RTL8195AFW_COMPILE_TIME);
|
||||||
|
}
|
||||||
|
|
||||||
|
log_item_t at_sys_items[] = {
|
||||||
|
{"ATSD", fATSD,}, // Dump register
|
||||||
|
{"ATSE", fATSE,}, // Edit register
|
||||||
|
#if SUPPORT_UART_YMODEM
|
||||||
|
{"ATSY", fATSY,}, // uart ymodem upgrade
|
||||||
|
#endif
|
||||||
|
#if SUPPORT_MP_MODE
|
||||||
|
{"ATSA", fATSA,}, // MP ADC test
|
||||||
|
{"ATSG", fATSG,}, // MP GPIO test
|
||||||
|
{"ATSC", fATSC,}, // Clear OTA signature
|
||||||
|
{"ATSR", fATSR,}, // Recover OTA signature
|
||||||
|
{"ATSP", fATSP,}, // MP Power related test
|
||||||
|
#endif
|
||||||
|
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
|
||||||
|
{"ATSL", fATSL,}, // wakelock test
|
||||||
|
#endif
|
||||||
|
#if (configGENERATE_RUN_TIME_STATS == 1)
|
||||||
|
{"ATSS", fATSS,}, // Show CPU stats
|
||||||
|
#endif
|
||||||
|
{"ATS@", fATSs,}, // Debug message setting
|
||||||
|
{"ATS!", fATSc,}, // Debug config setting
|
||||||
|
{"ATS#", fATSt,}, // test command
|
||||||
|
{"ATS?", fATSx,} // Help
|
||||||
|
};
|
||||||
|
|
||||||
|
void at_sys_init(void)
|
||||||
|
{
|
||||||
|
log_service_add_table(at_sys_items, sizeof(at_sys_items)/sizeof(at_sys_items[0]));
|
||||||
|
}
|
||||||
|
|
||||||
|
log_module_init(at_sys_init);
|
5
component/common/api/at_cmd/atcmd_sys.h
Executable file
5
component/common/api/at_cmd/atcmd_sys.h
Executable file
|
@ -0,0 +1,5 @@
|
||||||
|
#ifndef __ATCMD_SYS_H__
|
||||||
|
#define __ATCMD_SYS_H__
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
1392
component/common/api/at_cmd/atcmd_wifi.c
Executable file
1392
component/common/api/at_cmd/atcmd_wifi.c
Executable file
File diff suppressed because it is too large
Load diff
67
component/common/api/at_cmd/atcmd_wifi.h
Executable file
67
component/common/api/at_cmd/atcmd_wifi.h
Executable file
|
@ -0,0 +1,67 @@
|
||||||
|
#ifndef __ATCMD_WIFI_H__
|
||||||
|
#define __ATCMD_WIFI_H__
|
||||||
|
#include "main.h"
|
||||||
|
#ifndef WLAN0_NAME
|
||||||
|
#define WLAN0_NAME "wlan0"
|
||||||
|
#endif
|
||||||
|
#ifndef WLAN1_NAME
|
||||||
|
#define WLAN1_NAME "wlan1"
|
||||||
|
#endif
|
||||||
|
/* Give default value if not defined */
|
||||||
|
#ifndef NET_IF_NUM
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
#define NET_IF_NUM 2
|
||||||
|
#else
|
||||||
|
#define NET_IF_NUM 1
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#ifndef IP_ADDR0
|
||||||
|
#define IP_ADDR0 192
|
||||||
|
#define IP_ADDR1 168
|
||||||
|
#define IP_ADDR2 1
|
||||||
|
#define IP_ADDR3 80
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#ifndef NETMASK_ADDR0
|
||||||
|
#define NETMASK_ADDR0 255
|
||||||
|
#define NETMASK_ADDR1 255
|
||||||
|
#define NETMASK_ADDR2 255
|
||||||
|
#define NETMASK_ADDR3 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#ifndef GW_ADDR0
|
||||||
|
#define GW_ADDR0 192
|
||||||
|
#define GW_ADDR1 168
|
||||||
|
#define GW_ADDR2 1
|
||||||
|
#define GW_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#ifndef AP_IP_ADDR0
|
||||||
|
#define AP_IP_ADDR0 192
|
||||||
|
#define AP_IP_ADDR1 168
|
||||||
|
#define AP_IP_ADDR2 43
|
||||||
|
#define AP_IP_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#ifndef AP_NETMASK_ADDR0
|
||||||
|
#define AP_NETMASK_ADDR0 255
|
||||||
|
#define AP_NETMASK_ADDR1 255
|
||||||
|
#define AP_NETMASK_ADDR2 255
|
||||||
|
#define AP_NETMASK_ADDR3 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#ifndef AP_GW_ADDR0
|
||||||
|
#define AP_GW_ADDR0 192
|
||||||
|
#define AP_GW_ADDR1 168
|
||||||
|
#define AP_GW_ADDR2 43
|
||||||
|
#define AP_GW_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
339
component/common/api/at_cmd/log_service.c
Executable file
339
component/common/api/at_cmd/log_service.c
Executable file
|
@ -0,0 +1,339 @@
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
|
||||||
|
#include "freertos_pmu.h"
|
||||||
|
#endif
|
||||||
|
#include "log_service.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "semphr.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "wifi_util.h"
|
||||||
|
|
||||||
|
#if SUPPORT_LOG_SERVICE
|
||||||
|
//======================================================
|
||||||
|
struct list_head log_hash[ATC_INDEX_NUM];
|
||||||
|
|
||||||
|
extern void at_wifi_init(void);
|
||||||
|
extern void at_fs_init(void);
|
||||||
|
extern void at_sys_init(void);
|
||||||
|
//extern void at_app_init(void);
|
||||||
|
char log_buf[LOG_SERVICE_BUFLEN];
|
||||||
|
#if CONFIG_LOG_HISTORY
|
||||||
|
char log_history[LOG_HISTORY_LEN][LOG_SERVICE_BUFLEN];
|
||||||
|
static unsigned int log_history_count = 0;
|
||||||
|
#endif
|
||||||
|
xSemaphoreHandle log_rx_interrupt_sema = NULL;
|
||||||
|
extern xSemaphoreHandle uart_rx_interrupt_sema;
|
||||||
|
|
||||||
|
#if CONFIG_INIC_EN
|
||||||
|
extern unsigned char inic_cmd_ioctl;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (__ICCARM__)
|
||||||
|
#pragma section=".data.log_init"
|
||||||
|
|
||||||
|
unsigned int __log_init_begin__;
|
||||||
|
unsigned int __log_init_end__;
|
||||||
|
#elif defined ( __CC_ARM ) || defined(__GNUC__)
|
||||||
|
//#pragma section=".data.log_init"
|
||||||
|
log_init_t* __log_init_begin__;
|
||||||
|
log_init_t* __log_init_end__;
|
||||||
|
log_init_t log_init_table[] = {
|
||||||
|
at_wifi_init,
|
||||||
|
// at_fs_init,
|
||||||
|
at_sys_init
|
||||||
|
// at_app_init
|
||||||
|
};
|
||||||
|
#else
|
||||||
|
#error "not implement, add to linker script"
|
||||||
|
extern unsigned int __log_init_begin__;
|
||||||
|
extern unsigned int __log_init_end__;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__GNUC__)
|
||||||
|
#define USE_STRSEP
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//======================================================
|
||||||
|
int hash_index(char *str)
|
||||||
|
{
|
||||||
|
unsigned int seed = 131; // 31 131 1313 13131 131313 etc..
|
||||||
|
unsigned int hash = 0;
|
||||||
|
|
||||||
|
while (*str)
|
||||||
|
{
|
||||||
|
hash = hash * seed + (*str++);
|
||||||
|
}
|
||||||
|
|
||||||
|
return (hash & 0x7FFFFFFF);
|
||||||
|
}
|
||||||
|
|
||||||
|
void log_add_new_command(log_item_t *new)
|
||||||
|
{
|
||||||
|
int index = hash_index(new->log_cmd)%ATC_INDEX_NUM;
|
||||||
|
|
||||||
|
list_add(&new->node, &log_hash[index]);
|
||||||
|
}
|
||||||
|
void start_log_service(void);
|
||||||
|
void log_service_init(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
#if defined (__ICCARM__)
|
||||||
|
log_init_t *log_init_table;
|
||||||
|
__log_init_begin__ = (unsigned int)__section_begin(".data.log_init");
|
||||||
|
__log_init_end__ = (unsigned int)__section_end(".data.log_init");
|
||||||
|
log_init_table = (log_init_t *)__log_init_begin__;
|
||||||
|
#elif defined(__CC_ARM) || defined(__GNUC__)
|
||||||
|
__log_init_begin__ = log_init_table;
|
||||||
|
__log_init_end__ = log_init_table + sizeof(log_init_table);
|
||||||
|
#else
|
||||||
|
#error "not implement"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
for(i=0;i<ATC_INDEX_NUM;i++)
|
||||||
|
INIT_LIST_HEAD(&log_hash[i]);
|
||||||
|
|
||||||
|
for(i=0;i<(__log_init_end__-__log_init_begin__)/sizeof(log_init_t); i++)
|
||||||
|
log_init_table[i]();
|
||||||
|
|
||||||
|
/* Initial uart rx swmaphore*/
|
||||||
|
vSemaphoreCreateBinary(log_rx_interrupt_sema);
|
||||||
|
xSemaphoreTake(log_rx_interrupt_sema, 1/portTICK_RATE_MS);
|
||||||
|
start_log_service();
|
||||||
|
}
|
||||||
|
|
||||||
|
//sizeof(log_items)/sizeof(log_items[0])
|
||||||
|
void log_service_add_table(log_item_t *tbl, int len)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
for(i=0;i<len;i++)
|
||||||
|
log_add_new_command(&tbl[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void* log_action(char *cmd)
|
||||||
|
{
|
||||||
|
int search_cnt=0;
|
||||||
|
int index = hash_index(cmd)%ATC_INDEX_NUM;
|
||||||
|
struct list_head *head = &log_hash[index];
|
||||||
|
struct list_head *iterator;
|
||||||
|
log_item_t *item;
|
||||||
|
void *act = NULL;
|
||||||
|
|
||||||
|
list_for_each(iterator, head) {
|
||||||
|
item = list_entry(iterator, log_item_t, node);
|
||||||
|
search_cnt++;
|
||||||
|
if( strcmp(item->log_cmd, cmd) == 0){
|
||||||
|
//printf("%s match %s, search cnt %d\n\r", cmd, item->log_cmd, search_cnt);
|
||||||
|
act = (void*)item->at_act;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return act;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* log_handler(char *cmd)
|
||||||
|
{
|
||||||
|
log_act_t action=NULL;
|
||||||
|
char buf[100] = {0};
|
||||||
|
char *copy=buf;
|
||||||
|
char *token = NULL;
|
||||||
|
char *param = NULL;
|
||||||
|
char tok[5] = {0};//'\0'
|
||||||
|
#if CONFIG_LOG_HISTORY
|
||||||
|
strcpy(log_history[((log_history_count++)%LOG_HISTORY_LEN)], log_buf);
|
||||||
|
#endif
|
||||||
|
strcpy(copy, cmd);
|
||||||
|
|
||||||
|
#if defined(USE_STRSEP)
|
||||||
|
token = _strsep(©, "=");
|
||||||
|
param = copy;
|
||||||
|
#else
|
||||||
|
token = strtok(copy, "=");
|
||||||
|
param = strtok(NULL, NULL);
|
||||||
|
#endif
|
||||||
|
if(token && (strlen(token) <= 4))
|
||||||
|
strcpy(tok, token);
|
||||||
|
else{
|
||||||
|
//printf("\n\rAT Cmd format error!\n");
|
||||||
|
return NULL;
|
||||||
|
};
|
||||||
|
//printf(" Command %s \n\r ", tok);
|
||||||
|
//printf(" Param %s \n\r", param);
|
||||||
|
action = (log_act_t)log_action(tok);
|
||||||
|
|
||||||
|
if(action){
|
||||||
|
action(param);
|
||||||
|
}
|
||||||
|
return (void*)action;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
int parse_param(char *buf, char **argv)
|
||||||
|
{
|
||||||
|
int argc = 1;
|
||||||
|
while((argc < MAX_ARGC) && (*buf != '\0')) {
|
||||||
|
while((*buf == '[')||(*buf == ' '))
|
||||||
|
buf ++;
|
||||||
|
if((*buf == ']')||(*buf == '\0'))
|
||||||
|
break;
|
||||||
|
argv[argc] = buf;
|
||||||
|
argc ++;
|
||||||
|
buf ++;
|
||||||
|
|
||||||
|
while((*buf != ',')&&(*buf != '[')&&(*buf != ']')&&(*buf != '\0'))
|
||||||
|
buf ++;
|
||||||
|
|
||||||
|
while((*buf == ',')||(*buf == '[')||(*buf == ']')) {
|
||||||
|
*buf = '\0';
|
||||||
|
buf ++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return argc;
|
||||||
|
}
|
||||||
|
|
||||||
|
void at_set_debug_level(unsigned char newDbgLevel)
|
||||||
|
{
|
||||||
|
gDbgLevel = newDbgLevel;
|
||||||
|
}
|
||||||
|
|
||||||
|
void at_set_debug_mask(unsigned int newDbgFlag)
|
||||||
|
{
|
||||||
|
gDbgFlag = newDbgFlag;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if SUPPORT_INTERACTIVE_MODE
|
||||||
|
extern char uart_buf[64];
|
||||||
|
void legency_interactive_handler(unsigned char argc, unsigned char **argv)
|
||||||
|
{
|
||||||
|
#if 0 //defined(CONFIG_PLATFORM_8195A)
|
||||||
|
if(argc<1)
|
||||||
|
{
|
||||||
|
DiagPrintf("Wrong argument number!\r\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
DiagPrintf("Wlan Normal Mode\n");
|
||||||
|
|
||||||
|
WlanNormal( argc, argv);
|
||||||
|
#else
|
||||||
|
strncpy(uart_buf, log_buf, 63);//uart_buf[64]
|
||||||
|
xSemaphoreGive(uart_rx_interrupt_sema);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
#ifndef WLAN0_NAME
|
||||||
|
#define WLAN0_NAME "wlan0"
|
||||||
|
#endif
|
||||||
|
#ifndef WLAN1_NAME
|
||||||
|
#define WLAN1_NAME "wlan1"
|
||||||
|
#endif
|
||||||
|
int mp_commnad_handler(char *cmd)
|
||||||
|
{
|
||||||
|
char buf[64] = {0};
|
||||||
|
char *token = NULL;
|
||||||
|
|
||||||
|
strcpy(buf, cmd);
|
||||||
|
token = strtok(buf, " ");
|
||||||
|
if(token && (strcmp(buf, "iwpriv") == 0)){
|
||||||
|
token = strtok(NULL, "");
|
||||||
|
wext_private_command(WLAN0_NAME, token, 1);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
void print_help_msg(void){
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
extern void print_wlan_help(void);
|
||||||
|
print_wlan_help();
|
||||||
|
#endif
|
||||||
|
//add other help message print here
|
||||||
|
}
|
||||||
|
|
||||||
|
int print_help_handler(char *cmd){
|
||||||
|
if(strcmp(cmd, "help") == 0){
|
||||||
|
print_help_msg();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void log_service(void *param)
|
||||||
|
{
|
||||||
|
printf("\n\rStart LOG SERVICE MODE\n\r");
|
||||||
|
printf("\n\r# ");
|
||||||
|
while(1){
|
||||||
|
while(xSemaphoreTake(log_rx_interrupt_sema, portMAX_DELAY) != pdTRUE);
|
||||||
|
if(log_handler((char *)log_buf) == NULL){
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
if(mp_commnad_handler((char *)log_buf) < 0)
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
#if SUPPORT_INTERACTIVE_MODE
|
||||||
|
print_help_handler((char *)log_buf);
|
||||||
|
legency_interactive_handler(NULL, NULL);
|
||||||
|
continue;
|
||||||
|
#else
|
||||||
|
if(print_help_handler((char *)log_buf) < 0){
|
||||||
|
printf("\n\runknown command '%s'", log_buf);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
log_buf[0] = '\0';
|
||||||
|
#if CONFIG_INIC_EN
|
||||||
|
inic_cmd_ioctl = 0;
|
||||||
|
#endif
|
||||||
|
printf("\n\r[MEM] After do cmd, available heap %d\n\r", xPortGetFreeHeapSize());
|
||||||
|
printf("\r\n\n# ");
|
||||||
|
#if defined(configUSE_WAKELOCK_PMU) && (configUSE_WAKELOCK_PMU == 1)
|
||||||
|
release_wakelock(WAKELOCK_LOGUART);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#define STACKSIZE 1280
|
||||||
|
void start_log_service(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(log_service, (char const*)"log_service", STACKSIZE, NULL, tskIDLE_PRIORITY + 5, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate failed", __FUNCTION__);
|
||||||
|
}
|
||||||
|
void fAT_exit(void *arg){
|
||||||
|
printf("\n\rLeave LOG SERVICE");
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
#if CONFIG_LOG_HISTORY
|
||||||
|
void fAT_log(void *arg){
|
||||||
|
int i = 0;
|
||||||
|
printf("[AT]log history:\n\n\r");
|
||||||
|
if(log_history_count > LOG_HISTORY_LEN){
|
||||||
|
for(i=0; i<4; i++)
|
||||||
|
printf(" %s\n\r", log_history[((log_history_count+i)%LOG_HISTORY_LEN)]);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
for(i=0; i<(log_history_count-1); i++)
|
||||||
|
printf(" %s\n\r", log_history[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
log_item_t at_log_items[ ] = {
|
||||||
|
{"AT--", fAT_exit,},
|
||||||
|
#if CONFIG_LOG_HISTORY
|
||||||
|
{"AT??", fAT_log,},
|
||||||
|
#endif
|
||||||
|
{"ATxx", fAT_exit,}
|
||||||
|
};
|
||||||
|
void at_log_init(void)
|
||||||
|
{
|
||||||
|
log_service_add_table(at_log_items, sizeof(at_log_items)/sizeof(at_log_items[0]));
|
||||||
|
}
|
||||||
|
log_module_init(at_log_init);
|
||||||
|
#endif
|
97
component/common/api/at_cmd/log_service.h
Executable file
97
component/common/api/at_cmd/log_service.h
Executable file
|
@ -0,0 +1,97 @@
|
||||||
|
#ifndef LOG_SERVICE_H
|
||||||
|
#define LOG_SERVICE_H
|
||||||
|
|
||||||
|
#include "dlist.h"
|
||||||
|
/*
|
||||||
|
* Include user defined options first. Anything not defined in these files
|
||||||
|
* will be set to standard values. Override anything you dont like!
|
||||||
|
*/
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#include "platform_opts.h"
|
||||||
|
#include "platform_stdlib.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __ICCARM__
|
||||||
|
#define log_module_init(fn) \
|
||||||
|
SECTION(".data.log_init") __root static void* log_##fn = (void*)fn
|
||||||
|
#elif defined(__CC_ARM)
|
||||||
|
#define log_module_init(fn) \
|
||||||
|
static void* log_##fn __attribute__((section(".data.log_init"))) = (void*)fn;
|
||||||
|
#define DiagPrintf printf
|
||||||
|
#elif defined(__GNUC__)
|
||||||
|
#define log_module_init(fn) \
|
||||||
|
static void* log_##fn __attribute__((section(".data.log_init"))) = (void*)fn;
|
||||||
|
#else
|
||||||
|
#error "not implement"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ATC_INDEX_NUM 32
|
||||||
|
|
||||||
|
#ifndef SUPPORT_LOG_SERVICE
|
||||||
|
#define SUPPORT_LOG_SERVICE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if SUPPORT_LOG_SERVICE
|
||||||
|
|
||||||
|
//LOG_SERVICE_BUFLEN: default, only 63 bytes could be used for keeping input
|
||||||
|
// cmd, the last byte is for string end ('\0').
|
||||||
|
#ifndef LOG_SERVICE_BUFLEN
|
||||||
|
#define LOG_SERVICE_BUFLEN 64
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_LOG_HISTORY
|
||||||
|
#define CONFIG_LOG_HISTORY 0
|
||||||
|
#if CONFIG_LOG_HISTORY
|
||||||
|
#define LOG_HISTORY_LEN 5
|
||||||
|
#endif
|
||||||
|
#endif //#ifndef CONFIG_LOG_HISTORY
|
||||||
|
|
||||||
|
#ifndef MAX_ARGC
|
||||||
|
#define MAX_ARGC 6
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define AT_BIT(n) (1<<n)
|
||||||
|
#define AT_FLAG_DUMP AT_BIT(0)
|
||||||
|
#define AT_FLAG_EDIT AT_BIT(1)
|
||||||
|
#define AT_FLAG_ADC AT_BIT(2)
|
||||||
|
#define AT_FLAG_GPIO AT_BIT(3)
|
||||||
|
#define AT_FLAG_OTA AT_BIT(4)
|
||||||
|
#define AT_FLAG_NFC AT_BIT(5)
|
||||||
|
#define AT_FLAG_OS AT_BIT(6)
|
||||||
|
|
||||||
|
enum{
|
||||||
|
AT_DBG_OFF = 0,
|
||||||
|
AT_DBG_ALWAYS,
|
||||||
|
AT_DBG_ERROR,
|
||||||
|
AT_DBG_WARNING,
|
||||||
|
AT_DBG_INFO
|
||||||
|
};
|
||||||
|
|
||||||
|
static unsigned char gDbgLevel = AT_DBG_ERROR;
|
||||||
|
static unsigned int gDbgFlag = 0xFFFFFFFF;
|
||||||
|
|
||||||
|
#define AT_PRINTK(...) do { printf(__VA_ARGS__); printf("\r\n"); } while(0)
|
||||||
|
#define AT_DBG_MSG(flag, level, ...) \
|
||||||
|
do{ \
|
||||||
|
if(((flag) & gDbgFlag) && (level <= gDbgLevel)){ \
|
||||||
|
AT_PRINTK(__VA_ARGS__); \
|
||||||
|
} \
|
||||||
|
}while(0)
|
||||||
|
|
||||||
|
#ifndef SUPPORT_INTERACTIVE_MODE
|
||||||
|
#define SUPPORT_INTERACTIVE_MODE 0
|
||||||
|
#endif //#ifndef SUPPORT_INTERACTIVE_MODE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef void (*log_init_t)(void);
|
||||||
|
typedef void (*log_act_t)(void*);
|
||||||
|
typedef struct _at_command_item_{
|
||||||
|
char *log_cmd;
|
||||||
|
log_act_t at_act;
|
||||||
|
struct list_head node;
|
||||||
|
}log_item_t;
|
||||||
|
|
||||||
|
void log_service_add_table(log_item_t *tbl, int len);
|
||||||
|
int parse_param(char *buf, char **argv);
|
||||||
|
|
||||||
|
#endif
|
354
component/common/api/lwip_netconf.c
Executable file
354
component/common/api/lwip_netconf.c
Executable file
|
@ -0,0 +1,354 @@
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "lwip/mem.h"
|
||||||
|
#include "lwip/memp.h"
|
||||||
|
#include "lwip/dhcp.h"
|
||||||
|
#include "lwip/dns.h"
|
||||||
|
#include "ethernetif.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "lwip_netconf.h"
|
||||||
|
#include "wifi_ind.h"
|
||||||
|
#if defined(STM32F2XX)
|
||||||
|
#include "stm322xg_eval_lcd.h"
|
||||||
|
#elif defined(STM32F4XX)
|
||||||
|
#include "stm324xg_eval_lcd.h"
|
||||||
|
#endif
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
/* Give default value if not defined */
|
||||||
|
#ifndef NET_IF_NUM
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
#define NET_IF_NUM 2
|
||||||
|
#else
|
||||||
|
#define NET_IF_NUM 1
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#ifndef IP_ADDR0
|
||||||
|
#define IP_ADDR0 192
|
||||||
|
#define IP_ADDR1 168
|
||||||
|
#define IP_ADDR2 1
|
||||||
|
#define IP_ADDR3 80
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#ifndef NETMASK_ADDR0
|
||||||
|
#define NETMASK_ADDR0 255
|
||||||
|
#define NETMASK_ADDR1 255
|
||||||
|
#define NETMASK_ADDR2 255
|
||||||
|
#define NETMASK_ADDR3 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#ifndef GW_ADDR0
|
||||||
|
#define GW_ADDR0 192
|
||||||
|
#define GW_ADDR1 168
|
||||||
|
#define GW_ADDR2 1
|
||||||
|
#define GW_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#ifndef AP_IP_ADDR0
|
||||||
|
#define AP_IP_ADDR0 192
|
||||||
|
#define AP_IP_ADDR1 168
|
||||||
|
#define AP_IP_ADDR2 43
|
||||||
|
#define AP_IP_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#ifndef AP_NETMASK_ADDR0
|
||||||
|
#define AP_NETMASK_ADDR0 255
|
||||||
|
#define AP_NETMASK_ADDR1 255
|
||||||
|
#define AP_NETMASK_ADDR2 255
|
||||||
|
#define AP_NETMASK_ADDR3 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#ifndef AP_GW_ADDR0
|
||||||
|
#define AP_GW_ADDR0 192
|
||||||
|
#define AP_GW_ADDR1 168
|
||||||
|
#define AP_GW_ADDR2 43
|
||||||
|
#define AP_GW_ADDR3 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* Private define ------------------------------------------------------------*/
|
||||||
|
#define MAX_DHCP_TRIES 5
|
||||||
|
|
||||||
|
/* Private macro -------------------------------------------------------------*/
|
||||||
|
/* Private variables ---------------------------------------------------------*/
|
||||||
|
|
||||||
|
struct netif xnetif[NET_IF_NUM]; /* network interface structure */
|
||||||
|
/* Private functions ---------------------------------------------------------*/
|
||||||
|
/**
|
||||||
|
* @brief Initializes the lwIP stack
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
|
||||||
|
extern int error_flag;
|
||||||
|
void LwIP_Init(void)
|
||||||
|
{
|
||||||
|
struct ip_addr ipaddr;
|
||||||
|
struct ip_addr netmask;
|
||||||
|
struct ip_addr gw;
|
||||||
|
int8_t idx = 0;
|
||||||
|
/* Create tcp_ip stack thread */
|
||||||
|
tcpip_init( NULL, NULL );
|
||||||
|
|
||||||
|
/* - netif_add(struct netif *netif, struct ip_addr *ipaddr,
|
||||||
|
struct ip_addr *netmask, struct ip_addr *gw,
|
||||||
|
void *state, err_t (* init)(struct netif *netif),
|
||||||
|
err_t (* input)(struct pbuf *p, struct netif *netif))
|
||||||
|
|
||||||
|
Adds your network interface to the netif_list. Allocate a struct
|
||||||
|
netif and pass a pointer to this structure as the first argument.
|
||||||
|
Give pointers to cleared ip_addr structures when using DHCP,
|
||||||
|
or fill them with sane numbers otherwise. The state pointer may be NULL.
|
||||||
|
|
||||||
|
The init function pointer must point to a initialization function for
|
||||||
|
your ethernet netif interface. The following code illustrates it's use.*/
|
||||||
|
//printf("NET_IF_NUM:%d\n\r",NET_IF_NUM);
|
||||||
|
for(idx=NET_IF_NUM - 1;idx>=0;idx--){
|
||||||
|
if(idx==0){
|
||||||
|
IP4_ADDR(&ipaddr, IP_ADDR0, IP_ADDR1, IP_ADDR2, IP_ADDR3);
|
||||||
|
IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1 , NETMASK_ADDR2, NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
IP4_ADDR(&ipaddr, AP_IP_ADDR0, AP_IP_ADDR1, AP_IP_ADDR2, AP_IP_ADDR3);
|
||||||
|
IP4_ADDR(&netmask, AP_NETMASK_ADDR0, AP_NETMASK_ADDR1 , AP_NETMASK_ADDR2, AP_NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, AP_GW_ADDR0, AP_GW_ADDR1, AP_GW_ADDR2, AP_GW_ADDR3);
|
||||||
|
}
|
||||||
|
xnetif[idx].name[0] = 'r';
|
||||||
|
xnetif[idx].name[1] = '0'+idx;
|
||||||
|
netif_add(&xnetif[idx], &ipaddr, &netmask, &gw, NULL, ðernetif_init, &tcpip_input);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Registers the default network interface. */
|
||||||
|
netif_set_default(&xnetif[0]);
|
||||||
|
|
||||||
|
/* When the netif is fully configured this function must be called.*/
|
||||||
|
for(idx = 0;idx < NET_IF_NUM;idx++)
|
||||||
|
netif_set_up(&xnetif[idx]);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief LwIP_DHCP_Process_Handle
|
||||||
|
* @param None
|
||||||
|
* @retval None
|
||||||
|
*/
|
||||||
|
uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state)
|
||||||
|
{
|
||||||
|
struct ip_addr ipaddr;
|
||||||
|
struct ip_addr netmask;
|
||||||
|
struct ip_addr gw;
|
||||||
|
uint32_t IPaddress;
|
||||||
|
uint8_t iptab[4];
|
||||||
|
uint8_t DHCP_state;
|
||||||
|
int mscnt = 0;
|
||||||
|
struct netif *pnetif = NULL;
|
||||||
|
|
||||||
|
DHCP_state = dhcp_state;
|
||||||
|
|
||||||
|
if(idx > 1)
|
||||||
|
idx = 1;
|
||||||
|
pnetif = &xnetif[idx];
|
||||||
|
if(DHCP_state == 0){
|
||||||
|
pnetif->ip_addr.addr = 0;
|
||||||
|
pnetif->netmask.addr = 0;
|
||||||
|
pnetif->gw.addr = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (;;)
|
||||||
|
{
|
||||||
|
//printf("\n\r ========DHCP_state:%d============\n\r",DHCP_state);
|
||||||
|
switch (DHCP_state)
|
||||||
|
{
|
||||||
|
case DHCP_START:
|
||||||
|
{
|
||||||
|
wifi_unreg_event_handler(WIFI_EVENT_BEACON_AFTER_DHCP, wifi_rx_beacon_hdl);
|
||||||
|
dhcp_start(pnetif);
|
||||||
|
IPaddress = 0;
|
||||||
|
DHCP_state = DHCP_WAIT_ADDRESS;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case DHCP_WAIT_ADDRESS:
|
||||||
|
{
|
||||||
|
/* Read the new IP address */
|
||||||
|
IPaddress = pnetif->ip_addr.addr;
|
||||||
|
|
||||||
|
if (IPaddress!=0)
|
||||||
|
{
|
||||||
|
DHCP_state = DHCP_ADDRESS_ASSIGNED;
|
||||||
|
|
||||||
|
wifi_reg_event_handler(WIFI_EVENT_BEACON_AFTER_DHCP, wifi_rx_beacon_hdl, NULL);
|
||||||
|
|
||||||
|
|
||||||
|
/* Stop DHCP */
|
||||||
|
dhcp_stop(pnetif);
|
||||||
|
|
||||||
|
iptab[0] = (uint8_t)(IPaddress >> 24);
|
||||||
|
iptab[1] = (uint8_t)(IPaddress >> 16);
|
||||||
|
iptab[2] = (uint8_t)(IPaddress >> 8);
|
||||||
|
iptab[3] = (uint8_t)(IPaddress);
|
||||||
|
printf("\n\rIP address : %d.%d.%d.%d", iptab[3], iptab[2], iptab[1], iptab[0]);
|
||||||
|
error_flag = RTW_NO_ERROR;
|
||||||
|
return DHCP_ADDRESS_ASSIGNED;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
/* DHCP timeout */
|
||||||
|
if (pnetif->dhcp->tries > MAX_DHCP_TRIES)
|
||||||
|
{
|
||||||
|
DHCP_state = DHCP_TIMEOUT;
|
||||||
|
|
||||||
|
/* Stop DHCP */
|
||||||
|
dhcp_stop(pnetif);
|
||||||
|
|
||||||
|
/* Static address used */
|
||||||
|
IP4_ADDR(&ipaddr, IP_ADDR0 ,IP_ADDR1 , IP_ADDR2 , IP_ADDR3 );
|
||||||
|
IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1, NETMASK_ADDR2, NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3);
|
||||||
|
netif_set_addr(pnetif, &ipaddr , &netmask, &gw);
|
||||||
|
|
||||||
|
iptab[0] = IP_ADDR3;
|
||||||
|
iptab[1] = IP_ADDR2;
|
||||||
|
iptab[2] = IP_ADDR1;
|
||||||
|
iptab[3] = IP_ADDR0;
|
||||||
|
printf("\n\rDHCP timeout");
|
||||||
|
printf("\n\rStatic IP address : %d.%d.%d.%d", iptab[3], iptab[2], iptab[1], iptab[0]);
|
||||||
|
error_flag = RTW_DHCP_FAIL;
|
||||||
|
return DHCP_TIMEOUT;
|
||||||
|
}else
|
||||||
|
{
|
||||||
|
//sys_msleep(DHCP_FINE_TIMER_MSECS);
|
||||||
|
vTaskDelay(DHCP_FINE_TIMER_MSECS);
|
||||||
|
dhcp_fine_tmr();
|
||||||
|
mscnt += DHCP_FINE_TIMER_MSECS;
|
||||||
|
if (mscnt >= DHCP_COARSE_TIMER_SECS*1000)
|
||||||
|
{
|
||||||
|
dhcp_coarse_tmr();
|
||||||
|
mscnt = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case DHCP_RELEASE_IP:
|
||||||
|
wifi_unreg_event_handler(WIFI_EVENT_BEACON_AFTER_DHCP, wifi_rx_beacon_hdl);
|
||||||
|
printf("\n\rLwIP_DHCP: Release ip");
|
||||||
|
dhcp_release_unicast(pnetif);
|
||||||
|
return DHCP_RELEASE_IP;
|
||||||
|
case DHCP_STOP:
|
||||||
|
wifi_unreg_event_handler(WIFI_EVENT_BEACON_AFTER_DHCP, wifi_rx_beacon_hdl);
|
||||||
|
printf("\n\rLwIP_DHCP: dhcp stop.");
|
||||||
|
dhcp_stop(pnetif);
|
||||||
|
return DHCP_STOP;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* LwIP_GetMAC(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
return (uint8_t *) (pnetif->hwaddr);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* LwIP_GetIP(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
return (uint8_t *) &(pnetif->ip_addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* LwIP_GetGW(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
return (uint8_t *) &(pnetif->gw);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* LwIP_GetMASK(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
return (uint8_t *) &(pnetif->netmask);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint8_t* LwIP_GetBC(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
return (uint8_t *) &(pnetif->dhcp->offered_bc_addr);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if LWIP_DNS
|
||||||
|
void LwIP_GetDNS(struct ip_addr* dns)
|
||||||
|
{
|
||||||
|
*dns = dns_getserver(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void LwIP_SetDNS(struct ip_addr* dns)
|
||||||
|
{
|
||||||
|
dns_setserver(0, dns);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
void LwIP_UseStaticIP(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
struct ip_addr ipaddr;
|
||||||
|
struct ip_addr netmask;
|
||||||
|
struct ip_addr gw;
|
||||||
|
|
||||||
|
/* Static address used */
|
||||||
|
if(pnetif->name[1] == '0'){
|
||||||
|
IP4_ADDR(&ipaddr, IP_ADDR0 ,IP_ADDR1 , IP_ADDR2 , IP_ADDR3 );
|
||||||
|
IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1, NETMASK_ADDR2, NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3);
|
||||||
|
}else{
|
||||||
|
IP4_ADDR(&ipaddr, AP_IP_ADDR0, AP_IP_ADDR1, AP_IP_ADDR2, AP_IP_ADDR3);
|
||||||
|
IP4_ADDR(&netmask, AP_NETMASK_ADDR0, AP_NETMASK_ADDR1 , AP_NETMASK_ADDR2, AP_NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, AP_GW_ADDR0, AP_GW_ADDR1, AP_GW_ADDR2, AP_GW_ADDR3);
|
||||||
|
}
|
||||||
|
|
||||||
|
netif_set_addr(pnetif, &ipaddr , &netmask, &gw);
|
||||||
|
}
|
||||||
|
#if LWIP_AUTOIP
|
||||||
|
#include <lwip/autoip.h>
|
||||||
|
|
||||||
|
void LwIP_AUTOIP(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
uint8_t *ip = LwIP_GetIP(pnetif);
|
||||||
|
|
||||||
|
autoip_start(pnetif);
|
||||||
|
|
||||||
|
while((pnetif->autoip->state == AUTOIP_STATE_PROBING) || (pnetif->autoip->state == AUTOIP_STATE_ANNOUNCING)) {
|
||||||
|
vTaskDelay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(*((uint32_t *) ip) == 0) {
|
||||||
|
struct ip_addr ipaddr;
|
||||||
|
struct ip_addr netmask;
|
||||||
|
struct ip_addr gw;
|
||||||
|
|
||||||
|
printf("AUTOIP timeout\n");
|
||||||
|
|
||||||
|
/* Static address used */
|
||||||
|
IP4_ADDR(&ipaddr, IP_ADDR0 ,IP_ADDR1 , IP_ADDR2 , IP_ADDR3 );
|
||||||
|
IP4_ADDR(&netmask, NETMASK_ADDR0, NETMASK_ADDR1, NETMASK_ADDR2, NETMASK_ADDR3);
|
||||||
|
IP4_ADDR(&gw, GW_ADDR0, GW_ADDR1, GW_ADDR2, GW_ADDR3);
|
||||||
|
netif_set_addr(pnetif, &ipaddr , &netmask, &gw);
|
||||||
|
printf("Static IP address : %d.%d.%d.%d\n", ip[0], ip[1], ip[2], ip[3]);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("\nLink-local address: %d.%d.%d.%d\n", ip[0], ip[1], ip[2], ip[3]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if LWIP_IPV6
|
||||||
|
/* Get IPv6 address with lwip 1.5.0 */
|
||||||
|
void LwIP_AUTOIP_IPv6(struct netif *pnetif)
|
||||||
|
{
|
||||||
|
uint8_t *ipv6 = (uint8_t *) &(pnetif->ip6_addr[0].addr[0]);
|
||||||
|
|
||||||
|
netif_create_ip6_linklocal_address(pnetif, 1);
|
||||||
|
printf("\nIPv6 link-local address: %02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x:%02x%02x\n",
|
||||||
|
ipv6[0], ipv6[1], ipv6[2], ipv6[3], ipv6[4], ipv6[5], ipv6[6], ipv6[7],
|
||||||
|
ipv6[8], ipv6[9], ipv6[10], ipv6[11], ipv6[12], ipv6[13], ipv6[14], ipv6[15]);
|
||||||
|
}
|
||||||
|
#endif
|
78
component/common/api/lwip_netconf.h
Executable file
78
component/common/api/lwip_netconf.h
Executable file
|
@ -0,0 +1,78 @@
|
||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file netconf.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.1.0
|
||||||
|
* @date 07-October-2011
|
||||||
|
* @brief This file contains all the functions prototypes for the netconf.c
|
||||||
|
* file.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __NETCONF_H
|
||||||
|
#define __NETCONF_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "tcpip.h"
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
/* Private typedef -----------------------------------------------------------*/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
DHCP_START=0,
|
||||||
|
DHCP_WAIT_ADDRESS,
|
||||||
|
DHCP_ADDRESS_ASSIGNED,
|
||||||
|
DHCP_RELEASE_IP,
|
||||||
|
DHCP_STOP,
|
||||||
|
DHCP_TIMEOUT
|
||||||
|
} DHCP_State_TypeDef;
|
||||||
|
|
||||||
|
/* Extern functions ------------------------------------------------------------*/
|
||||||
|
void wifi_rx_beacon_hdl( char* buf, int buf_len, int flags, void* userdata);
|
||||||
|
|
||||||
|
|
||||||
|
/* Exported types ------------------------------------------------------------*/
|
||||||
|
/* Exported constants --------------------------------------------------------*/
|
||||||
|
/* Exported macro ------------------------------------------------------------*/
|
||||||
|
/* Exported functions ------------------------------------------------------- */
|
||||||
|
void LwIP_Init(void);
|
||||||
|
uint8_t LwIP_DHCP(uint8_t idx, uint8_t dhcp_state);
|
||||||
|
unsigned char* LwIP_GetMAC(struct netif *pnetif);
|
||||||
|
unsigned char* LwIP_GetIP(struct netif *pnetif);
|
||||||
|
unsigned char* LwIP_GetGW(struct netif *pnetif);
|
||||||
|
uint8_t* LwIP_GetMASK(struct netif *pnetif);
|
||||||
|
uint8_t* LwIP_GetBC(struct netif *pnetif);
|
||||||
|
#if LWIP_DNS
|
||||||
|
void LwIP_GetDNS(struct ip_addr* dns);
|
||||||
|
void LwIP_SetDNS(struct ip_addr* dns);
|
||||||
|
#endif
|
||||||
|
void LwIP_UseStaticIP(struct netif *pnetif);
|
||||||
|
#if LWIP_AUTOIP
|
||||||
|
void LwIP_AUTOIP(struct netif *pnetif);
|
||||||
|
#endif
|
||||||
|
#if LWIP_IPV6
|
||||||
|
void LwIP_AUTOIP_IPv6(struct netif *pnetif);
|
||||||
|
#endif
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __NETCONF_H */
|
||||||
|
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
261
component/common/api/network/include/lwipopts.h
Executable file
261
component/common/api/network/include/lwipopts.h
Executable file
|
@ -0,0 +1,261 @@
|
||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file lwipopts.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.1.0
|
||||||
|
* @date 07-October-2011
|
||||||
|
* @brief lwIP Options Configuration.
|
||||||
|
* This file is based on Utilities\lwip_v1.3.2\src\include\lwip\opt.h
|
||||||
|
* and contains the lwIP configuration for the STM32F2x7 demonstration.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __LWIPOPTS_H__
|
||||||
|
#define __LWIPOPTS_H__
|
||||||
|
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* SYS_LIGHTWEIGHT_PROT==1: if you want inter-task protection for certain
|
||||||
|
* critical regions during buffer allocation, deallocation and memory
|
||||||
|
* allocation and deallocation.
|
||||||
|
*/
|
||||||
|
#define SYS_LIGHTWEIGHT_PROT 1
|
||||||
|
|
||||||
|
/* Define LWIP_COMPAT_MUTEX if the port has no mutexes and binary semaphores
|
||||||
|
should be used instead */
|
||||||
|
#define LWIP_COMPAT_MUTEX 1
|
||||||
|
|
||||||
|
#define ETHARP_TRUST_IP_MAC 0
|
||||||
|
#define IP_REASSEMBLY 1
|
||||||
|
#define IP_FRAG 1
|
||||||
|
#define ARP_QUEUEING 0
|
||||||
|
|
||||||
|
/**
|
||||||
|
* NO_SYS==1: Provides VERY minimal functionality. Otherwise,
|
||||||
|
* use lwIP facilities.
|
||||||
|
*/
|
||||||
|
#define NO_SYS 0
|
||||||
|
|
||||||
|
/* ---------- Memory options ---------- */
|
||||||
|
/* MEM_ALIGNMENT: should be set to the alignment of the CPU for which
|
||||||
|
lwIP is compiled. 4 byte alignment -> define MEM_ALIGNMENT to 4, 2
|
||||||
|
byte alignment -> define MEM_ALIGNMENT to 2. */
|
||||||
|
#define MEM_ALIGNMENT 4
|
||||||
|
|
||||||
|
/* MEM_SIZE: the size of the heap memory. If the application will send
|
||||||
|
a lot of data that needs to be copied, this should be set high. */
|
||||||
|
#define MEM_SIZE (5*1024)
|
||||||
|
|
||||||
|
/* MEMP_NUM_PBUF: the number of memp struct pbufs. If the application
|
||||||
|
sends a lot of data out of ROM (or other static memory), this
|
||||||
|
should be set high. */
|
||||||
|
#define MEMP_NUM_PBUF 100
|
||||||
|
/* MEMP_NUM_UDP_PCB: the number of UDP protocol control blocks. One
|
||||||
|
per active UDP "connection". */
|
||||||
|
#define MEMP_NUM_UDP_PCB 6
|
||||||
|
/* MEMP_NUM_TCP_PCB: the number of simulatenously active TCP
|
||||||
|
connections. */
|
||||||
|
#define MEMP_NUM_TCP_PCB 10
|
||||||
|
/* MEMP_NUM_TCP_PCB_LISTEN: the number of listening TCP
|
||||||
|
connections. */
|
||||||
|
#define MEMP_NUM_TCP_PCB_LISTEN 5
|
||||||
|
/* MEMP_NUM_TCP_SEG: the number of simultaneously queued TCP
|
||||||
|
segments. */
|
||||||
|
#define MEMP_NUM_TCP_SEG 20
|
||||||
|
/* MEMP_NUM_SYS_TIMEOUT: the number of simulateously active
|
||||||
|
timeouts. */
|
||||||
|
#define MEMP_NUM_SYS_TIMEOUT 10
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- Pbuf options ---------- */
|
||||||
|
/* PBUF_POOL_SIZE: the number of buffers in the pbuf pool. */
|
||||||
|
#define PBUF_POOL_SIZE 20
|
||||||
|
|
||||||
|
/* PBUF_POOL_BUFSIZE: the size of each pbuf in the pbuf pool. */
|
||||||
|
#define PBUF_POOL_BUFSIZE 500
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- TCP options ---------- */
|
||||||
|
#define LWIP_TCP 1
|
||||||
|
#define TCP_TTL 255
|
||||||
|
|
||||||
|
/* Controls if TCP should queue segments that arrive out of
|
||||||
|
order. Define to 0 if your device is low on memory. */
|
||||||
|
#define TCP_QUEUE_OOSEQ 1
|
||||||
|
|
||||||
|
/* TCP Maximum segment size. */
|
||||||
|
#define TCP_MSS (1500 - 40) /* TCP_MSS = (Ethernet MTU - IP header size - TCP header size) */
|
||||||
|
|
||||||
|
/* TCP sender buffer space (bytes). */
|
||||||
|
#define TCP_SND_BUF (5*TCP_MSS)
|
||||||
|
|
||||||
|
/* TCP_SND_QUEUELEN: TCP sender buffer space (pbufs). This must be at least
|
||||||
|
as much as (2 * TCP_SND_BUF/TCP_MSS) for things to work. */
|
||||||
|
|
||||||
|
#define TCP_SND_QUEUELEN (4* TCP_SND_BUF/TCP_MSS)
|
||||||
|
|
||||||
|
/* TCP receive window. */
|
||||||
|
#define TCP_WND (2*TCP_MSS)
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- ICMP options ---------- */
|
||||||
|
#define LWIP_ICMP 1
|
||||||
|
|
||||||
|
/* ---------- ARP options ----------- */
|
||||||
|
#define LWIP_ARP 1
|
||||||
|
|
||||||
|
/* ---------- DHCP options ---------- */
|
||||||
|
/* Define LWIP_DHCP to 1 if you want DHCP configuration of
|
||||||
|
interfaces. DHCP is not implemented in lwIP 0.5.1, however, so
|
||||||
|
turning this on does currently not work. */
|
||||||
|
#define LWIP_DHCP 1
|
||||||
|
|
||||||
|
|
||||||
|
/* ---------- UDP options ---------- */
|
||||||
|
#define LWIP_UDP 1
|
||||||
|
#define UDP_TTL 255
|
||||||
|
/* ---------- DNS options ---------- */
|
||||||
|
#define LWIP_DNS 1
|
||||||
|
|
||||||
|
/* ---------- UPNP options --------- */
|
||||||
|
#define LWIP_UPNP 0
|
||||||
|
|
||||||
|
/* Support Multicast */
|
||||||
|
#define LWIP_IGMP 1
|
||||||
|
#define LWIP_RAND() rand()
|
||||||
|
|
||||||
|
#define LWIP_UART_ADAPTER 0
|
||||||
|
|
||||||
|
#if LWIP_UART_ADAPTER
|
||||||
|
#undef LWIP_IGMP
|
||||||
|
#define LWIP_IGMP 1
|
||||||
|
|
||||||
|
#undef LWIP_SO_SNDTIMEO
|
||||||
|
#define LWIP_SO_SNDTIMEO 1
|
||||||
|
|
||||||
|
#undef SO_REUSE
|
||||||
|
#define SO_REUSE 1
|
||||||
|
|
||||||
|
#undef LWIP_TCP_KEEPALIVE
|
||||||
|
#define LWIP_TCP_KEEPALIVE 1
|
||||||
|
|
||||||
|
#undef MEMP_NUM_NETCONN
|
||||||
|
#define MEMP_NUM_NETCONN 10
|
||||||
|
|
||||||
|
#undef TCP_WND
|
||||||
|
#define TCP_WND (4*TCP_MSS)
|
||||||
|
|
||||||
|
#define TCP_KEEPIDLE_DEFAULT 10000UL
|
||||||
|
#define TCP_KEEPINTVL_DEFAULT 1000UL
|
||||||
|
#define TCP_KEEPCNT_DEFAULT 10U
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* ---------- Statistics options ---------- */
|
||||||
|
#define LWIP_STATS 0
|
||||||
|
#define LWIP_PROVIDE_ERRNO 1
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
--------------------------------------
|
||||||
|
---------- Checksum options ----------
|
||||||
|
--------------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
The STM32F2x7 allows computing and verifying the IP, UDP, TCP and ICMP checksums by hardware:
|
||||||
|
- To use this feature let the following define uncommented.
|
||||||
|
- To disable it and process by CPU comment the the checksum.
|
||||||
|
*/
|
||||||
|
//Do checksum by lwip - WLAN nic does not support Checksum offload
|
||||||
|
//#define CHECKSUM_BY_HARDWARE
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CHECKSUM_BY_HARDWARE
|
||||||
|
/* CHECKSUM_GEN_IP==0: Generate checksums by hardware for outgoing IP packets.*/
|
||||||
|
#define CHECKSUM_GEN_IP 0
|
||||||
|
/* CHECKSUM_GEN_UDP==0: Generate checksums by hardware for outgoing UDP packets.*/
|
||||||
|
#define CHECKSUM_GEN_UDP 0
|
||||||
|
/* CHECKSUM_GEN_TCP==0: Generate checksums by hardware for outgoing TCP packets.*/
|
||||||
|
#define CHECKSUM_GEN_TCP 0
|
||||||
|
/* CHECKSUM_CHECK_IP==0: Check checksums by hardware for incoming IP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_IP 0
|
||||||
|
/* CHECKSUM_CHECK_UDP==0: Check checksums by hardware for incoming UDP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_UDP 0
|
||||||
|
/* CHECKSUM_CHECK_TCP==0: Check checksums by hardware for incoming TCP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_TCP 0
|
||||||
|
#else
|
||||||
|
/* CHECKSUM_GEN_IP==1: Generate checksums in software for outgoing IP packets.*/
|
||||||
|
#define CHECKSUM_GEN_IP 1
|
||||||
|
/* CHECKSUM_GEN_UDP==1: Generate checksums in software for outgoing UDP packets.*/
|
||||||
|
#define CHECKSUM_GEN_UDP 1
|
||||||
|
/* CHECKSUM_GEN_TCP==1: Generate checksums in software for outgoing TCP packets.*/
|
||||||
|
#define CHECKSUM_GEN_TCP 1
|
||||||
|
/* CHECKSUM_CHECK_IP==1: Check checksums in software for incoming IP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_IP 1
|
||||||
|
/* CHECKSUM_CHECK_UDP==1: Check checksums in software for incoming UDP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_UDP 1
|
||||||
|
/* CHECKSUM_CHECK_TCP==1: Check checksums in software for incoming TCP packets.*/
|
||||||
|
#define CHECKSUM_CHECK_TCP 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
----------------------------------------------
|
||||||
|
---------- Sequential layer options ----------
|
||||||
|
----------------------------------------------
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* LWIP_NETCONN==1: Enable Netconn API (require to use api_lib.c)
|
||||||
|
*/
|
||||||
|
#define LWIP_NETCONN 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
------------------------------------
|
||||||
|
---------- Socket options ----------
|
||||||
|
------------------------------------
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* LWIP_SOCKET==1: Enable Socket API (require to use sockets.c)
|
||||||
|
*/
|
||||||
|
#define LWIP_SOCKET 1
|
||||||
|
|
||||||
|
/*
|
||||||
|
-----------------------------------
|
||||||
|
---------- DEBUG options ----------
|
||||||
|
-----------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define LWIP_DEBUG 0
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
---------------------------------
|
||||||
|
---------- OS options ----------
|
||||||
|
---------------------------------
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define TCPIP_THREAD_STACKSIZE 1000
|
||||||
|
#define TCPIP_MBOX_SIZE 5
|
||||||
|
#define DEFAULT_UDP_RECVMBOX_SIZE 2000
|
||||||
|
#define DEFAULT_TCP_RECVMBOX_SIZE 2000
|
||||||
|
#define DEFAULT_ACCEPTMBOX_SIZE 2000
|
||||||
|
#define DEFAULT_THREAD_STACKSIZE 500
|
||||||
|
#define TCPIP_THREAD_PRIO (configMAX_PRIORITIES - 2)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* __LWIPOPTS_H__ */
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
68
component/common/api/network/include/main.h
Executable file
68
component/common/api/network/include/main.h
Executable file
|
@ -0,0 +1,68 @@
|
||||||
|
#ifndef MAIN_H
|
||||||
|
#define MAIN_H
|
||||||
|
|
||||||
|
#include <autoconf.h>
|
||||||
|
|
||||||
|
#define CONFIG_WLAN 1
|
||||||
|
|
||||||
|
|
||||||
|
/* Header file declaration*/
|
||||||
|
void wlan_network();
|
||||||
|
|
||||||
|
|
||||||
|
/* Interactive Mode */
|
||||||
|
#define SERIAL_DEBUG_RX 1
|
||||||
|
#if defined(__ICCARM__)
|
||||||
|
static
|
||||||
|
#endif
|
||||||
|
char uart_buf[64];
|
||||||
|
|
||||||
|
|
||||||
|
/* WLAN and Netork */
|
||||||
|
#define STA_MODE_SSID "ap" /* Set SSID here */
|
||||||
|
#define AP_MODE_SSID "wlan_ap_ssid" /* Set SSID here */
|
||||||
|
#define AP_DEFAULT_CH 6
|
||||||
|
#define WLAN0_NAME "wlan0"
|
||||||
|
#define WLAN1_NAME "wlan1"
|
||||||
|
#define WPA_PASSPHRASE "1234567890" /* Max 32 cahracters */
|
||||||
|
#define WEP40_KEY {0x12, 0x34, 0x56, 0x78, 0x90}
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#define IP_ADDR0 192
|
||||||
|
#define IP_ADDR1 168
|
||||||
|
#define IP_ADDR2 1
|
||||||
|
#define IP_ADDR3 80
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#define NETMASK_ADDR0 255
|
||||||
|
#define NETMASK_ADDR1 255
|
||||||
|
#define NETMASK_ADDR2 255
|
||||||
|
#define NETMASK_ADDR3 0
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#define GW_ADDR0 192
|
||||||
|
#define GW_ADDR1 168
|
||||||
|
#define GW_ADDR2 1
|
||||||
|
#define GW_ADDR3 1
|
||||||
|
|
||||||
|
/*******************************************/
|
||||||
|
|
||||||
|
/*Static IP ADDRESS*/
|
||||||
|
#define AP_IP_ADDR0 192
|
||||||
|
#define AP_IP_ADDR1 168
|
||||||
|
#define AP_IP_ADDR2 43
|
||||||
|
#define AP_IP_ADDR3 1
|
||||||
|
|
||||||
|
/*NETMASK*/
|
||||||
|
#define AP_NETMASK_ADDR0 255
|
||||||
|
#define AP_NETMASK_ADDR1 255
|
||||||
|
#define AP_NETMASK_ADDR2 255
|
||||||
|
#define AP_NETMASK_ADDR3 0
|
||||||
|
|
||||||
|
/*Gateway Address*/
|
||||||
|
#define AP_GW_ADDR0 192
|
||||||
|
#define AP_GW_ADDR1 168
|
||||||
|
#define AP_GW_ADDR2 43
|
||||||
|
#define AP_GW_ADDR3 1
|
||||||
|
|
||||||
|
#endif
|
21
component/common/api/network/include/main_test.h
Executable file
21
component/common/api/network/include/main_test.h
Executable file
|
@ -0,0 +1,21 @@
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
#ifndef __MAIN_TEST_H
|
||||||
|
#define __MAIN_TEST_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Exported test functions ------------------------------------------------------- */
|
||||||
|
void do_ping_test(char *ip, int size, int count, int interval);
|
||||||
|
void do_ping_call(char *ip, int loop, int count);
|
||||||
|
void interactive_question(char *question, char *choice, char *buf, int buf_size);
|
||||||
|
void start_interactive_mode(void);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __MAIN_TEST_H
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
50
component/common/api/network/include/netconf.h
Executable file
50
component/common/api/network/include/netconf.h
Executable file
|
@ -0,0 +1,50 @@
|
||||||
|
/**
|
||||||
|
******************************************************************************
|
||||||
|
* @file netconf.h
|
||||||
|
* @author MCD Application Team
|
||||||
|
* @version V1.1.0
|
||||||
|
* @date 07-October-2011
|
||||||
|
* @brief This file contains all the functions prototypes for the netconf.c
|
||||||
|
* file.
|
||||||
|
******************************************************************************
|
||||||
|
* @attention
|
||||||
|
*
|
||||||
|
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
|
||||||
|
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
|
||||||
|
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
|
||||||
|
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
|
||||||
|
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
|
||||||
|
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
|
||||||
|
*
|
||||||
|
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
|
||||||
|
******************************************************************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* Define to prevent recursive inclusion -------------------------------------*/
|
||||||
|
#ifndef __NETCONF_H
|
||||||
|
#define __NETCONF_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// TODO: remove this file
|
||||||
|
#include "lwip_netconf.h"
|
||||||
|
#if 0
|
||||||
|
/* Includes ------------------------------------------------------------------*/
|
||||||
|
#include "main.h"
|
||||||
|
/* Exported types ------------------------------------------------------------*/
|
||||||
|
/* Exported constants --------------------------------------------------------*/
|
||||||
|
/* Exported macro ------------------------------------------------------------*/
|
||||||
|
/* Exported functions ------------------------------------------------------- */
|
||||||
|
void LwIP_Init(void);
|
||||||
|
void LwIP_DHCP(void);
|
||||||
|
#endif
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __NETCONF_H */
|
||||||
|
|
||||||
|
|
||||||
|
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
|
8
component/common/api/network/include/rtl8195a_it.h
Executable file
8
component/common/api/network/include/rtl8195a_it.h
Executable file
|
@ -0,0 +1,8 @@
|
||||||
|
|
||||||
|
#ifndef __RTL8195A_IT_H_
|
||||||
|
#define __RTL8195A_IT_H_
|
||||||
|
|
||||||
|
|
||||||
|
int irq_alloc_wlan(void *contex);
|
||||||
|
|
||||||
|
#endif //__RTL8195A_IT_H_
|
46
component/common/api/network/include/util.h
Executable file
46
component/common/api/network/include/util.h
Executable file
|
@ -0,0 +1,46 @@
|
||||||
|
#ifndef _UTIL_H
|
||||||
|
#define _UTIL_H
|
||||||
|
|
||||||
|
#include <wireless.h>
|
||||||
|
#include <wlan_intf.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "wifi_util.h"
|
||||||
|
#if 0
|
||||||
|
typedef enum _WIFI_EVENT_INDICATE{
|
||||||
|
WIFI_EVENT_CONNECT = 0,
|
||||||
|
WIFI_EVENT_DISCONNECT = 1,
|
||||||
|
WIFI_EVENT_FOURWAY_HANDSHAKE_DONE = 2,
|
||||||
|
}WIFI_EVENT_INDICATE;
|
||||||
|
|
||||||
|
int wext_get_ssid(const char *ifname, __u8 *ssid);
|
||||||
|
int wext_set_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len);
|
||||||
|
int wext_set_auth_param(const char *ifname, __u16 idx, __u32 value);
|
||||||
|
int wext_set_key_ext(const char *ifname, __u16 alg, const __u8 *addr, int key_idx, int set_tx, const __u8 *seq, __u16 seq_len, __u8 *key, __u16 key_len);
|
||||||
|
int wext_get_enc_ext(const char *ifname, __u16 *alg);
|
||||||
|
int wext_set_passphrase(const char *ifname, const __u8 *passphrase, __u16 passphrase_len);
|
||||||
|
int wext_get_passphrase(const char *ifname, __u8 *passphrase);
|
||||||
|
int wext_set_mode(const char *ifname, int mode);
|
||||||
|
int wext_get_mode(const char *ifname, int *mode);
|
||||||
|
int wext_set_ap_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len);
|
||||||
|
int wext_set_country(const char *ifname, char *country_code);
|
||||||
|
int wext_get_rssi(const char *ifname, int *rssi);
|
||||||
|
int wext_set_channel(const char *ifname, __u8 ch);
|
||||||
|
int wext_get_channel(const char *ifname, __u8 *ch);
|
||||||
|
int wext_set_scan(const char *ifname, char *buf, __u16 buf_len);
|
||||||
|
int wext_get_scan(const char *ifname, char *buf, __u16 buf_len);
|
||||||
|
int wext_mp_command(const char *ifname, char *cmd, int show_msg);
|
||||||
|
int wext_wifi_priv(const char *ifname, int argc, char **argv);
|
||||||
|
void wext_wlan_indicate(unsigned int cmd, union iwreq_data *wrqu, char *extra);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define wext_handshake_done rltk_wlan_handshake_done
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _UTIL_H */
|
136
component/common/api/network/src/ping_test.c
Executable file
136
component/common/api/network/src/ping_test.c
Executable file
|
@ -0,0 +1,136 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "main.h"
|
||||||
|
|
||||||
|
#include <lwip/sockets.h>
|
||||||
|
#include <lwip/raw.h>
|
||||||
|
#include <lwip/icmp.h>
|
||||||
|
#include <lwip/inet_chksum.h>
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
#include "diag.h"
|
||||||
|
|
||||||
|
//#define PING_IP "192.168.0.1"
|
||||||
|
#define PING_IP "192.168.159.1"
|
||||||
|
#define PING_TO 1000
|
||||||
|
#define PING_ID 0xABCD
|
||||||
|
#define BUF_SIZE 200
|
||||||
|
#define STACKSIZE 1024
|
||||||
|
|
||||||
|
static unsigned short ping_seq = 0;
|
||||||
|
static int infinite_loop, ping_count, data_size, ping_interval, ping_call;
|
||||||
|
static char ping_ip[16];
|
||||||
|
|
||||||
|
static void generate_ping_echo(unsigned char *buf, int size)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct icmp_echo_hdr *pecho;
|
||||||
|
|
||||||
|
for(i = 0; i < size; i ++) {
|
||||||
|
buf[sizeof(struct icmp_echo_hdr) + i] = (unsigned char) i;
|
||||||
|
}
|
||||||
|
|
||||||
|
pecho = (struct icmp_echo_hdr *) buf;
|
||||||
|
ICMPH_TYPE_SET(pecho, ICMP_ECHO);
|
||||||
|
ICMPH_CODE_SET(pecho, 0);
|
||||||
|
pecho->chksum = 0;
|
||||||
|
pecho->id = PING_ID;
|
||||||
|
pecho->seqno = htons(++ ping_seq);
|
||||||
|
|
||||||
|
//Checksum includes icmp header and data. Need to calculate after fill up icmp header
|
||||||
|
pecho->chksum = inet_chksum(pecho, sizeof(struct icmp_echo_hdr) + size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void ping_test(void *param)
|
||||||
|
//void ping_test()
|
||||||
|
{
|
||||||
|
int i, ping_socket;
|
||||||
|
int pint_timeout = PING_TO;
|
||||||
|
struct sockaddr_in to_addr, from_addr;
|
||||||
|
int from_addr_len;
|
||||||
|
int ping_size, reply_size;
|
||||||
|
unsigned char ping_buf[BUF_SIZE], reply_buf[BUF_SIZE];
|
||||||
|
unsigned int ping_time, reply_time;
|
||||||
|
struct ip_hdr *iphdr;
|
||||||
|
struct icmp_echo_hdr *pecho;
|
||||||
|
|
||||||
|
//Ping size = icmp header(8 bytes) + data size
|
||||||
|
ping_size = sizeof(struct icmp_echo_hdr) + data_size;
|
||||||
|
printf("\n\r[%s] PING %s %d(%d) bytes of data\n", __FUNCTION__, ping_ip, data_size, sizeof(struct ip_hdr) + sizeof(struct icmp_echo_hdr) + data_size);
|
||||||
|
|
||||||
|
for(i = 0; (i < ping_count) || (infinite_loop == 1); i ++) {
|
||||||
|
ping_socket = socket(AF_INET, SOCK_RAW, IP_PROTO_ICMP);
|
||||||
|
setsockopt(ping_socket, SOL_SOCKET, SO_RCVTIMEO, &pint_timeout, sizeof(pint_timeout));
|
||||||
|
|
||||||
|
to_addr.sin_len = sizeof(to_addr);
|
||||||
|
to_addr.sin_family = AF_INET;
|
||||||
|
to_addr.sin_addr.s_addr = inet_addr(ping_ip);
|
||||||
|
|
||||||
|
generate_ping_echo(ping_buf, data_size);
|
||||||
|
sendto(ping_socket, ping_buf, ping_size, 0, (struct sockaddr *) &to_addr, sizeof(to_addr));
|
||||||
|
|
||||||
|
ping_time = xTaskGetTickCount();
|
||||||
|
if((reply_size = recvfrom(ping_socket, reply_buf, sizeof(reply_buf), 0, (struct sockaddr *) &from_addr, (socklen_t *) &from_addr_len))
|
||||||
|
>= (int)(sizeof(struct ip_hdr) + sizeof(struct icmp_echo_hdr))) {
|
||||||
|
|
||||||
|
reply_time = xTaskGetTickCount();
|
||||||
|
iphdr = (struct ip_hdr *)reply_buf;
|
||||||
|
pecho = (struct icmp_echo_hdr *)(reply_buf + (IPH_HL(iphdr) * 4));
|
||||||
|
|
||||||
|
if((pecho->id == PING_ID) && (pecho->seqno == htons(ping_seq))) {
|
||||||
|
printf("\n\r[%s] %d bytes from %s: icmp_seq=%d time=%d ms", __FUNCTION__, reply_size - sizeof(struct ip_hdr), inet_ntoa(from_addr.sin_addr), htons(pecho->seqno), (reply_time - ping_time) * portTICK_RATE_MS);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\n\r[%s] Request timeout for icmp_seq %d\n", __FUNCTION__, ping_seq);
|
||||||
|
|
||||||
|
close(ping_socket);
|
||||||
|
vTaskDelay(ping_interval * configTICK_RATE_HZ);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!ping_call)
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_ping_call(char *ip, int loop, int count)
|
||||||
|
{
|
||||||
|
ping_call = 1;
|
||||||
|
ping_seq = 0;
|
||||||
|
data_size = 120;
|
||||||
|
ping_interval = 1;
|
||||||
|
infinite_loop = loop;
|
||||||
|
ping_count = count;
|
||||||
|
strcpy(ping_ip, ip);
|
||||||
|
|
||||||
|
ping_test(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_ping_test(char *ip, int size, int count, int interval)
|
||||||
|
{
|
||||||
|
if((sizeof(struct icmp_echo_hdr) + size) > BUF_SIZE) {
|
||||||
|
printf("\n\r%s BUF_SIZE(%d) is too small", __FUNCTION__, BUF_SIZE);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(ip == NULL)
|
||||||
|
strcpy(ping_ip, PING_IP);
|
||||||
|
else
|
||||||
|
strcpy(ping_ip, ip);
|
||||||
|
|
||||||
|
ping_call = 0;
|
||||||
|
ping_seq = 0;
|
||||||
|
data_size = size;
|
||||||
|
ping_interval = interval;
|
||||||
|
|
||||||
|
if(count == 0) {
|
||||||
|
infinite_loop = 1;
|
||||||
|
ping_count = 0;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
infinite_loop = 0;
|
||||||
|
ping_count = count;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(xTaskCreate(ping_test, ((const signed char*)"ping_test"), STACKSIZE, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate failed", __FUNCTION__);
|
||||||
|
}
|
110
component/common/api/network/src/rtl8195a_it.c
Executable file
110
component/common/api/network/src/rtl8195a_it.c
Executable file
|
@ -0,0 +1,110 @@
|
||||||
|
#include "rtl8195a.h"
|
||||||
|
#include <main.h>
|
||||||
|
#include "rtl8195a_it.h"
|
||||||
|
|
||||||
|
/* os dependent*/
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "queue.h"
|
||||||
|
#include "semphr.h"
|
||||||
|
|
||||||
|
|
||||||
|
#include <diag.h>
|
||||||
|
#define printf DiagPrintf
|
||||||
|
|
||||||
|
/*-----------------------------Global Variable ---------------------*/
|
||||||
|
//#ifdef CONFIG_WLAN
|
||||||
|
//#ifdef CONFIG_ISR_THREAD_MODE_INTERRUPT
|
||||||
|
extern xSemaphoreHandle *pExportWlanIrqSemaphore;
|
||||||
|
//#endif
|
||||||
|
//#endif
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_WLAN
|
||||||
|
#ifdef CONFIG_ISR_THREAD_MODE_INTERRUPT
|
||||||
|
|
||||||
|
//TODO: chris
|
||||||
|
#define IRQ_HANDLED 1
|
||||||
|
#define IRQ_NONE 0
|
||||||
|
|
||||||
|
int wlan_Interrupt (
|
||||||
|
IN VOID* Data
|
||||||
|
)
|
||||||
|
{
|
||||||
|
#if 1
|
||||||
|
|
||||||
|
portBASE_TYPE xHigherPriorityTaskWoken = pdFALSE;
|
||||||
|
|
||||||
|
printf("wlan interrupt\n");
|
||||||
|
/* This semaphore is initialized once wlan interrupt handler thread is created and initialized*/
|
||||||
|
if(!pExportWlanIrqSemaphore)
|
||||||
|
{
|
||||||
|
printf("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
xSemaphoreGiveFromISR( *pExportWlanIrqSemaphore, &xHigherPriorityTaskWoken );
|
||||||
|
|
||||||
|
printf("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
/* Switch tasks if necessary. */
|
||||||
|
if( xHigherPriorityTaskWoken != pdFALSE )
|
||||||
|
{
|
||||||
|
printf("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
portEND_SWITCHING_ISR( xHigherPriorityTaskWoken );
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
#else
|
||||||
|
struct dvobj_priv *dvobj = (struct dvobj_priv *)Data;
|
||||||
|
_adapter *adapter = dvobj->if1;
|
||||||
|
DBG_8192C("Dma isr\n");
|
||||||
|
|
||||||
|
if (dvobj->irq_enabled == 0) {
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
}
|
||||||
|
DBG_871X("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
if(rtw_hal_interrupt_handler(adapter) == _FAIL)
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
//return IRQ_NONE;
|
||||||
|
DBG_871X("%s(%d)\n", __FUNCTION__, __LINE__);
|
||||||
|
return IRQ_HANDLED;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
VOID
|
||||||
|
lextra_bus_dma_Interrupt (
|
||||||
|
IN VOID* Data
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This function register interrupt handler and is called by wlan driver
|
||||||
|
* Return 0 if success, Others if fail
|
||||||
|
*/
|
||||||
|
|
||||||
|
int irq_alloc_wlan(void *contex)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
IRQ_HANDLE IrqHandle = {0};
|
||||||
|
|
||||||
|
printf("Register Interrupt\n");
|
||||||
|
IrqHandle.Data = (u32) (contex);
|
||||||
|
IrqHandle.IrqNum = WL_DMA_IRQ;
|
||||||
|
IrqHandle.IrqFun = (IRQ_FUN)wlan_Interrupt;
|
||||||
|
//IrqHandle.IrqFun = (IRQ_FUN)lextra_bus_dma_Interrupt;
|
||||||
|
IrqHandle.Priority = 0;
|
||||||
|
|
||||||
|
InterruptRegister(&IrqHandle);
|
||||||
|
InterruptEn(&IrqHandle);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
68
component/common/api/network/src/wlan_network.c
Executable file
68
component/common/api/network/src/wlan_network.c
Executable file
|
@ -0,0 +1,68 @@
|
||||||
|
/*
|
||||||
|
* Hello World
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 Realtek Semiconductor Corp.
|
||||||
|
*
|
||||||
|
* This module is a confidential and proprietary property of RealTek and
|
||||||
|
* possession or use of this module requires written permission of RealTek.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "semphr.h"
|
||||||
|
|
||||||
|
#include "main.h"
|
||||||
|
#include "main_test.h"
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#include "wlan_intf.h"
|
||||||
|
#include "lwip_netconf.h"
|
||||||
|
#include "wifi_constants.h"
|
||||||
|
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
#ifndef CONFIG_INIT_NET
|
||||||
|
#define CONFIG_INIT_NET 1
|
||||||
|
#endif
|
||||||
|
#ifndef CONFIG_INTERACTIVE_MODE
|
||||||
|
#define CONFIG_INTERACTIVE_MODE 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define STACKSIZE (512 + 768)
|
||||||
|
|
||||||
|
xSemaphoreHandle uart_rx_interrupt_sema = NULL;
|
||||||
|
|
||||||
|
void init_thread(void *param)
|
||||||
|
{
|
||||||
|
|
||||||
|
#if CONFIG_INIT_NET
|
||||||
|
#if CONFIG_LWIP_LAYER
|
||||||
|
/* Initilaize the LwIP stack */
|
||||||
|
LwIP_Init();
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
wifi_on(RTW_MODE_STA);
|
||||||
|
#if CONFIG_AUTO_RECONNECT
|
||||||
|
//setup reconnection flag
|
||||||
|
wifi_set_autoreconnect(1);
|
||||||
|
#endif
|
||||||
|
printf("\n\r%s(%d), Available heap 0x%x", __FUNCTION__, __LINE__, xPortGetFreeHeapSize());
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_INTERACTIVE_MODE
|
||||||
|
/* Initial uart rx swmaphore*/
|
||||||
|
vSemaphoreCreateBinary(uart_rx_interrupt_sema);
|
||||||
|
xSemaphoreTake(uart_rx_interrupt_sema, 1/portTICK_RATE_MS);
|
||||||
|
start_interactive_mode();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Kill init thread after all init tasks done */
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wlan_network()
|
||||||
|
{
|
||||||
|
if(xTaskCreate(init_thread, ((const char*)"init"), STACKSIZE, NULL, tskIDLE_PRIORITY + 3 + PRIORITIE_OFFSET, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate(init_thread) failed", __FUNCTION__);
|
||||||
|
}
|
262
component/common/api/platform/dlist.h
Executable file
262
component/common/api/platform/dlist.h
Executable file
|
@ -0,0 +1,262 @@
|
||||||
|
#ifndef __LIST_H
|
||||||
|
#define __LIST_H
|
||||||
|
|
||||||
|
#if defined ( __CC_ARM )
|
||||||
|
#ifndef inline
|
||||||
|
#define inline __inline
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This file is from Linux Kernel (include/linux/list.h)
|
||||||
|
* and modified by simply removing hardware prefetching of list items.
|
||||||
|
* Here by copyright, credits attributed to wherever they belong.
|
||||||
|
* Kulesh Shanmugasundaram (kulesh [squiggly] isis.poly.edu)
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Simple doubly linked list implementation.
|
||||||
|
*
|
||||||
|
* Some of the internal functions ("__xxx") are useful when
|
||||||
|
* manipulating whole lists rather than single entries, as
|
||||||
|
* sometimes we already know the next/prev entries and we can
|
||||||
|
* generate better code by using them directly rather than
|
||||||
|
* using the generic single-entry routines.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct list_head {
|
||||||
|
struct list_head *next, *prev;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define LIST_HEAD_INIT(name) { &(name), &(name) }
|
||||||
|
|
||||||
|
#define LIST_HEAD(name) \
|
||||||
|
struct list_head name = LIST_HEAD_INIT(name)
|
||||||
|
|
||||||
|
#define INIT_LIST_HEAD(ptr) do { \
|
||||||
|
(ptr)->next = (ptr); (ptr)->prev = (ptr); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Insert a new entry between two known consecutive entries.
|
||||||
|
*
|
||||||
|
* This is only for internal list manipulation where we know
|
||||||
|
* the prev/next entries already!
|
||||||
|
*/
|
||||||
|
static inline void __list_add(struct list_head *new,
|
||||||
|
struct list_head *prev,
|
||||||
|
struct list_head *next)
|
||||||
|
{
|
||||||
|
next->prev = new;
|
||||||
|
new->next = next;
|
||||||
|
new->prev = prev;
|
||||||
|
prev->next = new;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_add - add a new entry
|
||||||
|
* @new: new entry to be added
|
||||||
|
* @head: list head to add it after
|
||||||
|
*
|
||||||
|
* Insert a new entry after the specified head.
|
||||||
|
* This is good for implementing stacks.
|
||||||
|
*/
|
||||||
|
static inline void list_add(struct list_head *new, struct list_head *head)
|
||||||
|
{
|
||||||
|
__list_add(new, head, head->next);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_add_tail - add a new entry
|
||||||
|
* @new: new entry to be added
|
||||||
|
* @head: list head to add it before
|
||||||
|
*
|
||||||
|
* Insert a new entry before the specified head.
|
||||||
|
* This is useful for implementing queues.
|
||||||
|
*/
|
||||||
|
static inline void list_add_tail(struct list_head *new, struct list_head *head)
|
||||||
|
{
|
||||||
|
__list_add(new, head->prev, head);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Delete a list entry by making the prev/next entries
|
||||||
|
* point to each other.
|
||||||
|
*
|
||||||
|
* This is only for internal list manipulation where we know
|
||||||
|
* the prev/next entries already!
|
||||||
|
*/
|
||||||
|
static inline void __list_del(struct list_head *prev, struct list_head *next)
|
||||||
|
{
|
||||||
|
next->prev = prev;
|
||||||
|
prev->next = next;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_del - deletes entry from list.
|
||||||
|
* @entry: the element to delete from the list.
|
||||||
|
* Note: list_empty on entry does not return true after this, the entry is in an undefined state.
|
||||||
|
*/
|
||||||
|
static inline void list_del(struct list_head *entry)
|
||||||
|
{
|
||||||
|
__list_del(entry->prev, entry->next);
|
||||||
|
entry->next = (void *) 0;
|
||||||
|
entry->prev = (void *) 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_del_init - deletes entry from list and reinitialize it.
|
||||||
|
* @entry: the element to delete from the list.
|
||||||
|
*/
|
||||||
|
static inline void list_del_init(struct list_head *entry)
|
||||||
|
{
|
||||||
|
__list_del(entry->prev, entry->next);
|
||||||
|
INIT_LIST_HEAD(entry);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_move - delete from one list and add as another's head
|
||||||
|
* @list: the entry to move
|
||||||
|
* @head: the head that will precede our entry
|
||||||
|
*/
|
||||||
|
static inline void list_move(struct list_head *list, struct list_head *head)
|
||||||
|
{
|
||||||
|
__list_del(list->prev, list->next);
|
||||||
|
list_add(list, head);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_move_tail - delete from one list and add as another's tail
|
||||||
|
* @list: the entry to move
|
||||||
|
* @head: the head that will follow our entry
|
||||||
|
*/
|
||||||
|
static inline void list_move_tail(struct list_head *list,
|
||||||
|
struct list_head *head)
|
||||||
|
{
|
||||||
|
__list_del(list->prev, list->next);
|
||||||
|
list_add_tail(list, head);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_empty - tests whether a list is empty
|
||||||
|
* @head: the list to test.
|
||||||
|
*/
|
||||||
|
static inline int list_empty(struct list_head *head)
|
||||||
|
{
|
||||||
|
return head->next == head;
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void __list_splice(struct list_head *list,
|
||||||
|
struct list_head *head)
|
||||||
|
{
|
||||||
|
struct list_head *first = list->next;
|
||||||
|
struct list_head *last = list->prev;
|
||||||
|
struct list_head *at = head->next;
|
||||||
|
|
||||||
|
first->prev = head;
|
||||||
|
head->next = first;
|
||||||
|
|
||||||
|
last->next = at;
|
||||||
|
at->prev = last;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_splice - join two lists
|
||||||
|
* @list: the new list to add.
|
||||||
|
* @head: the place to add it in the first list.
|
||||||
|
*/
|
||||||
|
static inline void list_splice(struct list_head *list, struct list_head *head)
|
||||||
|
{
|
||||||
|
if (!list_empty(list))
|
||||||
|
__list_splice(list, head);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_splice_init - join two lists and reinitialise the emptied list.
|
||||||
|
* @list: the new list to add.
|
||||||
|
* @head: the place to add it in the first list.
|
||||||
|
*
|
||||||
|
* The list at @list is reinitialised
|
||||||
|
*/
|
||||||
|
static inline void list_splice_init(struct list_head *list,
|
||||||
|
struct list_head *head)
|
||||||
|
{
|
||||||
|
if (!list_empty(list)) {
|
||||||
|
__list_splice(list, head);
|
||||||
|
INIT_LIST_HEAD(list);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_entry - get the struct for this entry
|
||||||
|
* @ptr: the &struct list_head pointer.
|
||||||
|
* @type: the type of the struct this is embedded in.
|
||||||
|
* @member: the name of the list_struct within the struct.
|
||||||
|
*/
|
||||||
|
#define list_entry(ptr, type, member) \
|
||||||
|
((type *)((char *)(ptr)-(unsigned long)(&((type *)0)->member)))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_first_entry - get the first element from a list
|
||||||
|
* @ptr: the list head to take the element from.
|
||||||
|
* @type: the type of the struct this is embedded in.
|
||||||
|
* @member: the name of the list_head within the struct.
|
||||||
|
*
|
||||||
|
* Note, that list is expected to be not empty.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define list_first_entry(ptr, type, member) \
|
||||||
|
list_entry((ptr)->next, type, member)
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_for_each - iterate over a list
|
||||||
|
* @pos: the &struct list_head to use as a loop counter.
|
||||||
|
* @head: the head for your list.
|
||||||
|
*/
|
||||||
|
#define list_for_each(pos, head) \
|
||||||
|
for (pos = (head)->next; pos != (head); \
|
||||||
|
pos = pos->next)
|
||||||
|
/**
|
||||||
|
* list_for_each_prev - iterate over a list backwards
|
||||||
|
* @pos: the &struct list_head to use as a loop counter.
|
||||||
|
* @head: the head for your list.
|
||||||
|
*/
|
||||||
|
#define list_for_each_prev(pos, head) \
|
||||||
|
for (pos = (head)->prev; pos != (head); \
|
||||||
|
pos = pos->prev)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_for_each_safe - iterate over a list safe against removal of list entry
|
||||||
|
* @pos: the &struct list_head to use as a loop counter.
|
||||||
|
* @n: another &struct list_head to use as temporary storage
|
||||||
|
* @head: the head for your list.
|
||||||
|
*/
|
||||||
|
#define list_for_each_safe(pos, n, head) \
|
||||||
|
for (pos = (head)->next, n = pos->next; pos != (head); \
|
||||||
|
pos = n, n = pos->next)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_for_each_entry - iterate over list of given type
|
||||||
|
* @pos: the type * to use as a loop counter.
|
||||||
|
* @head: the head for your list.
|
||||||
|
* @member: the name of the list_struct within the struct.
|
||||||
|
*/
|
||||||
|
#define list_for_each_entry(pos, head, member, type) \
|
||||||
|
for (pos = list_entry((head)->next, type, member); \
|
||||||
|
&pos->member != (head); \
|
||||||
|
pos = list_entry(pos->member.next, type, member))
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_for_each_entry_safe - iterate over list of given type safe against removal of list entry
|
||||||
|
* @pos: the type * to use as a loop counter.
|
||||||
|
* @n: another type * to use as temporary storage
|
||||||
|
* @head: the head for your list.
|
||||||
|
* @member: the name of the list_struct within the struct.
|
||||||
|
*/
|
||||||
|
#define list_for_each_entry_safe(pos, n, head, member, type) \
|
||||||
|
for (pos = list_entry((head)->next, type, member), \
|
||||||
|
n = list_entry(pos->member.next, type, member); \
|
||||||
|
&pos->member != (head); \
|
||||||
|
pos = n, n = list_entry(n->member.next, type, member))
|
||||||
|
|
||||||
|
#endif
|
145
component/common/api/platform/platform_stdlib.h
Executable file
145
component/common/api/platform/platform_stdlib.h
Executable file
|
@ -0,0 +1,145 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2014 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __PLATFORM_STDLIB_H__
|
||||||
|
#define __PLATFORM_STDLIB_H__
|
||||||
|
|
||||||
|
#define USE_CLIB_PATCH 0
|
||||||
|
#if defined (__GNUC__)
|
||||||
|
#define USE_RTL_ROM_CLIB 0
|
||||||
|
#else
|
||||||
|
#define USE_RTL_ROM_CLIB 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#if defined (__IARSTDLIB__)
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#include "diag.h"
|
||||||
|
|
||||||
|
#define strsep(str, delim) _strsep(str, delim)
|
||||||
|
#else
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "diag.h"
|
||||||
|
#include "strproc.h"
|
||||||
|
#include "basic_types.h"
|
||||||
|
#include "hal_misc.h"
|
||||||
|
#if USE_RTL_ROM_CLIB
|
||||||
|
#include "rtl_lib.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef printf
|
||||||
|
#undef sprintf
|
||||||
|
#undef snprintf
|
||||||
|
#undef atoi
|
||||||
|
#undef memcmp
|
||||||
|
#undef memcpy
|
||||||
|
#undef memset
|
||||||
|
#undef strcmp
|
||||||
|
#undef strcpy
|
||||||
|
#undef strlen
|
||||||
|
#undef strncmp
|
||||||
|
#undef strncpy
|
||||||
|
#undef strsep
|
||||||
|
#undef strtok
|
||||||
|
#if USE_RTL_ROM_CLIB
|
||||||
|
#undef memchr
|
||||||
|
#undef memmove
|
||||||
|
#undef strcat
|
||||||
|
#undef strchr
|
||||||
|
#undef strncat
|
||||||
|
#undef strstr
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if USE_RTL_ROM_CLIB
|
||||||
|
#define printf rtl_printf
|
||||||
|
#define sprintf rtl_sprintf
|
||||||
|
#define snprintf rtl_snprintf
|
||||||
|
#define memchr rtl_memchr
|
||||||
|
#define memcmp rtl_memcmp
|
||||||
|
#define memcpy rtl_memcpy
|
||||||
|
#define memmove rtl_memmove
|
||||||
|
#define memset rtl_memset
|
||||||
|
#define strcat rtl_strcat
|
||||||
|
#define strchr rtl_strchr
|
||||||
|
#define strcmp(s1, s2) rtl_strcmp((const char *)s1, (const char *)s2)
|
||||||
|
#define strcpy rtl_strcpy
|
||||||
|
#define strlen(str) rtl_strlen((const char *)str)
|
||||||
|
#define strncat rtl_strncat
|
||||||
|
#define strncmp(s1, s2, n) rtl_strncmp((const char *)s1, (const char *)s2, n)
|
||||||
|
#define strncpy rtl_strncpy
|
||||||
|
#define strstr rtl_strstr
|
||||||
|
#define strsep rtl_strsep
|
||||||
|
#define strtok rtl_strtok
|
||||||
|
#else
|
||||||
|
#if USE_CLIB_PATCH
|
||||||
|
extern int DiagSscanfPatch(const char *buf, const char *fmt, ...);
|
||||||
|
extern char* DiagStrtokPatch(char *str, const char* delim);
|
||||||
|
extern char* DiagStrstrPatch(char *string, char *substring);
|
||||||
|
extern int DiagSnPrintfPatch(char *buf, size_t size, const char *fmt, ...);
|
||||||
|
extern u32 DiagPrintfPatch(const char *fmt, ...);
|
||||||
|
extern u32 DiagSPrintfPatch(u8 *buf, const char *fmt, ...);
|
||||||
|
#define printf DiagPrintfPatch
|
||||||
|
#define sprintf DiagSPrintfPatch
|
||||||
|
#define snprintf DiagSnPrintfPatch
|
||||||
|
#define strstr(a, b) DiagStrstrPatch((char *)(a), (char *)(b))
|
||||||
|
#define strtok DiagStrtokPatch
|
||||||
|
#else
|
||||||
|
#define printf DiagPrintf
|
||||||
|
#define sprintf(fmt, arg...) DiagSPrintf((u8*)fmt, ##arg)
|
||||||
|
#if defined (__GNUC__)
|
||||||
|
#define snprintf DiagSnPrintf // NULL function
|
||||||
|
#define strstr(str1, str2) prvStrStr(str1, str2) // NULL function
|
||||||
|
#endif
|
||||||
|
#define strtok(str, delim) _strsep(str, delim)
|
||||||
|
#endif
|
||||||
|
#define memcmp(dst, src, sz) _memcmp(dst, src, sz)
|
||||||
|
#define memcpy(dst, src, sz) _memcpy(dst, src, sz)
|
||||||
|
#define memset(dst, val, sz) _memset(dst, val, sz)
|
||||||
|
#define strchr(s, c) _strchr(s, c) // for B-cut ROM
|
||||||
|
#define strcmp(str1, str2) prvStrCmp((const unsigned char *) str1, (const unsigned char *) str2)
|
||||||
|
#define strcpy(dest, src) _strcpy(dest, src)
|
||||||
|
#define strlen(str) prvStrLen((const unsigned char *) str)
|
||||||
|
#define strncmp(str1, str2, cnt) _strncmp(str1, str2, cnt)
|
||||||
|
#define strncpy(dest, src, count) _strncpy(dest, src, count)
|
||||||
|
#define strsep(str, delim) _strsep(str, delim)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define atoi(str) prvAtoi(str)
|
||||||
|
#define strpbrk(cs, ct) _strpbrk(cs, ct) // for B-cut ROM
|
||||||
|
|
||||||
|
#if USE_CLIB_PATCH
|
||||||
|
#undef sscanf
|
||||||
|
#define sscanf DiagSscanfPatch
|
||||||
|
#else
|
||||||
|
#if defined (__GNUC__)
|
||||||
|
#undef sscanf
|
||||||
|
#define sscanf _sscanf
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif // defined (__IARSTDLIB__)
|
||||||
|
|
||||||
|
//
|
||||||
|
// memory management
|
||||||
|
//
|
||||||
|
extern void *pvPortMalloc( size_t xWantedSize );
|
||||||
|
extern void vPortFree( void *pv );
|
||||||
|
#define malloc pvPortMalloc
|
||||||
|
#define free vPortFree
|
||||||
|
|
||||||
|
#elif defined(USE_STM322xG_EVAL) || defined(USE_STM324xG_EVAL) || defined(STM32F10X_XL)
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__PLATFORM_STDLIB_H__
|
919
component/common/api/platform/stdlib_patch.c
Executable file
919
component/common/api/platform/stdlib_patch.c
Executable file
|
@ -0,0 +1,919 @@
|
||||||
|
/*
|
||||||
|
|
||||||
|
this is the c lib patch, It can help when the clib provided by IAR
|
||||||
|
does not work well.
|
||||||
|
|
||||||
|
How to use this:
|
||||||
|
1.You must include platform_stdlib.h in you source file。
|
||||||
|
2.There is a macro USE_CLIB_PATCH in platform_stdlib.h should be opened.
|
||||||
|
|
||||||
|
If there is some problems using this patch,
|
||||||
|
You'd better check if you code runs into these functions:
|
||||||
|
|
||||||
|
DiagSscanfPatch
|
||||||
|
DiagStrtokPatch
|
||||||
|
DiagStrstrPatch
|
||||||
|
DiagSnPrintfPatch
|
||||||
|
DiagPrintfPatch
|
||||||
|
DiagSPrintfPatch
|
||||||
|
DiagPrintfPatch
|
||||||
|
DiagSPrintfPatch
|
||||||
|
DiagSnPrintfPatch
|
||||||
|
DiagStrstrPatch
|
||||||
|
DiagStrtokPatch
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#define DiagPutChar HalSerialPutcRtl8195a
|
||||||
|
|
||||||
|
#define IN
|
||||||
|
#define NULL 0
|
||||||
|
|
||||||
|
typedef unsigned int size_t;
|
||||||
|
typedef unsigned int SIZE_T;
|
||||||
|
typedef unsigned long long u64;
|
||||||
|
typedef unsigned int u32;
|
||||||
|
typedef unsigned short int u16;
|
||||||
|
typedef unsigned char u8;
|
||||||
|
typedef signed long long s64;
|
||||||
|
typedef signed int s32;
|
||||||
|
typedef signed short int s16;
|
||||||
|
typedef unsigned char bool;
|
||||||
|
|
||||||
|
|
||||||
|
#define in_range(c, lo, up) ((u8)c >= lo && (u8)c <= up)
|
||||||
|
#define isprint(c) in_range(c, 0x20, 0x7f)
|
||||||
|
#define isdigit(c) in_range(c, '0', '9')
|
||||||
|
#define isxdigit(c) (isdigit(c) || in_range(c, 'a', 'f') || in_range(c, 'A', 'F'))
|
||||||
|
#define islower(c) in_range(c, 'a', 'z')
|
||||||
|
#define isspace(c) (c == ' ' || c == '\f' || c == '\n' || c == '\r' || c == '\t' || c == '\v' || c == ',')
|
||||||
|
#define ULLONG_MAX (~0ULL)
|
||||||
|
#define USHRT_MAX ((u16)(~0U))
|
||||||
|
#define KSTRTOX_OVERFLOW (1U << 31)
|
||||||
|
#define SHRT_MAX ((s16)(USHRT_MAX>>1))
|
||||||
|
|
||||||
|
static inline char _tolower(const char c)
|
||||||
|
{
|
||||||
|
return c | 0x20;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
extern s64 div_s64_rem(s64 dividend, s32 divisor, s32 *remainder);
|
||||||
|
extern s64 div_s64(s64 dividend, s32 divisor);
|
||||||
|
extern inline char _tolower(const char c);
|
||||||
|
extern u64 div_u64_rem(u64 dividend, u32 divisor, u32 *remainder);
|
||||||
|
extern u64 div_u64(u64 dividend, u32 divisor);
|
||||||
|
extern unsigned int _parse_integer(const char *s, unsigned int base, unsigned long long *p);
|
||||||
|
extern const char *_parse_integer_fixup_radix(const char *s, unsigned int *base);
|
||||||
|
extern char *skip_spaces(const char *str);
|
||||||
|
extern int skip_atoi(const char **s);
|
||||||
|
extern void HalSerialPutcRtl8195a(u8 c);
|
||||||
|
|
||||||
|
|
||||||
|
static unsigned long long simple_strtoull_patch(const char *cp, char **endp, unsigned int base)
|
||||||
|
{
|
||||||
|
unsigned long long result;
|
||||||
|
unsigned int rv;
|
||||||
|
|
||||||
|
cp = _parse_integer_fixup_radix(cp, &base);
|
||||||
|
rv = _parse_integer(cp, base, &result);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
static long long simple_strtoll_patch(const char *cp, char **endp, unsigned int base)
|
||||||
|
{
|
||||||
|
if(*cp == '-')
|
||||||
|
return -simple_strtoull_patch(cp + 1, endp, base);
|
||||||
|
|
||||||
|
return simple_strtoull_patch(cp, endp, base);
|
||||||
|
}
|
||||||
|
static unsigned long simple_strtoul_patch(const char *cp, char **endp, unsigned int base)
|
||||||
|
{
|
||||||
|
return simple_strtoull_patch(cp, endp, base);
|
||||||
|
}
|
||||||
|
|
||||||
|
static long simple_strtol_patch(const char *cp, char **endp, unsigned int base)
|
||||||
|
{
|
||||||
|
if(*cp == '-')
|
||||||
|
return -simple_strtoul_patch(cp + 1, endp, base);
|
||||||
|
|
||||||
|
return simple_strtoul_patch(cp, endp, base);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static int judge_digit_width(const char *str)
|
||||||
|
{
|
||||||
|
|
||||||
|
int width = 0;
|
||||||
|
|
||||||
|
while(isdigit(*str)) {
|
||||||
|
width++;
|
||||||
|
str++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return width;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int _vsscanf_patch(const char *buf, const char *fmt, va_list args)
|
||||||
|
{
|
||||||
|
const char *str = buf;
|
||||||
|
char *next;
|
||||||
|
char digit;
|
||||||
|
int num = 0;
|
||||||
|
int i =0;
|
||||||
|
u8 qualifier;
|
||||||
|
unsigned int base;
|
||||||
|
union {
|
||||||
|
long long s;
|
||||||
|
unsigned long long u;
|
||||||
|
} val;
|
||||||
|
s16 field_width;
|
||||||
|
bool is_sign;
|
||||||
|
|
||||||
|
char str_store[20] = {0};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
while(*fmt) {
|
||||||
|
/* skip any white space in format */
|
||||||
|
/* white space in format matchs any amount of
|
||||||
|
* white space, including none, in the input.
|
||||||
|
*/
|
||||||
|
if(isspace(*fmt)) {
|
||||||
|
fmt = skip_spaces(++fmt);
|
||||||
|
str = skip_spaces(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* anything that is not a conversion must match exactly */
|
||||||
|
if(*fmt != '%' && *fmt) {
|
||||||
|
if(*fmt++ != *str++) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!*fmt) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
++fmt;
|
||||||
|
|
||||||
|
/* skip this conversion.
|
||||||
|
* advance both strings to next white space
|
||||||
|
*/
|
||||||
|
if(*fmt == '*') {
|
||||||
|
if(!*str) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
while(!isspace(*fmt) && *fmt != '%' && *fmt)
|
||||||
|
fmt++;
|
||||||
|
|
||||||
|
while(!isspace(*str) && *str)
|
||||||
|
str++;
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* get field width */
|
||||||
|
field_width = -1;
|
||||||
|
|
||||||
|
if(isdigit(*fmt)) {
|
||||||
|
|
||||||
|
field_width = skip_atoi(&fmt);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if(field_width <= 0) {
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* get conversion qualifier */
|
||||||
|
qualifier = -1;
|
||||||
|
|
||||||
|
if(*fmt == 'h' || _tolower(*fmt) == 'l' ||
|
||||||
|
_tolower(*fmt) == 'z') {
|
||||||
|
qualifier = *fmt++;
|
||||||
|
|
||||||
|
if(qualifier == *fmt) {
|
||||||
|
if(qualifier == 'h') {
|
||||||
|
qualifier = 'H';
|
||||||
|
fmt++;
|
||||||
|
} else if(qualifier == 'l') {
|
||||||
|
qualifier = 'L';
|
||||||
|
fmt++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!*fmt) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(*fmt == 'n') {
|
||||||
|
/* return number of characters read so far */
|
||||||
|
*va_arg(args, int *) = str - buf;
|
||||||
|
++fmt;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!*str) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
base = 10;
|
||||||
|
is_sign = 0;
|
||||||
|
|
||||||
|
switch(*fmt++) {
|
||||||
|
case 'c': {
|
||||||
|
char *s = (char *)va_arg(args, char*);
|
||||||
|
|
||||||
|
if(field_width == -1)
|
||||||
|
field_width = 1;
|
||||||
|
|
||||||
|
do {
|
||||||
|
*s++ = *str++;
|
||||||
|
} while(--field_width > 0 && *str);
|
||||||
|
|
||||||
|
num++;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
|
||||||
|
case 's': {
|
||||||
|
char *s = (char *)va_arg(args, char *);
|
||||||
|
|
||||||
|
if(field_width == -1)
|
||||||
|
field_width = SHRT_MAX;
|
||||||
|
|
||||||
|
/* first, skip leading white space in buffer */
|
||||||
|
str = skip_spaces(str);
|
||||||
|
|
||||||
|
/* now copy until next white space */
|
||||||
|
while(*str && !isspace(*str) && field_width--) {
|
||||||
|
*s++ = *str++;
|
||||||
|
}
|
||||||
|
|
||||||
|
*s = '\0';
|
||||||
|
num++;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
|
||||||
|
case 'o':
|
||||||
|
base = 8;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'x':
|
||||||
|
case 'X':
|
||||||
|
base = 16;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'i':
|
||||||
|
base = 0;
|
||||||
|
|
||||||
|
case 'd':
|
||||||
|
is_sign = 1;
|
||||||
|
|
||||||
|
case 'u':
|
||||||
|
break;
|
||||||
|
|
||||||
|
case '%':
|
||||||
|
|
||||||
|
/* looking for '%' in str */
|
||||||
|
if(*str++ != '%') {
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
|
||||||
|
default:
|
||||||
|
/* invalid format; stop here */
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* have some sort of integer conversion.
|
||||||
|
* first, skip white space in buffer.
|
||||||
|
*/
|
||||||
|
str = skip_spaces(str);
|
||||||
|
|
||||||
|
digit = *str;
|
||||||
|
|
||||||
|
if(is_sign && digit == '-')
|
||||||
|
digit = *(str + 1);
|
||||||
|
|
||||||
|
if(!digit
|
||||||
|
|| (base == 16 && !isxdigit(digit))
|
||||||
|
|| (base == 10 && !isdigit(digit))
|
||||||
|
|| (base == 8 && (!isdigit(digit) || digit > '7'))
|
||||||
|
|| (base == 0 && !isdigit(digit))) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
//here problem *******************************************
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
//troy add ,fix support %2d, but not support %d
|
||||||
|
if(field_width <= 0) {
|
||||||
|
|
||||||
|
field_width = judge_digit_width(str);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/////troy add, fix str passed inwidth wrong
|
||||||
|
for(i = 0; i<field_width ; i++)
|
||||||
|
str_store[i] = str[i];
|
||||||
|
|
||||||
|
next = (char*)str + field_width;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if(is_sign) {
|
||||||
|
val.s = qualifier != 'L' ?
|
||||||
|
simple_strtol_patch(str_store, &next, base) :
|
||||||
|
simple_strtoll_patch(str_store, &next, base);
|
||||||
|
} else {
|
||||||
|
val.u = qualifier != 'L' ?
|
||||||
|
simple_strtoul_patch(str_store, &next, base) :
|
||||||
|
simple_strtoull_patch(str_store, &next, base);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
////troy add
|
||||||
|
for(i = 0; i<20 ; i++)
|
||||||
|
str_store[i] = 0;
|
||||||
|
|
||||||
|
|
||||||
|
//判断转换的字符串的宽度是否大于 %2d
|
||||||
|
if(field_width > 0 && next - str > field_width) {
|
||||||
|
if(base == 0)
|
||||||
|
_parse_integer_fixup_radix(str, &base);
|
||||||
|
|
||||||
|
while(next - str > field_width) {
|
||||||
|
if(is_sign) {
|
||||||
|
val.s = div_s64(val.s, base);
|
||||||
|
} else {
|
||||||
|
val.u = div_u64(val.u, base);
|
||||||
|
}
|
||||||
|
|
||||||
|
--next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(qualifier) {
|
||||||
|
case 'H': /* that's 'hh' in format */
|
||||||
|
if(is_sign)
|
||||||
|
*va_arg(args, signed char *) = val.s;
|
||||||
|
else
|
||||||
|
*va_arg(args, unsigned char *) = val.u;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'h':
|
||||||
|
if(is_sign)
|
||||||
|
*va_arg(args, short *) = val.s;
|
||||||
|
else
|
||||||
|
*va_arg(args, unsigned short *) = val.u;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'l':
|
||||||
|
if(is_sign)
|
||||||
|
*va_arg(args, long *) = val.s;
|
||||||
|
else
|
||||||
|
*va_arg(args, unsigned long *) = val.u;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'L':
|
||||||
|
if(is_sign)
|
||||||
|
*va_arg(args, long long *) = val.s;
|
||||||
|
else
|
||||||
|
*va_arg(args, unsigned long long *) = val.u;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'Z':
|
||||||
|
case 'z':
|
||||||
|
*va_arg(args, size_t *) = val.u;
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if(is_sign)
|
||||||
|
*va_arg(args, int *) = val.s;
|
||||||
|
else
|
||||||
|
*va_arg(args, unsigned int *) = val.u;
|
||||||
|
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
num++;
|
||||||
|
|
||||||
|
if(!next) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
str = next;
|
||||||
|
}
|
||||||
|
|
||||||
|
return num;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int DiagSscanfPatch(const char *buf, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
va_list args;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
va_start(args, fmt);
|
||||||
|
i = _vsscanf_patch(buf, fmt, args);
|
||||||
|
va_end(args);
|
||||||
|
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*********************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
char* DiagStrtokPatch(char *str, const char* delim) {
|
||||||
|
static char* _buffer;
|
||||||
|
|
||||||
|
if(str != NULL) _buffer = str;
|
||||||
|
|
||||||
|
if(_buffer[0] == '\0') return NULL;
|
||||||
|
|
||||||
|
char *ret = _buffer, *b;
|
||||||
|
const char *d;
|
||||||
|
|
||||||
|
for(b = _buffer; *b !='\0'; b++) {
|
||||||
|
for(d = delim; *d != '\0'; d++) {
|
||||||
|
if(*b == *d) {
|
||||||
|
*b = '\0';
|
||||||
|
_buffer = b+1;
|
||||||
|
|
||||||
|
// skip the beginning delimiters
|
||||||
|
if(b == ret) {
|
||||||
|
ret++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*********************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
char *DiagStrstrPatch(char *string, char *substring)
|
||||||
|
{
|
||||||
|
register char *a, *b;
|
||||||
|
|
||||||
|
/* First scan quickly through the two strings looking for a
|
||||||
|
* single-character match. When it's found, then compare the
|
||||||
|
* rest of the substring.
|
||||||
|
*/
|
||||||
|
|
||||||
|
b = substring;
|
||||||
|
|
||||||
|
if(*b == 0) {
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(; *string != 0; string += 1) {
|
||||||
|
if(*string != *b) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
a = string;
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
if(*b == 0) {
|
||||||
|
return string;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(*a++ != *b++) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
b = substring;
|
||||||
|
}
|
||||||
|
|
||||||
|
return (char *) 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*********************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
int DiagSnPrintfPatch(char *buf, size_t size, const char *fmt, ...)
|
||||||
|
{
|
||||||
|
|
||||||
|
va_list ap;
|
||||||
|
char *p, *s, *buf_end = NULL;
|
||||||
|
const int *dp = ((const int *)&fmt)+1;
|
||||||
|
|
||||||
|
if(buf == NULL)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
|
||||||
|
va_start(ap, fmt);
|
||||||
|
s = buf;
|
||||||
|
buf_end = size? (buf + size):(char*)~0;
|
||||||
|
|
||||||
|
for(; *fmt != '\0'; ++fmt) {
|
||||||
|
|
||||||
|
if(*fmt != '%') {
|
||||||
|
*s++ = *fmt;
|
||||||
|
|
||||||
|
if(s >= buf_end) {
|
||||||
|
goto Exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(*++fmt == 's') {
|
||||||
|
for(p = (char *)*dp++; *p != '\0'; p++) {
|
||||||
|
*s++ = *p;
|
||||||
|
|
||||||
|
if(s >= buf_end) {
|
||||||
|
goto Exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { /* Length of item is bounded */
|
||||||
|
char tmp[20], *q = tmp;
|
||||||
|
int alt = 0;
|
||||||
|
int shift = 0;// = 12;
|
||||||
|
const long *lpforchk = (const long *)dp;
|
||||||
|
|
||||||
|
if((*lpforchk) < 0x10) {
|
||||||
|
shift = 0;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x10) && ((*lpforchk) < 0x100)) {
|
||||||
|
shift = 4;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x100) && ((*lpforchk) < 0x1000)) {
|
||||||
|
shift = 8;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x1000) && ((*lpforchk) < 0x10000)) {
|
||||||
|
shift = 12;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x10000) && ((*lpforchk) < 0x100000)) {
|
||||||
|
shift = 16;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x100000) && ((*lpforchk) < 0x1000000)) {
|
||||||
|
shift = 20;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x1000000) && ((*lpforchk) < 0x10000000)) {
|
||||||
|
shift = 24;
|
||||||
|
}
|
||||||
|
else if((*lpforchk) >= 0x10000000) {
|
||||||
|
shift = 28;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
shift = 28;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((*fmt >= '0') && (*fmt <= '9'))
|
||||||
|
{
|
||||||
|
int width;
|
||||||
|
unsigned char fch = *fmt;
|
||||||
|
|
||||||
|
for(width=0; (fch>='0') && (fch<='9'); fch=*++fmt)
|
||||||
|
{ width = width * 10 + fch - '0';
|
||||||
|
}
|
||||||
|
|
||||||
|
shift=(width-1)*4;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Before each format q points to tmp buffer
|
||||||
|
* After each format q points past end of item
|
||||||
|
*/
|
||||||
|
if((*fmt == 'x')||(*fmt == 'X') || (*fmt == 'p') || (*fmt == 'P')) {
|
||||||
|
/* With x86 gcc, sizeof(long) == sizeof(int) */
|
||||||
|
const long *lp = (const long *)dp;
|
||||||
|
long h = *lp++;
|
||||||
|
int hex_count = 0;
|
||||||
|
unsigned long h_back = h;
|
||||||
|
int ncase = (*fmt & 0x20);
|
||||||
|
dp = (const int *)lp;
|
||||||
|
|
||||||
|
if((*fmt == 'p') || (*fmt == 'P'))
|
||||||
|
alt=1;
|
||||||
|
|
||||||
|
if(alt) {
|
||||||
|
*q++ = '0';
|
||||||
|
*q++ = 'X' | ncase;
|
||||||
|
}
|
||||||
|
|
||||||
|
while(h_back) {
|
||||||
|
hex_count += (h_back & 0xF) ? 1 : 0;
|
||||||
|
h_back = h_back >> 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(shift < (hex_count - 1)*4)
|
||||||
|
shift = (hex_count - 1)*4;
|
||||||
|
|
||||||
|
for(; shift >= 0; shift -= 4)
|
||||||
|
*q++ = "0123456789ABCDEF"[(h >> shift) & 0xF] | ncase;
|
||||||
|
}
|
||||||
|
else if(*fmt == 'd') {
|
||||||
|
int i = *dp++;
|
||||||
|
char *r;
|
||||||
|
int digit_space = 0;
|
||||||
|
|
||||||
|
|
||||||
|
if(i < 0) {
|
||||||
|
*q++ = '-';
|
||||||
|
i = -i;
|
||||||
|
digit_space++;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = q; /* save beginning of digits */
|
||||||
|
|
||||||
|
|
||||||
|
do {
|
||||||
|
*q++ = '0' + (i % 10);
|
||||||
|
i /= 10;
|
||||||
|
digit_space++;
|
||||||
|
} while(i);
|
||||||
|
|
||||||
|
|
||||||
|
for(; shift >= 0; shift -= 4) {
|
||||||
|
|
||||||
|
if(digit_space-- > 0) {
|
||||||
|
; //do nothing
|
||||||
|
} else {
|
||||||
|
*q++ = '0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* reverse digits, stop in middle */
|
||||||
|
r = q; /* don't alter q */
|
||||||
|
|
||||||
|
while(--r > p) {
|
||||||
|
i = *r;
|
||||||
|
*r = *p;
|
||||||
|
*p++ = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(*fmt == 'c')
|
||||||
|
*q++ = *dp++;
|
||||||
|
else
|
||||||
|
*q++ = *fmt;
|
||||||
|
|
||||||
|
/* now output the saved string */
|
||||||
|
for(p = tmp; p < q; ++p) {
|
||||||
|
*s++ = *p;
|
||||||
|
|
||||||
|
if(s >= buf_end) {
|
||||||
|
goto Exit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Exit:
|
||||||
|
|
||||||
|
if(buf)
|
||||||
|
*s = '\0';
|
||||||
|
|
||||||
|
va_end(ap);
|
||||||
|
return(s-buf);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*********************************************************/
|
||||||
|
|
||||||
|
static int VSprintfPatch(char *buf, const char *fmt, const int *dp)
|
||||||
|
{
|
||||||
|
char *p, *s;
|
||||||
|
s = buf;
|
||||||
|
|
||||||
|
for(; *fmt != '\0'; ++fmt) {
|
||||||
|
if(*fmt != '%') {
|
||||||
|
if(buf) {
|
||||||
|
*s++ = *fmt;
|
||||||
|
} else {
|
||||||
|
DiagPutChar(*fmt);
|
||||||
|
}
|
||||||
|
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(*++fmt == 's') {
|
||||||
|
for(p = (char *)*dp++; *p != '\0'; p++) {
|
||||||
|
if(buf) {
|
||||||
|
*s++ = *p;
|
||||||
|
} else {
|
||||||
|
DiagPutChar(*p);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { /* Length of item is bounded */
|
||||||
|
char tmp[20], *q = tmp;
|
||||||
|
int alt = 0;
|
||||||
|
int shift = 0;// = 12;
|
||||||
|
const long *lpforchk = (const long *)dp;
|
||||||
|
|
||||||
|
if((*lpforchk) < 0x10) {
|
||||||
|
shift = 0;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x10) && ((*lpforchk) < 0x100)) {
|
||||||
|
shift = 4;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x100) && ((*lpforchk) < 0x1000)) {
|
||||||
|
shift = 8;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x1000) && ((*lpforchk) < 0x10000)) {
|
||||||
|
shift = 12;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x10000) && ((*lpforchk) < 0x100000)) {
|
||||||
|
shift = 16;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x100000) && ((*lpforchk) < 0x1000000)) {
|
||||||
|
shift = 20;
|
||||||
|
}
|
||||||
|
else if(((*lpforchk) >= 0x1000000) && ((*lpforchk) < 0x10000000)) {
|
||||||
|
shift = 24;
|
||||||
|
}
|
||||||
|
else if((*lpforchk) >= 0x10000000) {
|
||||||
|
shift = 28;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
shift = 28;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if 1 //wei patch for %02x
|
||||||
|
|
||||||
|
if((*fmt >= '0') && (*fmt <= '9'))
|
||||||
|
{
|
||||||
|
int width;
|
||||||
|
unsigned char fch = *fmt;
|
||||||
|
|
||||||
|
for(width=0; (fch>='0') && (fch<='9'); fch=*++fmt)
|
||||||
|
{ width = width * 10 + fch - '0';
|
||||||
|
}
|
||||||
|
|
||||||
|
shift=(width-1)*4;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Before each format q points to tmp buffer
|
||||||
|
* After each format q points past end of item
|
||||||
|
*/
|
||||||
|
|
||||||
|
if((*fmt == 'x')||(*fmt == 'X') || (*fmt == 'p') || (*fmt == 'P')) {
|
||||||
|
/* With x86 gcc, sizeof(long) == sizeof(int) */
|
||||||
|
const long *lp = (const long *)dp;
|
||||||
|
long h = *lp++;
|
||||||
|
int hex_count = 0;
|
||||||
|
unsigned long h_back = h;
|
||||||
|
int ncase = (*fmt & 0x20);
|
||||||
|
dp = (const int *)lp;
|
||||||
|
|
||||||
|
if((*fmt == 'p') || (*fmt == 'P'))
|
||||||
|
alt=1;
|
||||||
|
|
||||||
|
if(alt) {
|
||||||
|
*q++ = '0';
|
||||||
|
*q++ = 'X' | ncase;
|
||||||
|
}
|
||||||
|
|
||||||
|
//hback 是实际得到的数据,hex_count是统计数据的HEX字符个数
|
||||||
|
while(h_back) {
|
||||||
|
hex_count += (h_back & 0xF) ? 1 : 0;
|
||||||
|
h_back = h_back >> 4;
|
||||||
|
}
|
||||||
|
|
||||||
|
//这里修复 example: 字符有4个,但是用了%02x导致字符被截断的情况
|
||||||
|
if(shift < (hex_count - 1)*4)
|
||||||
|
shift = (hex_count - 1)*4;
|
||||||
|
|
||||||
|
//printf("(%d,%d)", hex_count, shift);
|
||||||
|
|
||||||
|
for(; shift >= 0; shift -= 4) {
|
||||||
|
|
||||||
|
*q++ = "0123456789ABCDEF"[(h >> shift) & 0xF] | ncase;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else if(*fmt == 'd') {
|
||||||
|
int i = *dp++;
|
||||||
|
char *r;
|
||||||
|
int digit_space = 0;
|
||||||
|
|
||||||
|
if(i < 0) {
|
||||||
|
*q++ = '-';
|
||||||
|
i = -i;
|
||||||
|
digit_space++;
|
||||||
|
}
|
||||||
|
|
||||||
|
p = q; /* save beginning of digits */
|
||||||
|
|
||||||
|
do {
|
||||||
|
*q++ = '0' + (i % 10);
|
||||||
|
i /= 10;
|
||||||
|
digit_space++;
|
||||||
|
} while(i);
|
||||||
|
|
||||||
|
//这里修复 example:用了%08d后,在数字前面没有0的情况
|
||||||
|
for(; shift >= 0; shift -= 4) {
|
||||||
|
|
||||||
|
if(digit_space-- > 0) {
|
||||||
|
; //do nothing
|
||||||
|
} else {
|
||||||
|
*q++ = '0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* reverse digits, stop in middle */
|
||||||
|
r = q; /* don't alter q */
|
||||||
|
|
||||||
|
while(--r > p) {
|
||||||
|
i = *r;
|
||||||
|
*r = *p;
|
||||||
|
*p++ = i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(*fmt == 'c')
|
||||||
|
*q++ = *dp++;
|
||||||
|
else
|
||||||
|
*q++ = *fmt;
|
||||||
|
|
||||||
|
/* now output the saved string */
|
||||||
|
for(p = tmp; p < q; ++p) {
|
||||||
|
if(buf) {
|
||||||
|
*s++ = *p;
|
||||||
|
} else {
|
||||||
|
DiagPutChar(*p);
|
||||||
|
}
|
||||||
|
|
||||||
|
if((*p) == '\n') {
|
||||||
|
DiagPutChar('\r');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(buf)
|
||||||
|
*s = '\0';
|
||||||
|
|
||||||
|
return (s - buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
u32 DiagPrintfPatch(
|
||||||
|
IN const char *fmt, ...
|
||||||
|
)
|
||||||
|
{
|
||||||
|
(void)VSprintfPatch(0, fmt, ((const int *)&fmt)+1);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 DiagSPrintfPatch(
|
||||||
|
IN u8 *buf,
|
||||||
|
IN const char *fmt, ...
|
||||||
|
)
|
||||||
|
{
|
||||||
|
(void)VSprintfPatch((char*)buf, fmt, ((const int *)&fmt)+1);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
578
component/common/api/wifi/rtw_wpa_supplicant/src/utils/os.h
Executable file
578
component/common/api/wifi/rtw_wpa_supplicant/src/utils/os.h
Executable file
|
@ -0,0 +1,578 @@
|
||||||
|
/*
|
||||||
|
* OS specific functions
|
||||||
|
* Copyright (c) 2005-2009, Jouni Malinen <j@w1.fi>
|
||||||
|
*
|
||||||
|
* This software may be distributed under the terms of the BSD license.
|
||||||
|
* See README for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef OS_H
|
||||||
|
#define OS_H
|
||||||
|
|
||||||
|
//#include "basic_types.h"
|
||||||
|
#include <autoconf.h>
|
||||||
|
#include "osdep_service.h"
|
||||||
|
#include "utils/rom/rom_wps_os.h"
|
||||||
|
|
||||||
|
typedef void* xqueue_handle_t;
|
||||||
|
|
||||||
|
typedef long os_time_t;
|
||||||
|
|
||||||
|
typedef _timer os_timer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_sleep - Sleep (sec, usec)
|
||||||
|
* @sec: Number of seconds to sleep
|
||||||
|
* @usec: Number of microseconds to sleep
|
||||||
|
*/
|
||||||
|
void os_sleep(os_time_t sec, os_time_t usec);
|
||||||
|
|
||||||
|
struct os_time {
|
||||||
|
os_time_t sec;
|
||||||
|
os_time_t usec;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct os_reltime {
|
||||||
|
os_time_t sec;
|
||||||
|
os_time_t usec;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_get_time - Get current time (sec, usec)
|
||||||
|
* @t: Pointer to buffer for the time
|
||||||
|
* Returns: 0 on success, -1 on failure
|
||||||
|
*/
|
||||||
|
int os_get_time(struct os_time *t);
|
||||||
|
|
||||||
|
int os_get_reltime(struct os_reltime *t);
|
||||||
|
/* Helper macros for handling struct os_time */
|
||||||
|
/* (&timeout->time, &tmp->time) */
|
||||||
|
#define os_time_before(a, b) \
|
||||||
|
((a)->sec < (b)->sec || \
|
||||||
|
((a)->sec == (b)->sec && (a)->usec < (b)->usec))
|
||||||
|
|
||||||
|
#define os_time_sub(a, b, res) do { \
|
||||||
|
(res)->sec = (a)->sec - (b)->sec; \
|
||||||
|
(res)->usec = (a)->usec - (b)->usec; \
|
||||||
|
if ((res)->usec < 0) { \
|
||||||
|
(res)->sec--; \
|
||||||
|
(res)->usec += 1000000; \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_mktime - Convert broken-down time into seconds since 1970-01-01
|
||||||
|
* @year: Four digit year
|
||||||
|
* @month: Month (1 .. 12)
|
||||||
|
* @day: Day of month (1 .. 31)
|
||||||
|
* @hour: Hour (0 .. 23)
|
||||||
|
* @min: Minute (0 .. 59)
|
||||||
|
* @sec: Second (0 .. 60)
|
||||||
|
* @t: Buffer for returning calendar time representation (seconds since
|
||||||
|
* 1970-01-01 00:00:00)
|
||||||
|
* Returns: 0 on success, -1 on failure
|
||||||
|
*
|
||||||
|
* Note: The result is in seconds from Epoch, i.e., in UTC, not in local time
|
||||||
|
* which is used by POSIX mktime().
|
||||||
|
*/
|
||||||
|
int os_mktime(int year, int month, int day, int hour, int min, int sec,
|
||||||
|
os_time_t *t);
|
||||||
|
|
||||||
|
struct os_tm {
|
||||||
|
int sec; /* 0..59 or 60 for leap seconds */
|
||||||
|
int min; /* 0..59 */
|
||||||
|
int hour; /* 0..23 */
|
||||||
|
int day; /* 1..31 */
|
||||||
|
int month; /* 1..12 */
|
||||||
|
int year; /* Four digit year */
|
||||||
|
};
|
||||||
|
|
||||||
|
int os_gmtime(os_time_t t, struct os_tm *tm);
|
||||||
|
|
||||||
|
/* Helpers for handling struct os_time */
|
||||||
|
|
||||||
|
/* Helpers for handling struct os_reltime */
|
||||||
|
|
||||||
|
static inline int os_reltime_before(struct os_reltime *a,
|
||||||
|
struct os_reltime *b)
|
||||||
|
{
|
||||||
|
return os_time_before(a,b);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void os_reltime_sub(struct os_reltime *a, struct os_reltime *b,
|
||||||
|
struct os_reltime *res)
|
||||||
|
{
|
||||||
|
os_time_sub(a,b,res);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline void os_reltime_age(struct os_reltime *start,
|
||||||
|
struct os_reltime *age)
|
||||||
|
{
|
||||||
|
struct os_reltime now;
|
||||||
|
|
||||||
|
os_get_time((struct os_time *)&now);
|
||||||
|
os_reltime_sub(&now, start, age);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static inline int os_reltime_expired(struct os_reltime *now,
|
||||||
|
struct os_reltime *ts,
|
||||||
|
os_time_t timeout_secs)
|
||||||
|
{
|
||||||
|
struct os_reltime age;
|
||||||
|
|
||||||
|
os_reltime_sub(now, ts, &age);
|
||||||
|
return (age.sec > timeout_secs) ||
|
||||||
|
(age.sec == timeout_secs && age.usec > 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_daemonize - Run in the background (detach from the controlling terminal)
|
||||||
|
* @pid_file: File name to write the process ID to or %NULL to skip this
|
||||||
|
* Returns: 0 on success, -1 on failure
|
||||||
|
*/
|
||||||
|
int os_daemonize(const char *pid_file);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_daemonize_terminate - Stop running in the background (remove pid file)
|
||||||
|
* @pid_file: File name to write the process ID to or %NULL to skip this
|
||||||
|
*/
|
||||||
|
void os_daemonize_terminate(const char *pid_file);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_get_random - Get cryptographically strong pseudo random data
|
||||||
|
* @buf: Buffer for pseudo random data
|
||||||
|
* @len: Length of the buffer
|
||||||
|
* Returns: 0 on success, -1 on failure
|
||||||
|
*/
|
||||||
|
int os_get_random(unsigned char *buf, size_t len);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_random - Get pseudo random value (not necessarily very strong)
|
||||||
|
* Returns: Pseudo random value
|
||||||
|
*/
|
||||||
|
unsigned long os_random(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_rel2abs_path - Get an absolute path for a file
|
||||||
|
* @rel_path: Relative path to a file
|
||||||
|
* Returns: Absolute path for the file or %NULL on failure
|
||||||
|
*
|
||||||
|
* This function tries to convert a relative path of a file to an absolute path
|
||||||
|
* in order for the file to be found even if current working directory has
|
||||||
|
* changed. The returned value is allocated and caller is responsible for
|
||||||
|
* freeing it. It is acceptable to just return the same path in an allocated
|
||||||
|
* buffer, e.g., return strdup(rel_path). This function is only used to find
|
||||||
|
* configuration files when os_daemonize() may have changed the current working
|
||||||
|
* directory and relative path would be pointing to a different location.
|
||||||
|
*/
|
||||||
|
char * os_rel2abs_path(const char *rel_path);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_program_init - Program initialization (called at start)
|
||||||
|
* Returns: 0 on success, -1 on failure
|
||||||
|
*
|
||||||
|
* This function is called when a programs starts. If there are any OS specific
|
||||||
|
* processing that is needed, it can be placed here. It is also acceptable to
|
||||||
|
* just return 0 if not special processing is needed.
|
||||||
|
*/
|
||||||
|
int os_program_init(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_program_deinit - Program deinitialization (called just before exit)
|
||||||
|
*
|
||||||
|
* This function is called just before a program exists. If there are any OS
|
||||||
|
* specific processing, e.g., freeing resourced allocated in os_program_init(),
|
||||||
|
* it should be done here. It is also acceptable for this function to do
|
||||||
|
* nothing.
|
||||||
|
*/
|
||||||
|
void os_program_deinit(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_setenv - Set environment variable
|
||||||
|
* @name: Name of the variable
|
||||||
|
* @value: Value to set to the variable
|
||||||
|
* @overwrite: Whether existing variable should be overwritten
|
||||||
|
* Returns: 0 on success, -1 on error
|
||||||
|
*
|
||||||
|
* This function is only used for wpa_cli action scripts. OS wrapper does not
|
||||||
|
* need to implement this if such functionality is not needed.
|
||||||
|
*/
|
||||||
|
int os_setenv(const char *name, const char *value, int overwrite);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_unsetenv - Delete environent variable
|
||||||
|
* @name: Name of the variable
|
||||||
|
* Returns: 0 on success, -1 on error
|
||||||
|
*
|
||||||
|
* This function is only used for wpa_cli action scripts. OS wrapper does not
|
||||||
|
* need to implement this if such functionality is not needed.
|
||||||
|
*/
|
||||||
|
int os_unsetenv(const char *name);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_readfile - Read a file to an allocated memory buffer
|
||||||
|
* @name: Name of the file to read
|
||||||
|
* @len: For returning the length of the allocated buffer
|
||||||
|
* Returns: Pointer to the allocated buffer or %NULL on failure
|
||||||
|
*
|
||||||
|
* This function allocates memory and reads the given file to this buffer. Both
|
||||||
|
* binary and text files can be read with this function. The caller is
|
||||||
|
* responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
char * os_readfile(const char *name, size_t *len);
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/**
|
||||||
|
* os_zalloc - Allocate and zero memory
|
||||||
|
* @size: Number of bytes to allocate
|
||||||
|
* Returns: Pointer to allocated and zeroed memory or %NULL on failure
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
void * os_zalloc(size_t size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_calloc - Allocate and zero memory for an array
|
||||||
|
* @nmemb: Number of members in the array
|
||||||
|
* @size: Number of bytes in each member
|
||||||
|
* Returns: Pointer to allocated and zeroed memory or %NULL on failure
|
||||||
|
*
|
||||||
|
* This function can be used as a wrapper for os_zalloc(nmemb * size) when an
|
||||||
|
* allocation is used for an array. The main benefit over os_zalloc() is in
|
||||||
|
* having an extra check to catch integer overflows in multiplication.
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
static inline void * os_calloc(size_t nmemb, size_t size)
|
||||||
|
{
|
||||||
|
if (size && nmemb > (~(size_t) 0) / size)
|
||||||
|
return NULL;
|
||||||
|
return os_zalloc(nmemb * size);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The following functions are wrapper for standard ANSI C or POSIX functions.
|
||||||
|
* By default, they are just defined to use the standard function name and no
|
||||||
|
* os_*.c implementation is needed for them. This avoids extra function calls
|
||||||
|
* by allowing the C pre-processor take care of the function name mapping.
|
||||||
|
*
|
||||||
|
* If the target system uses a C library that does not provide these functions,
|
||||||
|
* build_config.h can be used to define the wrappers to use a different
|
||||||
|
* function name. This can be done on function-by-function basis since the
|
||||||
|
* defines here are only used if build_config.h does not define the os_* name.
|
||||||
|
* If needed, os_*.c file can be used to implement the functions that are not
|
||||||
|
* included in the C library on the target system. Alternatively,
|
||||||
|
* OS_NO_C_LIB_DEFINES can be defined to skip all defines here in which case
|
||||||
|
* these functions need to be implemented in os_*.c file for the target system.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef OS_NO_C_LIB_DEFINES
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_malloc - Allocate dynamic memory
|
||||||
|
* @size: Size of the buffer to allocate
|
||||||
|
* Returns: Allocated buffer or %NULL on failure
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
void * os_malloc(size_t size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_realloc - Re-allocate dynamic memory
|
||||||
|
* @ptr: Old buffer from os_malloc() or os_realloc()
|
||||||
|
* @size: Size of the new buffer
|
||||||
|
* Returns: Allocated buffer or %NULL on failure
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
* If re-allocation fails, %NULL is returned and the original buffer (ptr) is
|
||||||
|
* not freed and caller is still responsible for freeing it.
|
||||||
|
*/
|
||||||
|
void * os_realloc(void *ptr, size_t size);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_free - Free dynamic memory
|
||||||
|
* @ptr: Old buffer from os_malloc() or os_realloc(); can be %NULL
|
||||||
|
*/
|
||||||
|
void os_free(void *ptr);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_memcpy - Copy memory area
|
||||||
|
* @dest: Destination
|
||||||
|
* @src: Source
|
||||||
|
* @n: Number of bytes to copy
|
||||||
|
* Returns: dest
|
||||||
|
*
|
||||||
|
* The memory areas src and dst must not overlap. os_memmove() can be used with
|
||||||
|
* overlapping memory.
|
||||||
|
*/
|
||||||
|
void * os_memcpy(void *dest, const void *src, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_memmove - Copy memory area
|
||||||
|
* @dest: Destination
|
||||||
|
* @src: Source
|
||||||
|
* @n: Number of bytes to copy
|
||||||
|
* Returns: dest
|
||||||
|
*
|
||||||
|
* The memory areas src and dst may overlap.
|
||||||
|
*/
|
||||||
|
void *os_memmove(void *dest, const void *src, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_memset - Fill memory with a constant byte
|
||||||
|
* @s: Memory area to be filled
|
||||||
|
* @c: Constant byte
|
||||||
|
* @n: Number of bytes started from s to fill with c
|
||||||
|
* Returns: s
|
||||||
|
*/
|
||||||
|
void *os_memset(void *s, int c, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_memcmp - Compare memory areas
|
||||||
|
* @s1: First buffer
|
||||||
|
* @s2: Second buffer
|
||||||
|
* @n: Maximum numbers of octets to compare
|
||||||
|
* Returns: An integer less than, equal to, or greater than zero if s1 is
|
||||||
|
* found to be less than, to match, or be greater than s2. Only first n
|
||||||
|
* characters will be compared.
|
||||||
|
*/
|
||||||
|
int os_memcmp(const void *s1, const void *s2, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strdup - Duplicate a string
|
||||||
|
* @s: Source string
|
||||||
|
* Returns: Allocated buffer with the string copied into it or %NULL on failure
|
||||||
|
*
|
||||||
|
* Caller is responsible for freeing the returned buffer with os_free().
|
||||||
|
*/
|
||||||
|
char *os_strdup(const char *s);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strlen - Calculate the length of a string
|
||||||
|
* @s: '\0' terminated string
|
||||||
|
* Returns: Number of characters in s (not counting the '\0' terminator)
|
||||||
|
*/
|
||||||
|
size_t os_strlen(const char *s);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strcasecmp - Compare two strings ignoring case
|
||||||
|
* @s1: First string
|
||||||
|
* @s2: Second string
|
||||||
|
* Returns: An integer less than, equal to, or greater than zero if s1 is
|
||||||
|
* found to be less than, to match, or be greatred than s2
|
||||||
|
*/
|
||||||
|
int os_strcasecmp(const char *s1, const char *s2);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strncasecmp - Compare two strings ignoring case
|
||||||
|
* @s1: First string
|
||||||
|
* @s2: Second string
|
||||||
|
* @n: Maximum numbers of characters to compare
|
||||||
|
* Returns: An integer less than, equal to, or greater than zero if s1 is
|
||||||
|
* found to be less than, to match, or be greater than s2. Only first n
|
||||||
|
* characters will be compared.
|
||||||
|
*/
|
||||||
|
int os_strncasecmp(const char *s1, const char *s2, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strchr - Locate the first occurrence of a character in string
|
||||||
|
* @s: String
|
||||||
|
* @c: Character to search for
|
||||||
|
* Returns: Pointer to the matched character or %NULL if not found
|
||||||
|
*/
|
||||||
|
char *os_strchr(const char *s, int c);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strrchr - Locate the last occurrence of a character in string
|
||||||
|
* @s: String
|
||||||
|
* @c: Character to search for
|
||||||
|
* Returns: Pointer to the matched character or %NULL if not found
|
||||||
|
*/
|
||||||
|
char *os_strrchr(const char *s, int c);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strcmp - Compare two strings
|
||||||
|
* @s1: First string
|
||||||
|
* @s2: Second string
|
||||||
|
* Returns: An integer less than, equal to, or greater than zero if s1 is
|
||||||
|
* found to be less than, to match, or be greatred than s2
|
||||||
|
*/
|
||||||
|
int os_strcmp(const char *s1, const char *s2);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strncmp - Compare two strings
|
||||||
|
* @s1: First string
|
||||||
|
* @s2: Second string
|
||||||
|
* @n: Maximum numbers of characters to compare
|
||||||
|
* Returns: An integer less than, equal to, or greater than zero if s1 is
|
||||||
|
* found to be less than, to match, or be greater than s2. Only first n
|
||||||
|
* characters will be compared.
|
||||||
|
*/
|
||||||
|
int os_strncmp(const char *s1, const char *s2, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strncpy - Copy a string
|
||||||
|
* @dest: Destination
|
||||||
|
* @src: Source
|
||||||
|
* @n: Maximum number of characters to copy
|
||||||
|
* Returns: dest
|
||||||
|
*/
|
||||||
|
char *os_strncpy(char *dest, const char *src, size_t n);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_strstr - Locate a substring
|
||||||
|
* @haystack: String (haystack) to search from
|
||||||
|
* @needle: Needle to search from haystack
|
||||||
|
* Returns: Pointer to the beginning of the substring or %NULL if not found
|
||||||
|
*/
|
||||||
|
char *os_strstr(const char *haystack, const char *needle);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* os_snprintf - Print to a memory buffer
|
||||||
|
* @str: Memory buffer to print into
|
||||||
|
* @size: Maximum length of the str buffer
|
||||||
|
* @format: printf format
|
||||||
|
* Returns: Number of characters printed (not including trailing '\0').
|
||||||
|
*
|
||||||
|
* If the output buffer is truncated, number of characters which would have
|
||||||
|
* been written is returned. Since some C libraries return -1 in such a case,
|
||||||
|
* the caller must be prepared on that value, too, to indicate truncation.
|
||||||
|
*
|
||||||
|
* Note: Some C library implementations of snprintf() may not guarantee null
|
||||||
|
* termination in case the output is truncated. The OS wrapper function of
|
||||||
|
* os_snprintf() should provide this guarantee, i.e., to null terminate the
|
||||||
|
* output buffer if a C library version of the function is used and if that
|
||||||
|
* function does not guarantee null termination.
|
||||||
|
*
|
||||||
|
* If the target system does not include snprintf(), see, e.g.,
|
||||||
|
* http://www.ijs.si/software/snprintf/ for an example of a portable
|
||||||
|
* implementation of snprintf.
|
||||||
|
*/
|
||||||
|
int os_snprintf(char *str, size_t size, const char *format, ...);
|
||||||
|
|
||||||
|
#else /* OS_NO_C_LIB_DEFINES */
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_8195A) && !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#ifdef CONFIG_MEM_MONITOR
|
||||||
|
u8* os_malloc(u32 sz);
|
||||||
|
void os_mfree(u8 *pbuf, u32 sz);
|
||||||
|
#ifndef os_free
|
||||||
|
#define os_free(p, sz) os_mfree(((u8*)(p)), (sz))
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#ifndef os_malloc
|
||||||
|
#define os_malloc(sz) _rtw_malloc(sz)
|
||||||
|
#endif
|
||||||
|
#ifndef os_free
|
||||||
|
#define os_free(p, sz) _rtw_mfree(((u8*)(p)), (sz))
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
extern void *os_zalloc(size_t size);
|
||||||
|
extern char *os_strdup(const char *string_copy_from);
|
||||||
|
|
||||||
|
#ifndef os_sleep
|
||||||
|
#define os_sleep(s, us) rtw_mdelay_os((s)*1000 + (us)/1000)
|
||||||
|
#endif
|
||||||
|
#ifndef os_memcpy
|
||||||
|
#define os_memcpy(d, s, n) rtw_memcpy((void*)(d), ((void*)(s)), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_memmove
|
||||||
|
#define os_memmove(d, s, n) memmove((d), (s), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_memset
|
||||||
|
#define os_memset(pbuf, c, sz) rtw_memset(pbuf, c, sz)
|
||||||
|
#endif
|
||||||
|
#ifndef os_memcmp
|
||||||
|
#define os_memcmp(s1, s2, n) rtw_memcmp(((void*)(s1)), ((void*)(s2)), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_memcmp_p2p
|
||||||
|
#define os_memcmp_p2p(s1, s2, n) memcmp((s1), (s2), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_get_random_bytes
|
||||||
|
#define os_get_random_bytes(d,sz) rtw_get_random_bytes(((void*)(d)), (sz))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strlen
|
||||||
|
#define os_strlen(s) strlen(s)
|
||||||
|
#endif
|
||||||
|
#ifndef os_strcasecmp
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#define os_strcasecmp(s1, s2) _stricmp((s1), (s2))
|
||||||
|
#else
|
||||||
|
#define os_strcasecmp(s1, s2) strcasecmp((s1), (s2))
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#ifndef os_strncasecmp
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#define os_strncasecmp(s1, s2, n) _strnicmp((s1), (s2), (n))
|
||||||
|
#else
|
||||||
|
#define os_strncasecmp(s1, s2, n) strncasecmp((s1), (s2), (n))
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#ifndef os_init_timer
|
||||||
|
#define os_init_timer(t, p, f, x, n) rtw_init_timer((t), (p), (f), (x), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_set_timer
|
||||||
|
#define os_set_timer(t, d) rtw_set_timer((t), (d))
|
||||||
|
#endif
|
||||||
|
#ifndef os_cancel_timer
|
||||||
|
#define os_cancel_timer(t) rtw_cancel_timer(t)
|
||||||
|
#endif
|
||||||
|
#ifndef os_del_timer
|
||||||
|
#define os_del_timer(t) rtw_del_timer(t)
|
||||||
|
#endif
|
||||||
|
#ifndef os_atoi
|
||||||
|
#define os_atoi(s) rtw_atoi(s)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef os_strchr
|
||||||
|
#define os_strchr(s, c) strchr((s), (c))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strcmp
|
||||||
|
#define os_strcmp(s1, s2) strcmp((s1), (s2))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strncmp
|
||||||
|
#define os_strncmp(s1, s2, n) strncmp((s1), (s2), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strncpy
|
||||||
|
#define os_strncpy(d, s, n) strncpy((d), (s), (n))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strrchr
|
||||||
|
#define os_strrchr(s, c) strrchr((s), (c))
|
||||||
|
#endif
|
||||||
|
#ifndef os_strstr
|
||||||
|
#define os_strstr(h, n) strstr((h), (n))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef os_snprintf
|
||||||
|
#ifdef _MSC_VER
|
||||||
|
#define os_snprintf _snprintf
|
||||||
|
#else
|
||||||
|
#define os_snprintf snprintf
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* OS_NO_C_LIB_DEFINES */
|
||||||
|
|
||||||
|
|
||||||
|
static inline void * os_realloc_array(void *ptr, size_t nmemb, size_t size)
|
||||||
|
{
|
||||||
|
if (size && nmemb > (~(size_t) 0) / size)
|
||||||
|
return NULL;
|
||||||
|
return os_realloc(ptr, nmemb * size, nmemb * size);
|
||||||
|
}
|
||||||
|
|
||||||
|
void *os_xqueue_create(unsigned long uxQueueLength, unsigned long uxItemSize) ;
|
||||||
|
|
||||||
|
int os_xqueue_receive(xqueue_handle_t xQueue, void * const pvBuffer, unsigned long xSecsToWait);
|
||||||
|
|
||||||
|
void os_xqueue_delete(xqueue_handle_t xQueue );
|
||||||
|
|
||||||
|
int os_xqueue_send(xqueue_handle_t xQueue, const void * const pvItemToQueue, unsigned long xSecsToWait);
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* OS_H */
|
120
component/common/api/wifi/rtw_wpa_supplicant/src/utils/os_freertos.c
Executable file
120
component/common/api/wifi/rtw_wpa_supplicant/src/utils/os_freertos.c
Executable file
|
@ -0,0 +1,120 @@
|
||||||
|
/*
|
||||||
|
* OS specific functions for UNIX/POSIX systems
|
||||||
|
* Copyright (c) 2005-2009, Jouni Malinen <j@w1.fi>
|
||||||
|
*
|
||||||
|
* This software may be distributed under the terms of the BSD license.
|
||||||
|
* See README for more details.
|
||||||
|
*/
|
||||||
|
#include <autoconf.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_WPS
|
||||||
|
#include "utils/os.h"
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_8195A) && !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#ifdef CONFIG_MEM_MONITOR
|
||||||
|
#if CONFIG_MEM_MONITOR & MEM_MONITOR_LEAK
|
||||||
|
_list wpa_mem_table;
|
||||||
|
int wpa_mem_used_num;
|
||||||
|
//int wpa_mem_used_size;
|
||||||
|
#endif
|
||||||
|
extern int min_free_heap_size;
|
||||||
|
u8* os_malloc(u32 sz)
|
||||||
|
{
|
||||||
|
int free_heap_size = rtw_getFreeHeapSize();
|
||||||
|
u8 *pbuf = _rtw_malloc(sz);
|
||||||
|
#if CONFIG_MEM_MONITOR & MEM_MONITOR_LEAK
|
||||||
|
add_mem_usage(&wpa_mem_table, pbuf, sz, &wpa_mem_used_num, MEM_MONITOR_FLAG_WPAS);
|
||||||
|
#else
|
||||||
|
add_mem_usage(NULL, pbuf, sz, NULL, MEM_MONITOR_FLAG_WPAS);
|
||||||
|
#endif
|
||||||
|
if(min_free_heap_size > free_heap_size)
|
||||||
|
min_free_heap_size = free_heap_size;
|
||||||
|
return pbuf;
|
||||||
|
}
|
||||||
|
|
||||||
|
void os_mfree(u8 *pbuf, u32 sz)
|
||||||
|
{
|
||||||
|
_rtw_mfree(pbuf, sz);
|
||||||
|
#if CONFIG_MEM_MONITOR & MEM_MONITOR_LEAK
|
||||||
|
del_mem_usage(&wpa_mem_table, pbuf, &wpa_mem_used_num, MEM_MONITOR_FLAG_WPAS);
|
||||||
|
#else
|
||||||
|
del_mem_usage(NULL, pbuf, NULL, MEM_MONITOR_FLAG_WPAS);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif//CONFIG_MEM_MONITOR
|
||||||
|
|
||||||
|
#endif// !defined(CONFIG_PLATFORM_8195A)
|
||||||
|
|
||||||
|
#ifndef OS_NO_C_LIB_DEFINES
|
||||||
|
char *os_strdup(const char *string_copy_from)
|
||||||
|
{
|
||||||
|
char *string_copy_to = NULL;
|
||||||
|
string_copy_to = os_zalloc(strlen(string_copy_from) + 1);
|
||||||
|
os_memcpy((void *)string_copy_to, string_copy_from, strlen(string_copy_from));
|
||||||
|
string_copy_to[strlen(string_copy_from)] = '\0';
|
||||||
|
return string_copy_to;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int os_get_random(unsigned char *buf, size_t len)
|
||||||
|
{
|
||||||
|
//TODO implement it
|
||||||
|
rtw_get_random_bytes(buf, len);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_get_time(struct os_time *t){
|
||||||
|
unsigned int tt = rtw_get_current_time();
|
||||||
|
t->sec = (os_time_t) (tt / 1000);
|
||||||
|
t->usec = (os_time_t) (tt % 1000)*1000;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_get_reltime(struct os_reltime *t){
|
||||||
|
os_get_time((struct os_time *)t);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#if 0
|
||||||
|
void *os_xqueue_create(unsigned long uxQueueLength, unsigned long uxItemSize)
|
||||||
|
{
|
||||||
|
return xQueueCreate( uxQueueLength, uxItemSize );
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_xqueue_receive(xqueue_handle_t xQueue, void * const pvBuffer, unsigned long xSecsToWait)
|
||||||
|
{
|
||||||
|
return xQueueReceive((xQueueHandle)xQueue, pvBuffer, (portTickType)(xSecsToWait*configTICK_RATE_HZ));
|
||||||
|
}
|
||||||
|
|
||||||
|
void os_xqueue_delete(xqueue_handle_t xQueue )
|
||||||
|
{
|
||||||
|
vQueueDelete((xQueueHandle)xQueue);
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_xqueue_send(xqueue_handle_t xQueue, const void * const pvItemToQueue, unsigned long xSecsToWait)
|
||||||
|
{
|
||||||
|
return xQueueSendToBack((xQueueHandle)xQueue, pvItemToQueue, (portTickType)(xSecsToWait*configTICK_RATE_HZ));
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
void *os_xqueue_create(unsigned long uxQueueLength, unsigned long uxItemSize)
|
||||||
|
{
|
||||||
|
void* xQueue = NULL;
|
||||||
|
rtw_init_xqueue(&xQueue, "queue", uxItemSize, uxQueueLength);
|
||||||
|
return xQueue;
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_xqueue_receive(xqueue_handle_t xQueue, void * const pvBuffer, unsigned long xSecsToWait)
|
||||||
|
{
|
||||||
|
return rtw_pop_from_xqueue(&xQueue, pvBuffer, xSecsToWait*1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
void os_xqueue_delete(xqueue_handle_t xQueue )
|
||||||
|
{
|
||||||
|
rtw_deinit_xqueue(&xQueue);
|
||||||
|
}
|
||||||
|
|
||||||
|
int os_xqueue_send(xqueue_handle_t xQueue, const void * const pvItemToQueue, unsigned long xSecsToWait)
|
||||||
|
{
|
||||||
|
return rtw_push_to_xqueue(&xQueue, (void*)pvItemToQueue, xSecsToWait*1000);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
24
component/common/api/wifi/rtw_wpa_supplicant/src/utils/rom/rom_wps_os.h
Executable file
24
component/common/api/wifi/rtw_wpa_supplicant/src/utils/rom/rom_wps_os.h
Executable file
|
@ -0,0 +1,24 @@
|
||||||
|
/*
|
||||||
|
* OS specific functions
|
||||||
|
* Copyright (c) 2005-2009, Jouni Malinen <j@w1.fi>
|
||||||
|
*
|
||||||
|
* This software may be distributed under the terms of the BSD license.
|
||||||
|
* See README for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ROM_WPS_OS_H
|
||||||
|
#define ROM_WPS_OS_H
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
|
||||||
|
#include <rom_wlan_ram_map.h>
|
||||||
|
extern struct _rom_wlan_ram_map rom_wlan_ram_map;
|
||||||
|
#define os_malloc(sz) rom_wlan_ram_map.rtw_malloc(sz)
|
||||||
|
#define os_free(p, sz) rom_wlan_ram_map.rtw_mfree(((u8*)(p)), (sz))
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern u8 *WPS_realloc(u8 *old_buf, u32 old_sz, u32 new_sz);
|
||||||
|
#define os_realloc(p, os, ns) WPS_realloc(((u8*)(p)),(os),(ns))
|
||||||
|
|
||||||
|
#endif /* ROM_WPS_OS_H */
|
319
component/common/api/wifi/rtw_wpa_supplicant/src/wps/wps_defs.h
Executable file
319
component/common/api/wifi/rtw_wpa_supplicant/src/wps/wps_defs.h
Executable file
|
@ -0,0 +1,319 @@
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Wi-Fi Protected Setup - message definitions
|
||||||
|
* Copyright (c) 2008, Jouni Malinen <j@w1.fi>
|
||||||
|
*
|
||||||
|
* This software may be distributed under the terms of the BSD license.
|
||||||
|
* See README for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef WPS_DEFS_H
|
||||||
|
#define WPS_DEFS_H
|
||||||
|
|
||||||
|
|
||||||
|
/* Diffie-Hellman 1536-bit MODP Group; RFC 3526, Group 5 */
|
||||||
|
#define WPS_DH_GROUP (5)
|
||||||
|
|
||||||
|
#define WPS_UUID_LEN (16)
|
||||||
|
#define WPS_NONCE_LEN (16)
|
||||||
|
#define WPS_AUTHENTICATOR_LEN (8)
|
||||||
|
#define WPS_AUTHKEY_LEN (32)
|
||||||
|
#define WPS_KEYWRAPKEY_LEN (16)
|
||||||
|
#define WPS_EMSK_LEN (32)
|
||||||
|
#define WPS_PSK_LEN (16)
|
||||||
|
#define WPS_SECRET_NONCE_LEN (16)
|
||||||
|
#define WPS_HASH_LEN (32)
|
||||||
|
#define WPS_KWA_LEN (8)
|
||||||
|
#define WPS_MGMTAUTHKEY_LEN (32)
|
||||||
|
#define WPS_MGMTENCKEY_LEN (16)
|
||||||
|
#define WPS_MGMT_KEY_ID_LEN (16)
|
||||||
|
#define WPS_OOB_DEVICE_PASSWORD_MIN_LEN (16)
|
||||||
|
#define WPS_OOB_DEVICE_PASSWORD_LEN (32)
|
||||||
|
#define WPS_OOB_PUBKEY_HASH_LEN (20)
|
||||||
|
|
||||||
|
/* Attribute Types */
|
||||||
|
enum wps_attribute {
|
||||||
|
ATTR_AP_CHANNEL = 0x1001,
|
||||||
|
ATTR_ASSOC_STATE = 0x1002,
|
||||||
|
ATTR_AUTH_TYPE = 0x1003,
|
||||||
|
ATTR_AUTH_TYPE_FLAGS = 0x1004,
|
||||||
|
ATTR_AUTHENTICATOR = 0x1005,
|
||||||
|
ATTR_CONFIG_METHODS = 0x1008,
|
||||||
|
ATTR_CONFIG_ERROR = 0x1009,
|
||||||
|
ATTR_CONFIRM_URL4 = 0x100a,
|
||||||
|
ATTR_CONFIRM_URL6 = 0x100b,
|
||||||
|
ATTR_CONN_TYPE = 0x100c,
|
||||||
|
ATTR_CONN_TYPE_FLAGS = 0x100d,
|
||||||
|
ATTR_CRED = 0x100e,
|
||||||
|
ATTR_ENCR_TYPE = 0x100f,
|
||||||
|
ATTR_ENCR_TYPE_FLAGS = 0x1010,
|
||||||
|
ATTR_DEV_NAME = 0x1011,
|
||||||
|
ATTR_DEV_PASSWORD_ID = 0x1012,
|
||||||
|
ATTR_E_HASH1 = 0x1014,
|
||||||
|
ATTR_E_HASH2 = 0x1015,
|
||||||
|
ATTR_E_SNONCE1 = 0x1016,
|
||||||
|
ATTR_E_SNONCE2 = 0x1017,
|
||||||
|
ATTR_ENCR_SETTINGS = 0x1018,
|
||||||
|
ATTR_ENROLLEE_NONCE = 0x101a,
|
||||||
|
ATTR_FEATURE_ID = 0x101b,
|
||||||
|
ATTR_IDENTITY = 0x101c,
|
||||||
|
ATTR_IDENTITY_PROOF = 0x101d,
|
||||||
|
ATTR_KEY_WRAP_AUTH = 0x101e,
|
||||||
|
ATTR_KEY_ID = 0x101f,
|
||||||
|
ATTR_MAC_ADDR = 0x1020,
|
||||||
|
ATTR_MANUFACTURER = 0x1021,
|
||||||
|
ATTR_MSG_TYPE = 0x1022,
|
||||||
|
ATTR_MODEL_NAME = 0x1023,
|
||||||
|
ATTR_MODEL_NUMBER = 0x1024,
|
||||||
|
ATTR_NETWORK_INDEX = 0x1026,
|
||||||
|
ATTR_NETWORK_KEY = 0x1027,
|
||||||
|
ATTR_NETWORK_KEY_INDEX = 0x1028,
|
||||||
|
ATTR_NEW_DEVICE_NAME = 0x1029,
|
||||||
|
ATTR_NEW_PASSWORD = 0x102a,
|
||||||
|
ATTR_OOB_DEVICE_PASSWORD = 0x102c,
|
||||||
|
ATTR_OS_VERSION = 0x102d,
|
||||||
|
ATTR_POWER_LEVEL = 0x102f,
|
||||||
|
ATTR_PSK_CURRENT = 0x1030,
|
||||||
|
ATTR_PSK_MAX = 0x1031,
|
||||||
|
ATTR_PUBLIC_KEY = 0x1032,
|
||||||
|
ATTR_RADIO_ENABLE = 0x1033,
|
||||||
|
ATTR_REBOOT = 0x1034,
|
||||||
|
ATTR_REGISTRAR_CURRENT = 0x1035,
|
||||||
|
ATTR_REGISTRAR_ESTABLISHED = 0x1036,
|
||||||
|
ATTR_REGISTRAR_LIST = 0x1037,
|
||||||
|
ATTR_REGISTRAR_MAX = 0x1038,
|
||||||
|
ATTR_REGISTRAR_NONCE = 0x1039,
|
||||||
|
ATTR_REQUEST_TYPE = 0x103a,
|
||||||
|
ATTR_RESPONSE_TYPE = 0x103b,
|
||||||
|
ATTR_RF_BANDS = 0x103c,
|
||||||
|
ATTR_R_HASH1 = 0x103d,
|
||||||
|
ATTR_R_HASH2 = 0x103e,
|
||||||
|
ATTR_R_SNONCE1 = 0x103f,
|
||||||
|
ATTR_R_SNONCE2 = 0x1040,
|
||||||
|
ATTR_SELECTED_REGISTRAR = 0x1041,
|
||||||
|
ATTR_SERIAL_NUMBER = 0x1042,
|
||||||
|
ATTR_WPS_STATE = 0x1044,
|
||||||
|
ATTR_SSID = 0x1045,
|
||||||
|
ATTR_TOTAL_NETWORKS = 0x1046,
|
||||||
|
ATTR_UUID_E = 0x1047,
|
||||||
|
ATTR_UUID_R = 0x1048,
|
||||||
|
ATTR_VENDOR_EXT = 0x1049,
|
||||||
|
ATTR_VERSION = 0x104a,
|
||||||
|
ATTR_X509_CERT_REQ = 0x104b,
|
||||||
|
ATTR_X509_CERT = 0x104c,
|
||||||
|
ATTR_EAP_IDENTITY = 0x104d,
|
||||||
|
ATTR_MSG_COUNTER = 0x104e,
|
||||||
|
ATTR_PUBKEY_HASH = 0x104f,
|
||||||
|
ATTR_REKEY_KEY = 0x1050,
|
||||||
|
ATTR_KEY_LIFETIME = 0x1051,
|
||||||
|
ATTR_PERMITTED_CFG_METHODS = 0x1052,
|
||||||
|
ATTR_SELECTED_REGISTRAR_CONFIG_METHODS = 0x1053,
|
||||||
|
ATTR_PRIMARY_DEV_TYPE = 0x1054,
|
||||||
|
ATTR_SECONDARY_DEV_TYPE_LIST = 0x1055,
|
||||||
|
ATTR_PORTABLE_DEV = 0x1056,
|
||||||
|
ATTR_AP_SETUP_LOCKED = 0x1057,
|
||||||
|
ATTR_APPLICATION_EXT = 0x1058,
|
||||||
|
ATTR_EAP_TYPE = 0x1059,
|
||||||
|
ATTR_IV = 0x1060,
|
||||||
|
ATTR_KEY_PROVIDED_AUTO = 0x1061,
|
||||||
|
ATTR_802_1X_ENABLED = 0x1062,
|
||||||
|
ATTR_APPSESSIONKEY = 0x1063,
|
||||||
|
ATTR_WEPTRANSMITKEY = 0x1064,
|
||||||
|
ATTR_REQUESTED_DEV_TYPE = 0x106a,
|
||||||
|
ATTR_EXTENSIBILITY_TEST = 0x10fa /* _NOT_ defined in the spec */
|
||||||
|
};
|
||||||
|
|
||||||
|
#define WPS_VENDOR_ID_WFA 14122
|
||||||
|
|
||||||
|
/* WFA Vendor Extension subelements */
|
||||||
|
enum {
|
||||||
|
WFA_ELEM_VERSION2 = 0x00,
|
||||||
|
WFA_ELEM_AUTHORIZEDMACS = 0x01,
|
||||||
|
WFA_ELEM_NETWORK_KEY_SHAREABLE = 0x02,
|
||||||
|
WFA_ELEM_REQUEST_TO_ENROLL = 0x03,
|
||||||
|
WFA_ELEM_SETTINGS_DELAY_TIME = 0x04
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Device Password ID */
|
||||||
|
enum wps_dev_password_id {
|
||||||
|
DEV_PW_DEFAULT = 0x0000,
|
||||||
|
DEV_PW_USER_SPECIFIED = 0x0001,
|
||||||
|
DEV_PW_MACHINE_SPECIFIED = 0x0002,
|
||||||
|
DEV_PW_REKEY = 0x0003,
|
||||||
|
DEV_PW_PUSHBUTTON = 0x0004,
|
||||||
|
DEV_PW_REGISTRAR_SPECIFIED = 0x0005
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Message Type */
|
||||||
|
enum wps_msg_type {
|
||||||
|
WPS_START = 0x00,
|
||||||
|
WPS_Beacon = 0x01,
|
||||||
|
WPS_ProbeRequest = 0x02,
|
||||||
|
WPS_ProbeResponse = 0x03,
|
||||||
|
WPS_M1 = 0x04,
|
||||||
|
WPS_M2 = 0x05,
|
||||||
|
WPS_M2D = 0x06,
|
||||||
|
WPS_M3 = 0x07,
|
||||||
|
WPS_M4 = 0x08,
|
||||||
|
WPS_M5 = 0x09,
|
||||||
|
WPS_M6 = 0x0a,
|
||||||
|
WPS_M7 = 0x0b,
|
||||||
|
WPS_M8 = 0x0c,
|
||||||
|
WPS_WSC_ACK = 0x0d,
|
||||||
|
WPS_WSC_NACK = 0x0e,
|
||||||
|
WPS_WSC_DONE = 0x0f
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Authentication Type Flags */
|
||||||
|
#define WPS_AUTH_OPEN 0x0001
|
||||||
|
#define WPS_AUTH_WPAPSK 0x0002
|
||||||
|
#define WPS_AUTH_SHARED 0x0004
|
||||||
|
#define WPS_AUTH_WPA 0x0008
|
||||||
|
#define WPS_AUTH_WPA2 0x0010
|
||||||
|
#define WPS_AUTH_WPA2PSK 0x0020
|
||||||
|
#define WPS_AUTH_TYPES (WPS_AUTH_OPEN | WPS_AUTH_WPAPSK | WPS_AUTH_SHARED | \
|
||||||
|
WPS_AUTH_WPA | WPS_AUTH_WPA2 | WPS_AUTH_WPA2PSK)
|
||||||
|
|
||||||
|
/* Encryption Type Flags */
|
||||||
|
#define WPS_ENCR_NONE 0x0001
|
||||||
|
#define WPS_ENCR_WEP 0x0002
|
||||||
|
#define WPS_ENCR_TKIP 0x0004
|
||||||
|
#define WPS_ENCR_AES 0x0008
|
||||||
|
#define WPS_ENCR_TYPES (WPS_ENCR_NONE | WPS_ENCR_WEP | WPS_ENCR_TKIP | \
|
||||||
|
WPS_ENCR_AES)
|
||||||
|
|
||||||
|
/* Configuration Error */
|
||||||
|
enum wps_config_error {
|
||||||
|
WPS_CFG_NO_ERROR = 0,
|
||||||
|
WPS_CFG_OOB_IFACE_READ_ERROR = 1,
|
||||||
|
WPS_CFG_DECRYPTION_CRC_FAILURE = 2,
|
||||||
|
WPS_CFG_24_CHAN_NOT_SUPPORTED = 3,
|
||||||
|
WPS_CFG_50_CHAN_NOT_SUPPORTED = 4,
|
||||||
|
WPS_CFG_SIGNAL_TOO_WEAK = 5,
|
||||||
|
WPS_CFG_NETWORK_AUTH_FAILURE = 6,
|
||||||
|
WPS_CFG_NETWORK_ASSOC_FAILURE = 7,
|
||||||
|
WPS_CFG_NO_DHCP_RESPONSE = 8,
|
||||||
|
WPS_CFG_FAILED_DHCP_CONFIG = 9,
|
||||||
|
WPS_CFG_IP_ADDR_CONFLICT = 10,
|
||||||
|
WPS_CFG_NO_CONN_TO_REGISTRAR = 11,
|
||||||
|
WPS_CFG_MULTIPLE_PBC_DETECTED = 12,
|
||||||
|
WPS_CFG_ROGUE_SUSPECTED = 13,
|
||||||
|
WPS_CFG_DEVICE_BUSY = 14,
|
||||||
|
WPS_CFG_SETUP_LOCKED = 15,
|
||||||
|
WPS_CFG_MSG_TIMEOUT = 16,
|
||||||
|
WPS_CFG_REG_SESS_TIMEOUT = 17,
|
||||||
|
WPS_CFG_DEV_PASSWORD_AUTH_FAILURE = 18
|
||||||
|
};
|
||||||
|
|
||||||
|
/* RF Bands */
|
||||||
|
#define WPS_RF_24GHZ (0x01)
|
||||||
|
#define WPS_RF_50GHZ (0x02)
|
||||||
|
|
||||||
|
/* Config Methods */
|
||||||
|
#define WPS_CONFIG_USBA (0x0001)
|
||||||
|
#define WPS_CONFIG_ETHERNET (0x0002)
|
||||||
|
#define WPS_CONFIG_LABEL (0x0004)
|
||||||
|
#define WPS_CONFIG_DISPLAY (0x0008)
|
||||||
|
#define WPS_CONFIG_EXT_NFC_TOKEN (0x0010)
|
||||||
|
#define WPS_CONFIG_INT_NFC_TOKEN (0x0020)
|
||||||
|
#define WPS_CONFIG_NFC_INTERFACE (0x0040)
|
||||||
|
#define WPS_CONFIG_PUSHBUTTON (0x0080)
|
||||||
|
#define WPS_CONFIG_KEYPAD (0x0100)
|
||||||
|
|
||||||
|
#ifdef CONFIG_WPS2
|
||||||
|
#define WPS_CONFIG_VIRT_PUSHBUTTON (0x0280)
|
||||||
|
#define WPS_CONFIG_PHY_PUSHBUTTON (0x0480)
|
||||||
|
#define WPS_CONFIG_VIRT_DISPLAY (0x2008)
|
||||||
|
#define WPS_CONFIG_PHY_DISPLAY (0x4008)
|
||||||
|
#endif /* CONFIG_WPS2 */
|
||||||
|
|
||||||
|
/* Connection Type Flags */
|
||||||
|
#define WPS_CONN_ESS (0x01)
|
||||||
|
#define WPS_CONN_IBSS (0x02)
|
||||||
|
|
||||||
|
/* Wi-Fi Protected Setup State */
|
||||||
|
enum wps_state {
|
||||||
|
WPS_STATE_NOT_CONFIGURED = 1,
|
||||||
|
WPS_STATE_CONFIGURED = 2
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Association State */
|
||||||
|
enum wps_assoc_state {
|
||||||
|
WPS_ASSOC_NOT_ASSOC = 0,
|
||||||
|
WPS_ASSOC_CONN_SUCCESS = 1,
|
||||||
|
WPS_ASSOC_CFG_FAILURE = 2,
|
||||||
|
WPS_ASSOC_FAILURE = 3,
|
||||||
|
WPS_ASSOC_IP_FAILURE = 4
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#define WPS_DEV_OUI_WFA (0x0050f204)
|
||||||
|
|
||||||
|
enum wps_dev_categ {
|
||||||
|
WPS_DEV_COMPUTER = 1,
|
||||||
|
WPS_DEV_INPUT = 2,
|
||||||
|
WPS_DEV_PRINTER = 3,
|
||||||
|
WPS_DEV_CAMERA = 4,
|
||||||
|
WPS_DEV_STORAGE = 5,
|
||||||
|
WPS_DEV_NETWORK_INFRA = 6,
|
||||||
|
WPS_DEV_DISPLAY = 7,
|
||||||
|
WPS_DEV_MULTIMEDIA = 8,
|
||||||
|
WPS_DEV_GAMING = 9,
|
||||||
|
WPS_DEV_PHONE = 10
|
||||||
|
};
|
||||||
|
|
||||||
|
enum wps_dev_subcateg {
|
||||||
|
WPS_DEV_COMPUTER_PC = 1,
|
||||||
|
WPS_DEV_COMPUTER_SERVER = 2,
|
||||||
|
WPS_DEV_COMPUTER_MEDIA_CENTER = 3,
|
||||||
|
|
||||||
|
WPS_DEV_PRINTER_PRINTER = 1,
|
||||||
|
WPS_DEV_PRINTER_SCANNER = 2,
|
||||||
|
|
||||||
|
WPS_DEV_CAMERA_DIGITAL_STILL_CAMERA = 1,
|
||||||
|
|
||||||
|
WPS_DEV_STORAGE_NAS = 1,
|
||||||
|
|
||||||
|
WPS_DEV_NETWORK_INFRA_AP = 1,
|
||||||
|
WPS_DEV_NETWORK_INFRA_ROUTER = 2,
|
||||||
|
WPS_DEV_NETWORK_INFRA_SWITCH = 3,
|
||||||
|
|
||||||
|
WPS_DEV_DISPLAY_TV = 1,
|
||||||
|
WPS_DEV_DISPLAY_PICTURE_FRAME = 2,
|
||||||
|
WPS_DEV_DISPLAY_PROJECTOR = 3,
|
||||||
|
|
||||||
|
WPS_DEV_MULTIMEDIA_DAR = 1,
|
||||||
|
WPS_DEV_MULTIMEDIA_PVR = 2,
|
||||||
|
WPS_DEV_MULTIMEDIA_MCX = 3,
|
||||||
|
|
||||||
|
WPS_DEV_GAMING_XBOX = 1,
|
||||||
|
WPS_DEV_GAMING_XBOX360 = 2,
|
||||||
|
WPS_DEV_GAMING_PLAYSTATION = 3,
|
||||||
|
|
||||||
|
WPS_DEV_PHONE_WINDOWS_MOBILE = 1
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* Request Type */
|
||||||
|
enum wps_request_type {
|
||||||
|
WPS_REQ_ENROLLEE_INFO = 0,
|
||||||
|
WPS_REQ_ENROLLEE = 1,
|
||||||
|
WPS_REQ_REGISTRAR = 2,
|
||||||
|
WPS_REQ_WLAN_MANAGER_REGISTRAR = 3
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Response Type */
|
||||||
|
enum wps_response_type {
|
||||||
|
WPS_RESP_ENROLLEE_INFO = 0,
|
||||||
|
WPS_RESP_ENROLLEE = 1,
|
||||||
|
WPS_RESP_REGISTRAR = 2,
|
||||||
|
WPS_RESP_AP = 3
|
||||||
|
};
|
||||||
|
|
||||||
|
/* Walk Time for push button configuration (in seconds) */
|
||||||
|
#define WPS_PBC_WALK_TIME (120)
|
||||||
|
|
||||||
|
#define WPS_MAX_AUTHORIZED_MACS (5)
|
||||||
|
|
||||||
|
#endif /* WPS_DEFS_H */
|
||||||
|
|
531
component/common/api/wifi/rtw_wpa_supplicant/wpa_supplicant/wifi_wps_config.c
Executable file
531
component/common/api/wifi/rtw_wpa_supplicant/wpa_supplicant/wifi_wps_config.c
Executable file
|
@ -0,0 +1,531 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "queue.h"
|
||||||
|
#include "utils/os.h"
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <lwip/netif.h>
|
||||||
|
#include "wifi/wifi_conf.h"
|
||||||
|
#include "wps/wps_defs.h"
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
/**
|
||||||
|
* struct wps_credential - WPS Credential
|
||||||
|
* @ssid: SSID
|
||||||
|
* @ssid_len: Length of SSID
|
||||||
|
* @auth_type: Authentication Type (WPS_AUTH_OPEN, .. flags)
|
||||||
|
* @encr_type: Encryption Type (WPS_ENCR_NONE, .. flags)
|
||||||
|
* @key_idx: Key index
|
||||||
|
* @key: Key
|
||||||
|
* @key_len: Key length in octets
|
||||||
|
* @mac_addr: MAC address of the Credential receiver
|
||||||
|
* @cred_attr: Unparsed Credential attribute data (used only in cred_cb());
|
||||||
|
* this may be %NULL, if not used
|
||||||
|
* @cred_attr_len: Length of cred_attr in octets
|
||||||
|
* @ap_channel: AP channel
|
||||||
|
*/
|
||||||
|
struct dev_credential {
|
||||||
|
u8 ssid[32];
|
||||||
|
size_t ssid_len;
|
||||||
|
u16 auth_type;
|
||||||
|
u16 encr_type;
|
||||||
|
u8 key_idx;
|
||||||
|
u8 key[65];
|
||||||
|
size_t key_len;
|
||||||
|
u8 mac_addr[6];
|
||||||
|
const u8 *cred_attr;
|
||||||
|
size_t cred_attr_len;
|
||||||
|
u16 ap_channel;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char *target_ssid;
|
||||||
|
u16 config_method;
|
||||||
|
_sema scan_sema;
|
||||||
|
int isoverlap;
|
||||||
|
} internal_wps_scan_handler_arg_t;
|
||||||
|
|
||||||
|
#define WLAN0_NAME "wlan0"
|
||||||
|
#ifndef ENABLE
|
||||||
|
#define ENABLE (1)
|
||||||
|
#endif
|
||||||
|
#ifndef DISABLE
|
||||||
|
#define DISABLE (0)
|
||||||
|
#endif
|
||||||
|
#define STACKSIZE 512
|
||||||
|
|
||||||
|
|
||||||
|
//static xSemaphoreHandle wps_reconnect_semaphore;
|
||||||
|
//static struct _WIFI_NETWORK wifi_get_from_certificate = {0};
|
||||||
|
|
||||||
|
#define WPS_AUTH_TYPE_OPEN (0x0001)
|
||||||
|
#define WPS_AUTH_TYPE_WPA_PERSONAL (0x0002)
|
||||||
|
#define WPS_AUTH_TYPE_WPA_ENTERPRISE (0x0008)
|
||||||
|
#define WPS_AUTH_TYPE_WPA2_PERSONAL (0x0010)
|
||||||
|
#define WPS_AUTH_TYPE_WPA2_ENTERPRISE (0x0020)
|
||||||
|
|
||||||
|
#define SCAN_BUFFER_LENGTH (4096)
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_WPS
|
||||||
|
#if CONFIG_ENABLE_WPS
|
||||||
|
xqueue_handle_t queue_for_credential;
|
||||||
|
char wps_pin_code[32];
|
||||||
|
u16 config_method;
|
||||||
|
u8 wps_password_id;
|
||||||
|
|
||||||
|
void wps_check_and_show_connection_info(void)
|
||||||
|
{
|
||||||
|
rtw_wifi_setting_t setting;
|
||||||
|
#if CONFIG_LWIP_LAYER
|
||||||
|
/* Start DHCP Client */
|
||||||
|
LwIP_DHCP(0, DHCP_START);
|
||||||
|
#endif
|
||||||
|
wifi_get_setting(WLAN0_NAME, &setting);
|
||||||
|
wifi_show_setting(WLAN0_NAME, &setting);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wps_config_wifi_setting(rtw_network_info_t *wifi, struct dev_credential *dev_cred)
|
||||||
|
{
|
||||||
|
printf("\r\nwps_config_wifi_setting\n");
|
||||||
|
//memcpy((void *)wifi->ssid, (void *)dev_cred->ssid, dev_cred->ssid_len);
|
||||||
|
strcpy((char*)wifi->ssid.val, (char*)&dev_cred->ssid[0]);
|
||||||
|
printf("\r\nwps_wifi.ssid = %s\n", wifi->ssid.val);
|
||||||
|
wifi->ssid.len = dev_cred->ssid_len;
|
||||||
|
printf("\r\nwps_wifi.ssid_len = %d\n", wifi->ssid.len);
|
||||||
|
|
||||||
|
switch(dev_cred->auth_type) {
|
||||||
|
case WPS_AUTH_TYPE_OPEN :
|
||||||
|
printf("\r\nsecurity_type = RTW_SECURITY_OPEN\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_OPEN;
|
||||||
|
break;
|
||||||
|
case WPS_AUTH_TYPE_WPA_PERSONAL :
|
||||||
|
case WPS_AUTH_TYPE_WPA_ENTERPRISE :
|
||||||
|
printf("\r\nsecurity_type = RTW_SECURITY_WPA_AES_PSK\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_WPA_AES_PSK;
|
||||||
|
break;
|
||||||
|
case WPS_AUTH_TYPE_WPA2_PERSONAL :
|
||||||
|
case WPS_AUTH_TYPE_WPA2_ENTERPRISE :
|
||||||
|
printf("\r\nsecurity_type = RTW_SECURITY_WPA2_AES_PSK\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_WPA2_AES_PSK;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("\r\nwps_wifi.security_type = %d\n", wifi->security_type);
|
||||||
|
|
||||||
|
//memcpy(wifi->password, dev_cred->key, dev_cred->key_len);
|
||||||
|
wifi->password = dev_cred->key;
|
||||||
|
printf("\r\nwps_wifi.password = %s\n", wifi->password);
|
||||||
|
wifi->password_len = dev_cred->key_len;
|
||||||
|
printf("\r\nwps_wifi.password_len = %d", wifi->password_len);
|
||||||
|
//xSemaphoreGive(wps_reconnect_semaphore);
|
||||||
|
//printf("\r\nrelease wps_reconnect_semaphore");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void wps_connect_to_AP_by_certificate(rtw_network_info_t *wifi)
|
||||||
|
{
|
||||||
|
#define RETRY_COUNT 3
|
||||||
|
int retry_count = RETRY_COUNT, ret;
|
||||||
|
|
||||||
|
printf("\r\n=============== wifi_certificate_info ===============\n");
|
||||||
|
printf("\r\nwps_wifi.ssid = %s\n", wifi->ssid.val);
|
||||||
|
printf("\r\nsecurity_type = %d\n", wifi->security_type);
|
||||||
|
printf("\r\nwps_wifi.password = %s\n", wifi->password);
|
||||||
|
printf("\r\nssid_len = %d\n", wifi->ssid.len);
|
||||||
|
printf("\r\npassword_len = %d\n", wifi->password_len);
|
||||||
|
while (1) {
|
||||||
|
ret = wifi_connect((char*)wifi->ssid.val,
|
||||||
|
wifi->security_type,
|
||||||
|
(char*)wifi->password,
|
||||||
|
wifi->ssid.len,
|
||||||
|
wifi->password_len,
|
||||||
|
wifi->key_id,
|
||||||
|
NULL);
|
||||||
|
if (ret == RTW_SUCCESS) {
|
||||||
|
if(retry_count == RETRY_COUNT)
|
||||||
|
rtw_msleep_os(1000); //When start wps with OPEN AP, AP will send a disassociate frame after STA connected, need reconnect here.
|
||||||
|
if(RTW_SUCCESS == wifi_is_connected_to_ap( )){
|
||||||
|
//printf("\r\n[WPS]Ready to tranceive!!\n");
|
||||||
|
wps_check_and_show_connection_info();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (retry_count == 0) {
|
||||||
|
printf("\r\n[WPS]Join bss failed\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
retry_count --;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int wps_connect_to_AP_by_open_system(char *target_ssid)
|
||||||
|
{
|
||||||
|
int retry_count = 3, ret;
|
||||||
|
|
||||||
|
if (target_ssid != NULL) {
|
||||||
|
rtw_msleep_os(500); //wait scan complete.
|
||||||
|
while (1) {
|
||||||
|
ret = wifi_connect(target_ssid,
|
||||||
|
RTW_SECURITY_OPEN,
|
||||||
|
NULL,
|
||||||
|
strlen(target_ssid),
|
||||||
|
0,
|
||||||
|
0,
|
||||||
|
NULL);
|
||||||
|
if (ret == RTW_SUCCESS) {
|
||||||
|
//wps_check_and_show_connection_info();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (retry_count == 0) {
|
||||||
|
printf("\r\n[WPS]Join bss failed\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
retry_count --;
|
||||||
|
}
|
||||||
|
//
|
||||||
|
} else {
|
||||||
|
printf("\r\n[WPS]Target SSID is NULL\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void process_wps_scan_result( rtw_scan_result_t* record, void * user_data )
|
||||||
|
{
|
||||||
|
internal_wps_scan_handler_arg_t *wps_arg = (internal_wps_scan_handler_arg_t *)user_data;
|
||||||
|
|
||||||
|
if (record->wps_type != 0xff) {
|
||||||
|
if (wps_arg->config_method == WPS_CONFIG_PUSHBUTTON) {
|
||||||
|
if (record->wps_type == 0x04) {
|
||||||
|
wps_password_id = record->wps_type;
|
||||||
|
if (++wps_arg->isoverlap == 0) {
|
||||||
|
memcpy(&wps_arg->target_ssid[0], record->SSID.val, record->SSID.len);
|
||||||
|
wps_arg->target_ssid[record->SSID.len] = '\0';
|
||||||
|
printf("\r\n[pbc]Record first triger wps AP = %s\n", wps_arg->target_ssid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (wps_arg->config_method == WPS_CONFIG_DISPLAY) {
|
||||||
|
if (record->wps_type == 0x00) {
|
||||||
|
wps_arg->isoverlap = 0;
|
||||||
|
wps_password_id = record->wps_type;
|
||||||
|
memcpy(&wps_arg->target_ssid[0], record->SSID.val, record->SSID.len);
|
||||||
|
wps_arg->target_ssid[record->SSID.len] = '\0';
|
||||||
|
printf("\r\n[pin]find out first triger wps AP = %s\n", wps_arg->target_ssid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static rtw_result_t wps_scan_result_handler( rtw_scan_handler_result_t* malloced_scan_result )
|
||||||
|
{
|
||||||
|
internal_wps_scan_handler_arg_t *wps_arg = (internal_wps_scan_handler_arg_t *)malloced_scan_result->user_data;
|
||||||
|
if (malloced_scan_result->scan_complete != RTW_TRUE)
|
||||||
|
{
|
||||||
|
rtw_scan_result_t* record = &malloced_scan_result->ap_details;
|
||||||
|
record->SSID.val[record->SSID.len] = 0; /* Ensure the SSID is null terminated */
|
||||||
|
|
||||||
|
process_wps_scan_result(record, malloced_scan_result->user_data);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
printf("\r\nWPS scan done!\r\n");
|
||||||
|
rtw_up_sema(&wps_arg->scan_sema);
|
||||||
|
}
|
||||||
|
return RTW_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static int wps_find_out_triger_wps_AP(char *target_ssid, u16 config_method)
|
||||||
|
{
|
||||||
|
internal_wps_scan_handler_arg_t wps_arg = {0};
|
||||||
|
|
||||||
|
wps_password_id = 0xFF;
|
||||||
|
|
||||||
|
wps_arg.isoverlap = -1;
|
||||||
|
wps_arg.config_method = config_method;
|
||||||
|
wps_arg.target_ssid = target_ssid;
|
||||||
|
rtw_init_sema(&wps_arg.scan_sema, 0);
|
||||||
|
if(wps_arg.scan_sema == NULL) return RTW_ERROR;
|
||||||
|
|
||||||
|
if(wifi_scan_networks(wps_scan_result_handler, &wps_arg ) != RTW_SUCCESS){
|
||||||
|
printf("\n\rERROR: wifi scan failed");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
if(rtw_down_timeout_sema(&wps_arg.scan_sema, SCAN_LONGEST_WAIT_TIME) == RTW_FALSE){
|
||||||
|
printf("\r\nWPS scan done early!\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
rtw_free_sema(&wps_arg.scan_sema);
|
||||||
|
|
||||||
|
return wps_arg.isoverlap;
|
||||||
|
}
|
||||||
|
extern void wpas_wps_notify_wps_finish_hdl(char *buf, int buf_len, int flags, void *userdata);
|
||||||
|
extern void wpas_wsc_eapol_recvd_hdl(char *buf, int buf_len, int flags, void* handler_user_data);
|
||||||
|
int wps_start(u16 wps_config, char *pin, u8 channel, char *ssid)
|
||||||
|
{
|
||||||
|
struct dev_credential dev_cred;
|
||||||
|
rtw_network_info_t wifi = {0};
|
||||||
|
char target_ssid[64];
|
||||||
|
int is_overlap = -1;
|
||||||
|
u32 start_time = rtw_get_current_time();
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
memset(&dev_cred, 0, sizeof(struct dev_credential));
|
||||||
|
memset(target_ssid, 0, 64);
|
||||||
|
if((wps_config != WPS_CONFIG_PUSHBUTTON)
|
||||||
|
&& (wps_config != WPS_CONFIG_DISPLAY)
|
||||||
|
&& (wps_config != WPS_CONFIG_KEYPAD)){
|
||||||
|
printf("\n\rWPS: Wps method(%d) is wrong. Not triger WPS.\n", wps_config);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
config_method = wps_config;
|
||||||
|
|
||||||
|
if(wps_config == WPS_CONFIG_DISPLAY
|
||||||
|
|| wps_config == WPS_CONFIG_KEYPAD) {
|
||||||
|
if(pin)
|
||||||
|
strcpy(wps_pin_code, pin);
|
||||||
|
else{
|
||||||
|
printf("\n\rWPS: PIN is NULL. Not triger WPS.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!ssid) {
|
||||||
|
while (1) {
|
||||||
|
unsigned int current_time = rtw_get_current_time();
|
||||||
|
if (rtw_systime_to_sec(current_time - start_time) < 120) {
|
||||||
|
is_overlap = wps_find_out_triger_wps_AP(&target_ssid[0], wps_config);
|
||||||
|
if ((is_overlap == 0) || (is_overlap > 0))
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
printf("\r\nWPS: WPS Walking Time Out\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (is_overlap > 0) {
|
||||||
|
printf("\r\nWPS: WPS session overlap. Not triger WPS.\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
rtw_memcpy(target_ssid, ssid, strlen(ssid));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (queue_for_credential != NULL) {
|
||||||
|
os_xqueue_delete(queue_for_credential);
|
||||||
|
queue_for_credential = NULL;
|
||||||
|
}
|
||||||
|
queue_for_credential = os_xqueue_create(1, sizeof(struct dev_credential));
|
||||||
|
if(!queue_for_credential)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
wifi_reg_event_handler(WIFI_EVENT_WPS_FINISH, wpas_wps_notify_wps_finish_hdl, NULL);
|
||||||
|
wifi_reg_event_handler(WIFI_EVENT_EAPOL_RECVD, wpas_wsc_eapol_recvd_hdl, NULL);
|
||||||
|
|
||||||
|
wifi_set_wps_phase(ENABLE);
|
||||||
|
ret = wps_connect_to_AP_by_open_system(target_ssid);
|
||||||
|
if(ret < 0){
|
||||||
|
printf("\n\rWPS: WPS Fail!!\n");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
os_xqueue_receive(queue_for_credential, &dev_cred, 120);
|
||||||
|
if (dev_cred.ssid[0] != 0 && dev_cred.ssid_len <= 32) {
|
||||||
|
wps_config_wifi_setting(&wifi, &dev_cred);
|
||||||
|
wifi_set_wps_phase(DISABLE);
|
||||||
|
wps_connect_to_AP_by_certificate(&wifi);
|
||||||
|
goto exit1;
|
||||||
|
} else {
|
||||||
|
printf("\n\rWPS: WPS FAIL!!!\n");
|
||||||
|
printf("\n\rWPS: WPS FAIL!!!\n");
|
||||||
|
printf("\n\rWPS: WPS FAIL!!!\n");
|
||||||
|
}
|
||||||
|
exit:
|
||||||
|
wifi_set_wps_phase(DISABLE);
|
||||||
|
exit1:
|
||||||
|
if (queue_for_credential != NULL) {
|
||||||
|
os_xqueue_delete(queue_for_credential);
|
||||||
|
queue_for_credential = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_unreg_event_handler(WIFI_EVENT_WPS_FINISH, wpas_wps_notify_wps_finish_hdl);
|
||||||
|
wifi_unreg_event_handler(WIFI_EVENT_EAPOL_RECVD, wpas_wsc_eapol_recvd_hdl);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_WPS_AP
|
||||||
|
int ap_wps_start(u16 wps_config, char *pin)
|
||||||
|
{
|
||||||
|
u8 authorized_mac[ETH_ALEN];
|
||||||
|
int ret = 0;
|
||||||
|
u32 pin_val = 0;
|
||||||
|
|
||||||
|
printf("\n\rWPS-AP: wps_config(%x).\n", wps_config);
|
||||||
|
if((wps_config != WPS_CONFIG_PUSHBUTTON)
|
||||||
|
&& (wps_config != WPS_CONFIG_DISPLAY)
|
||||||
|
&& (wps_config != WPS_CONFIG_KEYPAD)){
|
||||||
|
printf("\n\rWPS-AP: Wps method(%d) is wrong. Not triger WPS.\n", wps_config);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
config_method = wps_config;
|
||||||
|
if(wps_config == WPS_CONFIG_DISPLAY
|
||||||
|
|| wps_config == WPS_CONFIG_KEYPAD) {
|
||||||
|
if(pin)
|
||||||
|
strcpy(wps_pin_code, pin);
|
||||||
|
else{
|
||||||
|
printf("\n\rWPS-AP: PIN is NULL. Not triger WPS.\n");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (queue_for_credential != NULL) {
|
||||||
|
os_xqueue_delete(queue_for_credential);
|
||||||
|
queue_for_credential = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
queue_for_credential = os_xqueue_create(1, sizeof(authorized_mac));
|
||||||
|
if(!queue_for_credential)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
wifi_set_wps_phase(1);
|
||||||
|
|
||||||
|
if(wps_config == WPS_CONFIG_KEYPAD)
|
||||||
|
{
|
||||||
|
pin_val = atoi(pin);
|
||||||
|
if (!wps_pin_valid(pin_val)) {
|
||||||
|
printf("\n\rWPS-AP: Enter pin code is unvalid.");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
ret = wpas_wps_registrar_add_pin((unsigned char const*)pin, strlen(pin));
|
||||||
|
}
|
||||||
|
else if(wps_config == WPS_CONFIG_DISPLAY)
|
||||||
|
ret = wpas_wps_registrar_add_pin((unsigned char const*)pin, strlen(pin));
|
||||||
|
else
|
||||||
|
ret = wpas_wps_registrar_button_pushed();
|
||||||
|
|
||||||
|
if(ret<0)
|
||||||
|
goto exit;
|
||||||
|
|
||||||
|
printf("\n\rWPS-AP: wait for STA connect!\n");
|
||||||
|
os_xqueue_receive(queue_for_credential, authorized_mac, 120); //max wait 2min
|
||||||
|
|
||||||
|
if(!wpas_wps_registrar_check_done())
|
||||||
|
{
|
||||||
|
ret = -1;
|
||||||
|
wpas_wps_registrar_wps_cancel();
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
wifi_set_wps_phase(0);
|
||||||
|
os_xqueue_delete(queue_for_credential);
|
||||||
|
queue_for_credential = NULL;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#endif //CONFIG_WPS_AP
|
||||||
|
|
||||||
|
void wps_judge_staion_disconnect(void)
|
||||||
|
{
|
||||||
|
int mode = 0;
|
||||||
|
unsigned char ssid[33];
|
||||||
|
|
||||||
|
wext_get_mode(WLAN0_NAME, &mode);
|
||||||
|
|
||||||
|
switch(mode) {
|
||||||
|
case IW_MODE_MASTER: //In AP mode
|
||||||
|
rltk_wlan_deinit();
|
||||||
|
rltk_wlan_init(0,RTW_MODE_STA);
|
||||||
|
rltk_wlan_start(0);
|
||||||
|
break;
|
||||||
|
case IW_MODE_INFRA: //In STA mode
|
||||||
|
if(wext_get_ssid(WLAN0_NAME, ssid) > 0)
|
||||||
|
wifi_disconnect();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_wps(int argc, char **argv)
|
||||||
|
{
|
||||||
|
wps_judge_staion_disconnect();
|
||||||
|
|
||||||
|
if((argc == 2 || argc == 3 ) && (argv[1] != NULL)){
|
||||||
|
if(strcmp(argv[1],"pin") == 0){
|
||||||
|
unsigned int pin_val = 0;
|
||||||
|
/* start pin */
|
||||||
|
if(argc == 2){
|
||||||
|
char device_pin[10];
|
||||||
|
pin_val = wps_generate_pin();
|
||||||
|
sprintf(device_pin, "%08d", pin_val);
|
||||||
|
/* Display PIN 3 times to prevent to be overwritten by logs from other tasks */
|
||||||
|
printf("\n\rWPS: Start WPS PIN Display. PIN: [%s]\n\r", device_pin);
|
||||||
|
printf("\n\rWPS: Start WPS PIN Display. PIN: [%s]\n\r", device_pin);
|
||||||
|
printf("\n\rWPS: Start WPS PIN Display. PIN: [%s]\n\r", device_pin);
|
||||||
|
wps_start(WPS_CONFIG_DISPLAY, (char*)device_pin, 0, NULL);
|
||||||
|
}else{
|
||||||
|
pin_val = atoi(argv[2]);
|
||||||
|
if (!wps_pin_valid(pin_val)) {
|
||||||
|
printf("\n\rWPS: Device pin code is invalid. Not triger WPS.\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
printf("\n\rWPS: Start WPS PIN Keypad.\n\r");
|
||||||
|
wps_start(WPS_CONFIG_KEYPAD, argv[2], 0, NULL);
|
||||||
|
}
|
||||||
|
}else if(strcmp(argv[1],"pbc") == 0){
|
||||||
|
/* start pbc */
|
||||||
|
printf("\n\rWPS: Start WPS PBC.\n\r");
|
||||||
|
wps_start(WPS_CONFIG_PUSHBUTTON, NULL, 0, NULL);
|
||||||
|
}else{
|
||||||
|
printf("\n\rWPS: Wps Method is wrong. Not triger WPS.\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_WPS_AP
|
||||||
|
/*
|
||||||
|
cmd_ap_wps for AP WSC setting. command style:
|
||||||
|
cmd_ap_wps pbc or cmd_ap_wps pin 12345678
|
||||||
|
*/
|
||||||
|
void cmd_ap_wps(int argc, char **argv)
|
||||||
|
{
|
||||||
|
if(rltk_wlan_running(WLAN1_IDX)){
|
||||||
|
printf("\n\rNot support con-current softAP WSC!\n\r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((argc == 2 || argc == 3) && (argv[1] != NULL)) {
|
||||||
|
if (strcmp(argv[1],"pin") == 0 ) {
|
||||||
|
unsigned int pin_val = 0;
|
||||||
|
if(argc == 3){
|
||||||
|
pin_val = atoi(argv[2]);
|
||||||
|
if (!wps_pin_valid(pin_val)) {
|
||||||
|
printf("\n\rWPS-AP: Device pin code is invalid. Not trigger WPS.\n\r");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
printf("\n\rWPS-AP: Start AP WPS PIN Keypad.\n");
|
||||||
|
ap_wps_start(WPS_CONFIG_KEYPAD, argv[2]);
|
||||||
|
}else{
|
||||||
|
char device_pin[10];
|
||||||
|
pin_val = wps_generate_pin();
|
||||||
|
sprintf(device_pin, "%08d", pin_val);
|
||||||
|
printf("\n\rWPS: Start WPS PIN Display. PIN: %s\n\r", device_pin);
|
||||||
|
ap_wps_start(WPS_CONFIG_DISPLAY, (char*)device_pin);
|
||||||
|
}
|
||||||
|
}else if (strcmp(argv[1],"pbc") == 0) {
|
||||||
|
printf("\n\rWPS-AP: Start AP WPS PBC\n");
|
||||||
|
ap_wps_start(WPS_CONFIG_PUSHBUTTON, NULL);
|
||||||
|
}else{
|
||||||
|
printf("\n\rWPS-AP Usage:\"wifi_ap_wps pin [pin_code]\" or \"wifi_ap_wps pbc\"\n");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
printf("\n\rWPS-AP Usage:\"wifi_ap_wps pin [pin_code]\" or \"wifi_ap_wps pbc\"\n");
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif //CONFIG_WPS_AP
|
||||||
|
#endif //CONFIG_ENABLE_WPS
|
||||||
|
#endif //#ifdef CONFIG_WPS
|
1686
component/common/api/wifi/wifi_conf.c
Executable file
1686
component/common/api/wifi/wifi_conf.c
Executable file
File diff suppressed because it is too large
Load diff
663
component/common/api/wifi/wifi_conf.h
Executable file
663
component/common/api/wifi/wifi_conf.h
Executable file
|
@ -0,0 +1,663 @@
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
#ifndef __WIFI_API_H
|
||||||
|
#define __WIFI_API_H
|
||||||
|
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "wifi_constants.h"
|
||||||
|
#include "wifi_structures.h"
|
||||||
|
#include "wifi_util.h"
|
||||||
|
#include "wifi_ind.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Macros
|
||||||
|
******************************************************/
|
||||||
|
|
||||||
|
#define RTW_ENABLE_API_INFO
|
||||||
|
|
||||||
|
#ifdef RTW_ENABLE_API_INFO
|
||||||
|
#define RTW_API_INFO(args) do {printf args;} while(0)
|
||||||
|
#else
|
||||||
|
#define RTW_API_INFO(args)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define MAC_ARG(x) ((u8*)(x))[0],((u8*)(x))[1],((u8*)(x))[2],((u8*)(x))[3],((u8*)(x))[4],((u8*)(x))[5]
|
||||||
|
#define CMP_MAC( a, b ) (((a[0])==(b[0]))&& \
|
||||||
|
((a[1])==(b[1]))&& \
|
||||||
|
((a[2])==(b[2]))&& \
|
||||||
|
((a[3])==(b[3]))&& \
|
||||||
|
((a[4])==(b[4]))&& \
|
||||||
|
((a[5])==(b[5])))
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Constants
|
||||||
|
******************************************************/
|
||||||
|
#define SCAN_LONGEST_WAIT_TIME (4500)
|
||||||
|
|
||||||
|
|
||||||
|
#define MAC_FMT "%02x:%02x:%02x:%02x:%02x:%02x"
|
||||||
|
|
||||||
|
#define PSCAN_ENABLE 0x01 //enable for partial channel scan
|
||||||
|
#define PSCAN_FAST_SURVEY 0x02 //set to select scan time to FAST_SURVEY_TO, otherwise SURVEY_TO
|
||||||
|
#define PSCAN_SIMPLE_CONFIG 0x04 //set to select scan time to FAST_SURVEY_TO and resend probe request
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Type Definitions
|
||||||
|
******************************************************/
|
||||||
|
|
||||||
|
/** Scan result callback function pointer type
|
||||||
|
*
|
||||||
|
* @param result_ptr : A pointer to the pointer that indicates where to put the next scan result
|
||||||
|
* @param user_data : User provided data
|
||||||
|
*/
|
||||||
|
typedef void (*rtw_scan_result_callback_t)( rtw_scan_result_t** result_ptr, void* user_data );
|
||||||
|
typedef rtw_result_t (*rtw_scan_result_handler_t)( rtw_scan_handler_result_t* malloced_scan_result );
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Structures
|
||||||
|
******************************************************/
|
||||||
|
typedef struct {
|
||||||
|
char *buf;
|
||||||
|
int buf_len;
|
||||||
|
} scan_buf_arg;
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Structures
|
||||||
|
******************************************************/
|
||||||
|
typedef struct internal_scan_handler{
|
||||||
|
rtw_scan_result_t** pap_details;
|
||||||
|
rtw_scan_result_t * ap_details;
|
||||||
|
int scan_cnt;
|
||||||
|
rtw_bool_t scan_complete;
|
||||||
|
unsigned char max_ap_size;
|
||||||
|
rtw_scan_result_handler_t gscan_result_handler;
|
||||||
|
#if SCAN_USE_SEMAPHORE
|
||||||
|
void *scan_semaphore;
|
||||||
|
#else
|
||||||
|
int scan_running;
|
||||||
|
#endif
|
||||||
|
void* user_data;
|
||||||
|
unsigned int scan_start_time;
|
||||||
|
} internal_scan_handler_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
rtw_network_info_t network_info;
|
||||||
|
void *join_sema;
|
||||||
|
} internal_join_result_t;
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Function Declarations
|
||||||
|
******************************************************/
|
||||||
|
/**
|
||||||
|
* Initialises Realtek WiFi API System
|
||||||
|
*
|
||||||
|
* - Initialises the required parts of the software platform
|
||||||
|
* i.e. worker, event registering, semaphore, etc.
|
||||||
|
*
|
||||||
|
* - Initialises the RTW API thread which handles the asynchronous event
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS if initialization is successful, RTW_ERROR otherwise
|
||||||
|
*/
|
||||||
|
int wifi_manager_init(void);
|
||||||
|
|
||||||
|
/** Joins a Wi-Fi network
|
||||||
|
*
|
||||||
|
* Scans for, associates and authenticates with a Wi-Fi network.
|
||||||
|
* On successful return, the system is ready to send data packets.
|
||||||
|
*
|
||||||
|
* @param[in] ssid : A null terminated string containing the SSID name of the network to join
|
||||||
|
* @param[in] security_type : Authentication type:
|
||||||
|
* - RTW_SECURITY_OPEN - Open Security
|
||||||
|
* - RTW_SECURITY_WEP_PSK - WEP Security with open authentication
|
||||||
|
* - RTW_SECURITY_WEP_SHARED - WEP Security with shared authentication
|
||||||
|
* - RTW_SECURITY_WPA_TKIP_PSK - WPA Security
|
||||||
|
* - RTW_SECURITY_WPA2_AES_PSK - WPA2 Security using AES cipher
|
||||||
|
* - RTW_SECURITY_WPA2_TKIP_PSK - WPA2 Security using TKIP cipher
|
||||||
|
* - RTW_SECURITY_WPA2_MIXED_PSK - WPA2 Security using AES and/or TKIP ciphers
|
||||||
|
* @param[in] password : A byte array containing either the
|
||||||
|
* cleartext security key for WPA/WPA2
|
||||||
|
* secured networks, or a pointer to
|
||||||
|
* an array of rtw_wep_key_t
|
||||||
|
* structures for WEP secured networks
|
||||||
|
* @param[in] ssid_len : The length of the SSID in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] password_len : The length of the security_key in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] key_id : The index of the wep key.
|
||||||
|
* @param[in] semaphore : A user provided semaphore that is flagged when the join is complete
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : when the system is joined and ready
|
||||||
|
* to send data packets
|
||||||
|
* RTW_ERROR : if an error occurred
|
||||||
|
*/
|
||||||
|
int wifi_connect(
|
||||||
|
char *ssid,
|
||||||
|
rtw_security_t security_type,
|
||||||
|
char *password,
|
||||||
|
int ssid_len,
|
||||||
|
int password_len,
|
||||||
|
int key_id,
|
||||||
|
void *semaphore);
|
||||||
|
|
||||||
|
int wifi_connect_bssid(
|
||||||
|
unsigned char bssid[ETH_ALEN],
|
||||||
|
char *ssid,
|
||||||
|
rtw_security_t security_type,
|
||||||
|
char *password,
|
||||||
|
int bssid_len,
|
||||||
|
int ssid_len,
|
||||||
|
int password_len,
|
||||||
|
int key_id,
|
||||||
|
void *semaphore);
|
||||||
|
|
||||||
|
/** Disassociates from a Wi-Fi network.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : On successful disassociation from
|
||||||
|
* the AP
|
||||||
|
* RTW_ERROR : If an error occurred
|
||||||
|
*/
|
||||||
|
int wifi_disconnect(void);
|
||||||
|
|
||||||
|
/** Check if the interface specified is up.
|
||||||
|
*
|
||||||
|
* @return RTW_TRUE : If it's up
|
||||||
|
* RTW_FALSE : If it's not
|
||||||
|
*/
|
||||||
|
|
||||||
|
int wifi_is_connected_to_ap(void);
|
||||||
|
/*check if wifi has connected to AP before dhcp
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS:if conneced
|
||||||
|
RTW_ERROR :if not connect
|
||||||
|
*/
|
||||||
|
|
||||||
|
int wifi_is_up(rtw_interface_t interface);
|
||||||
|
|
||||||
|
/** Determines if a particular interface is ready to transceive ethernet packets
|
||||||
|
*
|
||||||
|
* @param Radio interface to check, options are
|
||||||
|
* RTW_STA_INTERFACE, RTW_AP_INTERFACE
|
||||||
|
* @return RTW_SUCCESS : if the interface is ready to
|
||||||
|
* transceive ethernet packets
|
||||||
|
* @return RTW_NOTFOUND : no AP with a matching SSID was
|
||||||
|
* found
|
||||||
|
* @return RTW_NOT_AUTHENTICATED: a matching AP was found but
|
||||||
|
* it won't let you
|
||||||
|
* authenticate. This can
|
||||||
|
* occur if this device is
|
||||||
|
* in the block list on the
|
||||||
|
* AP.
|
||||||
|
* @return RTW_NOT_KEYED: the device has authenticated and
|
||||||
|
* associated but has not completed
|
||||||
|
* the key exchange. This can occur
|
||||||
|
* if the passphrase is incorrect.
|
||||||
|
* @return RTW_ERROR : if the interface is not ready to
|
||||||
|
* transceive ethernet packets
|
||||||
|
*/
|
||||||
|
int wifi_is_ready_to_transceive(rtw_interface_t interface);
|
||||||
|
|
||||||
|
/** ----------------------------------------------------------------------
|
||||||
|
* WARNING : This function is for internal use only!
|
||||||
|
* ----------------------------------------------------------------------
|
||||||
|
* This function sets the current Media Access Control (MAC) address of the
|
||||||
|
* 802.11 device.
|
||||||
|
*
|
||||||
|
* @param[in] mac Wi-Fi MAC address
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_set_mac_address(char * mac);
|
||||||
|
|
||||||
|
/** Retrieves the current Media Access Control (MAC) address
|
||||||
|
* (or Ethernet hardware address) of the 802.11 device
|
||||||
|
*
|
||||||
|
* @param mac Pointer to a variable that the current MAC address will be written to
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_get_mac_address(char * mac);
|
||||||
|
|
||||||
|
/** Enables powersave mode
|
||||||
|
*
|
||||||
|
* @return @ref rtw_result_t
|
||||||
|
*/
|
||||||
|
int wifi_enable_powersave(void);
|
||||||
|
|
||||||
|
/** Disables 802.11 power save mode
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if power save mode was successfully
|
||||||
|
* disabled
|
||||||
|
* RTW_ERROR : if power save mode was not successfully
|
||||||
|
* disabled
|
||||||
|
*/
|
||||||
|
int wifi_disable_powersave(void);
|
||||||
|
|
||||||
|
/** Gets the tx power in index units
|
||||||
|
*
|
||||||
|
* @param dbm : The variable to receive the tx power in index.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if successful
|
||||||
|
* RTW_ERROR : if not successful
|
||||||
|
*/
|
||||||
|
int wifi_get_txpower(int *poweridx);
|
||||||
|
|
||||||
|
/** Sets the tx power in index units
|
||||||
|
*
|
||||||
|
* @param dbm : The desired tx power in index.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if tx power was successfully set
|
||||||
|
* RTW_ERROR : if tx power was not successfully set
|
||||||
|
*/
|
||||||
|
int wifi_set_txpower(int poweridx);
|
||||||
|
|
||||||
|
/** Get the associated clients with SoftAP
|
||||||
|
*
|
||||||
|
* @param client_list_buffer : the location where the client
|
||||||
|
* list will be stored
|
||||||
|
* @param buffer_length : the buffer length.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if result was successfully get
|
||||||
|
* RTW_ERROR : if result was not successfully get
|
||||||
|
*/
|
||||||
|
int wifi_get_associated_client_list(void * client_list_buffer, unsigned short buffer_length);
|
||||||
|
|
||||||
|
/** Get the SoftAP information
|
||||||
|
*
|
||||||
|
* @param ap_info : the location where the AP info will be
|
||||||
|
* stored
|
||||||
|
* @param security : the security type.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if result was successfully get
|
||||||
|
* RTW_ERROR : if result was not successfully get
|
||||||
|
*/
|
||||||
|
int wifi_get_ap_info(rtw_bss_info_t * ap_info, rtw_security_t* security);
|
||||||
|
|
||||||
|
/** Set the country code to driver to determine the channel set
|
||||||
|
*
|
||||||
|
* @param country_code : the country code.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if result was successfully set
|
||||||
|
* RTW_ERROR : if result was not successfully set
|
||||||
|
*/
|
||||||
|
int wifi_set_country(rtw_country_code_t country_code);
|
||||||
|
|
||||||
|
/** Retrieve the latest RSSI value
|
||||||
|
*
|
||||||
|
* @param rssi: The location where the RSSI value will be stored
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the RSSI was succesfully retrieved
|
||||||
|
* RTW_ERROR : if the RSSI was not retrieved
|
||||||
|
*/
|
||||||
|
int wifi_get_rssi(int *pRSSI);
|
||||||
|
|
||||||
|
/** Set the current channel on STA interface
|
||||||
|
*
|
||||||
|
* @param channel : The desired channel
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the channel was successfully set
|
||||||
|
* RTW_ERROR : if the channel was not successfully
|
||||||
|
* set
|
||||||
|
*/
|
||||||
|
int wifi_set_channel(int channel);
|
||||||
|
|
||||||
|
/** Get the current channel on STA interface
|
||||||
|
*
|
||||||
|
* @param channel : A pointer to the variable where the
|
||||||
|
* channel value will be written
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the channel was successfully read
|
||||||
|
* RTW_ERROR : if the channel was not successfully
|
||||||
|
* read
|
||||||
|
*/
|
||||||
|
int wifi_get_channel(int *channel);
|
||||||
|
|
||||||
|
/** Registers interest in a multicast address
|
||||||
|
* Once a multicast address has been registered, all packets detected on the
|
||||||
|
* medium destined for that address are forwarded to the host.
|
||||||
|
* Otherwise they are ignored.
|
||||||
|
*
|
||||||
|
* @param mac: Ethernet MAC address
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the address was registered
|
||||||
|
* successfully
|
||||||
|
* RTW_ERROR : if the address was not registered
|
||||||
|
*/
|
||||||
|
int wifi_register_multicast_address(rtw_mac_t *mac);
|
||||||
|
|
||||||
|
/** Unregisters interest in a multicast address
|
||||||
|
* Once a multicast address has been unregistered, all packets detected on the
|
||||||
|
* medium destined for that address are ignored.
|
||||||
|
*
|
||||||
|
* @param mac: Ethernet MAC address
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the address was unregistered
|
||||||
|
* successfully
|
||||||
|
* RTW_ERROR : if the address was not unregistered
|
||||||
|
*/
|
||||||
|
int wifi_unregister_multicast_address(rtw_mac_t *mac);
|
||||||
|
|
||||||
|
int wifi_rf_on(void);
|
||||||
|
int wifi_rf_off(void);
|
||||||
|
|
||||||
|
/** Turn on the Wi-Fi device
|
||||||
|
*
|
||||||
|
* - Bring the Wireless interface "Up"
|
||||||
|
* - Initialises the driver thread which arbitrates access
|
||||||
|
* to the SDIO/SPI bus
|
||||||
|
*
|
||||||
|
* @param mode: wifi work mode
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if the WiFi chip was initialised
|
||||||
|
* successfully
|
||||||
|
* RTW_ERROR : if the WiFi chip was not initialised
|
||||||
|
* successfully
|
||||||
|
*/
|
||||||
|
int wifi_on(rtw_mode_t mode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Turn off the Wi-Fi device
|
||||||
|
*
|
||||||
|
* - Bring the Wireless interface "Down"
|
||||||
|
* - De-Initialises the driver thread which arbitrates access
|
||||||
|
* to the SDIO/SPI bus
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS if deinitialization is successful,
|
||||||
|
* RTW_ERROR otherwise
|
||||||
|
*/
|
||||||
|
int wifi_off(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set IPS/LPS mode
|
||||||
|
*
|
||||||
|
* @param[in] ips_mode : The desired IPS mode. It become effective when wlan enter ips.
|
||||||
|
* @param[in] lps_mode : The desired LPS mode. It become effective when wlan enter lps.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS if setting LPS mode successful
|
||||||
|
* RTW_ERROR otherwise
|
||||||
|
*/
|
||||||
|
int wifi_set_power_mode(unsigned char ips_mode, unsigned char lps_mode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set TDMA parameters
|
||||||
|
*
|
||||||
|
* @param[in] slot_period : We separate TBTT into 2 or 3 slots.
|
||||||
|
* If we separate TBTT into 2 slots, then slot_period should be larger or equal to 50ms.
|
||||||
|
* It means 2 slot period is
|
||||||
|
* slot_period, 100-slot_period
|
||||||
|
* If we separate TBTT into 3 slots, then slot_period should be less or equal to 33ms.
|
||||||
|
* It means 3 slot period is
|
||||||
|
* 100 - 2 * slot_period, slot_period, slot_period
|
||||||
|
* @param[in] rfon_period_len_1: rf on period of slot 1
|
||||||
|
* @param[in] rfon_period_len_2: rf on period of slot 2
|
||||||
|
* @param[in] rfon_period_len_3: rf on period of slot 3
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS if setting TDMA parameters successful
|
||||||
|
* RTW_ERROR otherwise
|
||||||
|
*/
|
||||||
|
int wifi_set_tdma_param(unsigned char slot_period, unsigned char rfon_period_len_1, unsigned char rfon_period_len_2, unsigned char rfon_period_len_3);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set LPS DTIM
|
||||||
|
*
|
||||||
|
* @param[in] dtim : In LPS, the package can be buffered at AP side.
|
||||||
|
* STA leave LPS until dtim count of packages buffered at AP side.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS if setting LPS dtim successful
|
||||||
|
* RTW_ERROR otherwise
|
||||||
|
*/
|
||||||
|
int wifi_set_lps_dtim(unsigned char dtim);
|
||||||
|
|
||||||
|
/** Starts an infrastructure WiFi network
|
||||||
|
*
|
||||||
|
* @warning If a STA interface is active when this function is called, the softAP will\n
|
||||||
|
* start on the same channel as the STA. It will NOT use the channel provided!
|
||||||
|
*
|
||||||
|
* @param[in] ssid : A null terminated string containing
|
||||||
|
* the SSID name of the network to join
|
||||||
|
* @param[in] security_type : Authentication type: \n
|
||||||
|
* - RTW_SECURITY_OPEN - Open Security \n
|
||||||
|
* - RTW_SECURITY_WPA_TKIP_PSK - WPA Security \n
|
||||||
|
* - RTW_SECURITY_WPA2_AES_PSK - WPA2 Security using AES cipher \n
|
||||||
|
* - RTW_SECURITY_WPA2_MIXED_PSK - WPA2 Security using AES and/or TKIP ciphers \n
|
||||||
|
* - WEP security is NOT IMPLEMENTED. It is NOT SECURE! \n
|
||||||
|
* @param[in] password : A byte array containing the cleartext
|
||||||
|
* security key for the network
|
||||||
|
* @param[in] ssid_len : The length of the SSID in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] password_len : The length of the security_key in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] channel : 802.11 channel number
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if successfully creates an AP
|
||||||
|
* RTW_ERROR : if an error occurred
|
||||||
|
*/
|
||||||
|
int wifi_start_ap(
|
||||||
|
char *ssid,
|
||||||
|
rtw_security_t security_type,
|
||||||
|
char *password,
|
||||||
|
int ssid_len,
|
||||||
|
int password_len,
|
||||||
|
int channel);
|
||||||
|
|
||||||
|
/** Initiates a scan to search for 802.11 networks.
|
||||||
|
*
|
||||||
|
* The scan progressively accumulates results over time, and
|
||||||
|
* may take between 1 and 3 seconds to complete. The results of
|
||||||
|
* the scan will be individually provided to the callback
|
||||||
|
* function. Note: The callback function will be executed in
|
||||||
|
* the context of the RTW thread.
|
||||||
|
*
|
||||||
|
* @param[in] scan_type : Specifies whether the scan should
|
||||||
|
* be Active, Passive or scan
|
||||||
|
* Prohibited channels
|
||||||
|
* @param[in] bss_type : Specifies whether the scan should
|
||||||
|
* search for Infrastructure
|
||||||
|
* networks (those using an Access
|
||||||
|
* Point), Ad-hoc networks, or both
|
||||||
|
* types.
|
||||||
|
* @param result_ptr[in] : Scan specific ssid. The first 4
|
||||||
|
* bytes is ssid lenth, and ssid name
|
||||||
|
* append after it.
|
||||||
|
* If no specific ssid need to scan,
|
||||||
|
* PLEASE CLEAN result_ptr before pass
|
||||||
|
* it into parameter.
|
||||||
|
* @param result_ptr[out] : a pointer to a pointer to a result
|
||||||
|
* storage structure.
|
||||||
|
*
|
||||||
|
* @note : When scanning specific channels, devices with a
|
||||||
|
* strong signal strength on nearby channels may be
|
||||||
|
* detected
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_scan(rtw_scan_type_t scan_type,
|
||||||
|
rtw_bss_type_t bss_type,
|
||||||
|
void* result_ptr);
|
||||||
|
|
||||||
|
/** Initiates a scan to search for 802.11 networks, a higher
|
||||||
|
* level API based on wifi_scan to simplify the scan
|
||||||
|
* operation.
|
||||||
|
*
|
||||||
|
* The scan results will be list by the order of RSSI.
|
||||||
|
* It may demand hundreds bytes memory during scan
|
||||||
|
* processing according to the quantity of AP nearby.
|
||||||
|
*
|
||||||
|
* @param results_handler[in] : the callback function which
|
||||||
|
* will receive and process the result data.
|
||||||
|
* @param user_data[in] : user specific data that will be
|
||||||
|
* passed directly to the callback function
|
||||||
|
*
|
||||||
|
* @note : Callback must not use blocking functions, since it is
|
||||||
|
* called from the context of the RTW thread.
|
||||||
|
* @note : The callback, user_data variables will
|
||||||
|
* be referenced after the function returns. Those
|
||||||
|
* variables must remain valid until the scan is
|
||||||
|
* complete.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_scan_networks(rtw_scan_result_handler_t results_handler, void* user_data);
|
||||||
|
int wifi_scan_networks_with_ssid(rtw_scan_result_handler_t results_handler, void* user_data, char* ssid, int ssid_len);
|
||||||
|
|
||||||
|
/** Set the partical scan
|
||||||
|
*
|
||||||
|
* @param channel_list[in] : the channel set the scan will
|
||||||
|
* stay on
|
||||||
|
* @param pscan_config[in] : the pscan_config of the channel set
|
||||||
|
*
|
||||||
|
* @param length[in] : the channel list length
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_set_pscan_chan(__u8 * channel_list,__u8 * pscan_config, __u8 length);
|
||||||
|
|
||||||
|
/** Get the network information
|
||||||
|
*
|
||||||
|
* @param ifname[in] : the name of the interface we are care
|
||||||
|
* @param pSetting[in] : the location where the network
|
||||||
|
* information will be stored
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_get_setting(const char *ifname,rtw_wifi_setting_t *pSetting);
|
||||||
|
|
||||||
|
/** Show the network information
|
||||||
|
*
|
||||||
|
* @param ifname[in] : the name of the interface we are care
|
||||||
|
* @param pSetting[in] : the location where the network
|
||||||
|
* information was stored
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_show_setting(const char *ifname,rtw_wifi_setting_t *pSetting);
|
||||||
|
|
||||||
|
/** Set the network mode according to the data rate it's
|
||||||
|
* supported
|
||||||
|
*
|
||||||
|
* @param mode[in] : the network mode
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_set_network_mode(rtw_network_mode_t mode);
|
||||||
|
|
||||||
|
/** Set the chip to worke in the promisc mode
|
||||||
|
*
|
||||||
|
* @param enabled[in] : enabled can be set 0, 1 and 2. if enabled is zero, disable the promisc, else enable the promisc.
|
||||||
|
* 0 means disable the promisc
|
||||||
|
* 1 means enable the promisc
|
||||||
|
* 2 means enable the promisc special for length is used
|
||||||
|
* @param callback[in] : the callback function which will
|
||||||
|
* receive and process the netowork data.
|
||||||
|
* @param len_used[in] : specify if the the promisc length is
|
||||||
|
* used.
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_set_promisc(rtw_rcr_level_t enabled, void (*callback)(unsigned char*, unsigned int, void*), unsigned char len_used);
|
||||||
|
|
||||||
|
/** Set the wps phase
|
||||||
|
*
|
||||||
|
* @param is_trigger_wps[in] : to trigger wps function or not
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS or RTW_ERROR
|
||||||
|
*/
|
||||||
|
int wifi_set_wps_phase(unsigned char is_trigger_wps);
|
||||||
|
|
||||||
|
/** Restarts an infrastructure WiFi network
|
||||||
|
*
|
||||||
|
* @warning If a STA interface is active when this function is called, the softAP will\n
|
||||||
|
* start on the same channel as the STA. It will NOT use the channel provided!
|
||||||
|
*
|
||||||
|
* @param[in] ssid : A null terminated string containing
|
||||||
|
* the SSID name of the network to join
|
||||||
|
* @param[in] security_type : Authentication type: \n
|
||||||
|
* - RTW_SECURITY_OPEN - Open Security \n
|
||||||
|
* - RTW_SECURITY_WPA_TKIP_PSK - WPA Security \n
|
||||||
|
* - RTW_SECURITY_WPA2_AES_PSK - WPA2 Security using AES cipher \n
|
||||||
|
* - RTW_SECURITY_WPA2_MIXED_PSK - WPA2 Security using AES and/or TKIP ciphers \n
|
||||||
|
* - WEP security is NOT IMPLEMENTED. It is NOT SECURE! \n
|
||||||
|
* @param[in] password : A byte array containing the cleartext
|
||||||
|
* security key for the network
|
||||||
|
* @param[in] ssid_len : The length of the SSID in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] password_len : The length of the security_key in
|
||||||
|
* bytes.
|
||||||
|
* @param[in] channel : 802.11 channel number
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if successfully creates an AP
|
||||||
|
* RTW_ERROR : if an error occurred
|
||||||
|
*/
|
||||||
|
int wifi_restart_ap(
|
||||||
|
unsigned char *ssid,
|
||||||
|
rtw_security_t security_type,
|
||||||
|
unsigned char *password,
|
||||||
|
int ssid_len,
|
||||||
|
int password_len,
|
||||||
|
int channel);
|
||||||
|
|
||||||
|
int wifi_config_autoreconnect(__u8 mode, __u8 retyr_times, __u16 timeout);
|
||||||
|
int wifi_set_autoreconnect(__u8 mode);
|
||||||
|
int wifi_get_autoreconnect(__u8 *mode);
|
||||||
|
int wifi_get_last_error( void );
|
||||||
|
/** Present device disconnect reason while connecting
|
||||||
|
*
|
||||||
|
*@return RTW_NO_ERROR = 0,
|
||||||
|
* RTW_NONE_NETWORK = 1,
|
||||||
|
* RTW_CONNECT_FAIL = 2,
|
||||||
|
* RTW_WRONG_PASSWORD = 3 ,
|
||||||
|
* RTW_DHCP_FAIL = 4,
|
||||||
|
* RTW_UNKNOWN, initial status
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef CONFIG_CUSTOM_IE
|
||||||
|
#ifndef BIT
|
||||||
|
#define BIT(x) ((__u32)1 << (x))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _CUSTOM_IE_TYPE_
|
||||||
|
#define _CUSTOM_IE_TYPE_
|
||||||
|
enum CUSTOM_IE_TYPE{
|
||||||
|
PROBE_REQ = BIT(0),
|
||||||
|
PROBE_RSP = BIT(1),
|
||||||
|
BEACON = BIT(2),
|
||||||
|
};
|
||||||
|
#endif /* _CUSTOM_IE_TYPE_ */
|
||||||
|
|
||||||
|
/* ie format
|
||||||
|
* +-----------+--------+-----------------------+
|
||||||
|
* |element ID | length | content in length byte|
|
||||||
|
* +-----------+--------+-----------------------+
|
||||||
|
*
|
||||||
|
* type: refer to CUSTOM_IE_TYPE
|
||||||
|
*/
|
||||||
|
#ifndef _CUS_IE_
|
||||||
|
#define _CUS_IE_
|
||||||
|
typedef struct _cus_ie{
|
||||||
|
__u8 *ie;
|
||||||
|
__u8 type;
|
||||||
|
}cus_ie, *p_cus_ie;
|
||||||
|
#endif /* _CUS_IE_ */
|
||||||
|
|
||||||
|
int wifi_add_custom_ie(void *cus_ie, int ie_num);
|
||||||
|
|
||||||
|
int wifi_update_custom_ie(void *cus_ie, int ie_index);
|
||||||
|
|
||||||
|
int wifi_del_custom_ie(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_PROMISC
|
||||||
|
void wifi_init_packet_filter(void);
|
||||||
|
int wifi_add_packet_filter(unsigned char filter_id, rtw_packet_filter_pattern_t *patt, rtw_packet_filter_rule_e rule);
|
||||||
|
int wifi_enable_packet_filter(unsigned char filter_id);
|
||||||
|
int wifi_disable_packet_filter(unsigned char filter_id);
|
||||||
|
int wifi_remove_packet_filter(unsigned char filter_id);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __WIFI_API_H
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
239
component/common/api/wifi/wifi_ind.c
Executable file
239
component/common/api/wifi/wifi_ind.c
Executable file
|
@ -0,0 +1,239 @@
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
#include "wifi/wifi_ind.h"
|
||||||
|
#include "wifi/wifi_conf.h"
|
||||||
|
#include "osdep_service.h"
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Constants
|
||||||
|
******************************************************/
|
||||||
|
|
||||||
|
#define WIFI_INDICATE_MSG 0
|
||||||
|
#define WIFI_MANAGER_STACKSIZE 128
|
||||||
|
#define WIFI_MANAGER_PRIORITY (5)
|
||||||
|
#define WIFI_MANAGER_PRIO 2
|
||||||
|
|
||||||
|
#define INDICATE_USE_THREAD 0
|
||||||
|
#define WIFI_EVENT_MAX_ROW 3
|
||||||
|
/******************************************************
|
||||||
|
* Globals
|
||||||
|
******************************************************/
|
||||||
|
|
||||||
|
static event_list_elem_t event_callback_list[WIFI_EVENT_MAX][WIFI_EVENT_MAX_ROW];
|
||||||
|
#if INDICATE_USE_THREAD
|
||||||
|
static rtw_worker_thread_t wifi_worker_thread;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//----------------------------------------------------------------------------//
|
||||||
|
#if INDICATE_USE_THREAD
|
||||||
|
static rtw_result_t rtw_send_event_to_worker(int event_cmd, char *buf, int buf_len, int flags)
|
||||||
|
{
|
||||||
|
rtw_event_message_t message;
|
||||||
|
int i;
|
||||||
|
rtw_result_t ret = RTW_SUCCESS;
|
||||||
|
|
||||||
|
if(event_cmd >= WIFI_EVENT_MAX)
|
||||||
|
return RTW_BADARG;
|
||||||
|
for(i = 0; i < WIFI_EVENT_MAX_ROW; i++){
|
||||||
|
if(event_callback_list[event_cmd][i].handler == NULL)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
message.function = (event_handler_t)event_callback_list[event_cmd][i].handler;
|
||||||
|
message.buf = buf;
|
||||||
|
message.buf_len = buf_len;
|
||||||
|
message.flags = flags;
|
||||||
|
message.user_data = event_callback_list[event_cmd][i].handler_user_data;
|
||||||
|
|
||||||
|
ret = rtw_push_to_xqueue(&wifi_worker_thread->event_queue, &message, 0);
|
||||||
|
if(ret != RTW_SUCCESS)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static rtw_result_t rtw_indicate_event_handle(int event_cmd, char *buf, int buf_len, int flags)
|
||||||
|
{
|
||||||
|
rtw_event_handler_t handle = NULL;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if(event_cmd >= WIFI_EVENT_MAX)
|
||||||
|
return RTW_BADARG;
|
||||||
|
|
||||||
|
for(i = 0; i < WIFI_EVENT_MAX_ROW; i++){
|
||||||
|
handle = event_callback_list[event_cmd][i].handler;
|
||||||
|
if(handle == NULL)
|
||||||
|
continue;
|
||||||
|
handle(buf, buf_len, flags, event_callback_list[event_cmd][i].handler_user_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
return RTW_SUCCESS;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void wifi_indication( WIFI_EVENT_INDICATE event, char *buf, int buf_len, int flags)
|
||||||
|
{
|
||||||
|
//
|
||||||
|
// If upper layer application triggers additional operations on receiving of wext_wlan_indicate,
|
||||||
|
// please strictly check current stack size usage (by using uxTaskGetStackHighWaterMark() )
|
||||||
|
// , and tries not to share the same stack with wlan driver if remaining stack space is
|
||||||
|
// not available for the following operations.
|
||||||
|
// ex: using semaphore to notice another thread.
|
||||||
|
switch(event)
|
||||||
|
{
|
||||||
|
case WIFI_EVENT_DISCONNECT:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r %s():Disconnection indication received", __FUNCTION__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_CONNECT:
|
||||||
|
// For WPA/WPA2 mode, indication of connection does not mean data can be
|
||||||
|
// correctly transmitted or received. Data can be correctly transmitted or
|
||||||
|
// received only when 4-way handshake is done.
|
||||||
|
// Please check WIFI_EVENT_FOURWAY_HANDSHAKE_DONE event
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
// Sample: return mac address
|
||||||
|
if(buf != NULL && buf_len == 6)
|
||||||
|
{
|
||||||
|
printf("\n\r%s():Connect indication received: %02x:%02x:%02x:%02x:%02x:%02x", __FUNCTION__,
|
||||||
|
buf[0],buf[1],buf[2],buf[3],buf[4],buf[5]);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_FOURWAY_HANDSHAKE_DONE:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
if(buf != NULL)
|
||||||
|
{
|
||||||
|
if(buf_len == strlen(IW_EXT_STR_FOURWAY_DONE))
|
||||||
|
printf("\n\r%s():%s", __FUNCTION__, buf);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_SCAN_RESULT_REPORT:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_SCAN_RESULT_REPORT\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_SCAN_DONE:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_SCAN_DONE\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_RECONNECTION_FAIL:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
if(buf != NULL){
|
||||||
|
if(buf_len == strlen(IW_EXT_STR_RECONNECTION_FAIL))
|
||||||
|
printf("\n\r%s", buf);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_NO_NETWORK:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_NO_NETWORK\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
#ifdef CONFIG_P2P_NEW
|
||||||
|
case WIFI_EVENT_SEND_ACTION_DONE:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_SEND_ACTION_DONE\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_RX_MGNT:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_RX_MGNT\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_STA_ASSOC:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_STA_ASSOC\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_STA_DISASSOC:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_STA_DISASSOC\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
#endif //CONFIG_P2P_NEW
|
||||||
|
#ifdef CONFIG_WPS
|
||||||
|
case WIFI_EVENT_WPS_FINISH:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_WPS_FINISH\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
case WIFI_EVENT_EAPOL_RECVD:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_EAPOL_RECVD\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
#endif
|
||||||
|
case WIFI_EVENT_BEACON_AFTER_DHCP:
|
||||||
|
#if(WIFI_INDICATE_MSG==1)
|
||||||
|
printf("\n\r%s(): WIFI_EVENT_BEACON_AFTER_DHCP\n", __func__);
|
||||||
|
#endif
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if CONFIG_INIC_EN
|
||||||
|
inic_indicate_event(event, buf, buf_len, flags);
|
||||||
|
#endif//CONFIG_INIC_EN
|
||||||
|
|
||||||
|
#if INDICATE_USE_THREAD
|
||||||
|
rtw_send_event_to_worker(event, buf, buf_len, flags);
|
||||||
|
#else
|
||||||
|
rtw_indicate_event_handle(event, buf, buf_len, flags);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void wifi_reg_event_handler(unsigned int event_cmds, rtw_event_handler_t handler_func, void *handler_user_data)
|
||||||
|
{
|
||||||
|
int i = 0, j = 0;
|
||||||
|
if(event_cmds < WIFI_EVENT_MAX){
|
||||||
|
for(i=0; i < WIFI_EVENT_MAX_ROW; i++){
|
||||||
|
if(event_callback_list[event_cmds][i].handler == NULL){
|
||||||
|
for(j=0; j<WIFI_EVENT_MAX_ROW; j++){
|
||||||
|
if(event_callback_list[event_cmds][j].handler == handler_func){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
event_callback_list[event_cmds][i].handler = handler_func;
|
||||||
|
event_callback_list[event_cmds][i].handler_user_data = handler_user_data;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wifi_unreg_event_handler(unsigned int event_cmds, rtw_event_handler_t handler_func)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
if(event_cmds < WIFI_EVENT_MAX){
|
||||||
|
for(i = 0; i < WIFI_EVENT_MAX_ROW; i++){
|
||||||
|
if(event_callback_list[event_cmds][i].handler == handler_func){
|
||||||
|
event_callback_list[event_cmds][i].handler = NULL;
|
||||||
|
event_callback_list[event_cmds][i].handler_user_data = NULL;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void init_event_callback_list(){
|
||||||
|
memset(event_callback_list, 0, sizeof(event_callback_list));
|
||||||
|
}
|
||||||
|
|
||||||
|
int wifi_manager_init()
|
||||||
|
{
|
||||||
|
#if INDICATE_USE_THREAD
|
||||||
|
rtw_create_worker_thread(&wifi_worker_thread,
|
||||||
|
WIFI_MANAGER_PRIORITY,
|
||||||
|
WIFI_MANAGER_STACKSIZE,
|
||||||
|
WIFI_MANAGER_PRIO);
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
void rtw_wifi_manager_deinit()
|
||||||
|
{
|
||||||
|
#if INDICATE_USE_THREAD
|
||||||
|
rtw_delete_worker_thread(&wifi_worker_thread);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
52
component/common/api/wifi/wifi_ind.h
Executable file
52
component/common/api/wifi/wifi_ind.h
Executable file
|
@ -0,0 +1,52 @@
|
||||||
|
#ifndef _WIFI_INDICATE_H
|
||||||
|
#define _WIFI_INDICATE_H
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#if 0 //move to wifi_constants.h
|
||||||
|
typedef enum _WIFI_EVENT_INDICATE{
|
||||||
|
WIFI_EVENT_CONNECT = 0,
|
||||||
|
WIFI_EVENT_DISCONNECT = 1,
|
||||||
|
WIFI_EVENT_FOURWAY_HANDSHAKE_DONE = 2,
|
||||||
|
WIFI_EVENT_SCAN_RESULT_REPORT = 3,
|
||||||
|
WIFI_EVENT_SCAN_DONE = 4,
|
||||||
|
WIFI_EVENT_RECONNECTION_FAIL = 5,
|
||||||
|
WIFI_EVENT_SEND_ACTION_DONE = 6,
|
||||||
|
WIFI_EVENT_RX_MGNT = 7,
|
||||||
|
WIFI_EVENT_STA_ASSOC = 8,
|
||||||
|
WIFI_EVENT_STA_DISASSOC = 9,
|
||||||
|
WIFI_EVENT_WPS_FINISH = 10,
|
||||||
|
WIFI_EVENT_EAPOL_RECVD = 11,
|
||||||
|
WIFI_EVENT_NO_NETWORK = 12,
|
||||||
|
WIFI_EVENT_BEACON_AFTER_DHCP = 13,
|
||||||
|
WIFI_EVENT_MAX,
|
||||||
|
}WIFI_EVENT_INDICATE;
|
||||||
|
#endif
|
||||||
|
typedef void (*rtw_event_handler_t)(char *buf, int buf_len, int flags, void* handler_user_data );
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
// WIFI_EVENT_INDICATE event_cmd;
|
||||||
|
rtw_event_handler_t handler;
|
||||||
|
void* handler_user_data;
|
||||||
|
} event_list_elem_t;
|
||||||
|
|
||||||
|
void init_event_callback_list(void);
|
||||||
|
extern void wifi_indication( WIFI_EVENT_INDICATE event, char *buf, int buf_len, int flags);
|
||||||
|
/** Register the event listener
|
||||||
|
*
|
||||||
|
* @param[in] event_cmds : The event command number indicated
|
||||||
|
* @param[in] handler_func : the callback function which will
|
||||||
|
* receive and process the event
|
||||||
|
* @param[in] handler_user_data : user specific data that will be
|
||||||
|
* passed directly to the callback function
|
||||||
|
*
|
||||||
|
* @note : Set the same event_cmds with empty handler_func will
|
||||||
|
* unregister the event_cmds
|
||||||
|
*
|
||||||
|
* @return RTW_SUCCESS : if successfully registers the event
|
||||||
|
* RTW_ERROR : if an error occurred
|
||||||
|
*/
|
||||||
|
extern void wifi_reg_event_handler(unsigned int event_cmds, rtw_event_handler_t handler_func, void *handler_user_data);
|
||||||
|
extern void wifi_unreg_event_handler(unsigned int event_cmds, rtw_event_handler_t handler_func);
|
||||||
|
|
||||||
|
#endif //_WIFI_INDICATE_H
|
||||||
|
|
409
component/common/api/wifi/wifi_promisc.c
Executable file
409
component/common/api/wifi/wifi_promisc.c
Executable file
|
@ -0,0 +1,409 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "tcpip.h"
|
||||||
|
#include "wifi/wifi_conf.h"
|
||||||
|
|
||||||
|
#ifndef CONFIG_WLAN
|
||||||
|
#define CONFIG_WLAN 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
struct eth_frame {
|
||||||
|
struct eth_frame *prev;
|
||||||
|
struct eth_frame *next;
|
||||||
|
unsigned char da[6];
|
||||||
|
unsigned char sa[6];
|
||||||
|
unsigned int len;
|
||||||
|
unsigned char type;
|
||||||
|
signed char rssi;
|
||||||
|
};
|
||||||
|
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack(1)
|
||||||
|
#endif
|
||||||
|
struct inic_eth_frame {
|
||||||
|
unsigned char da[6];
|
||||||
|
unsigned char sa[6];
|
||||||
|
unsigned int len;
|
||||||
|
unsigned char type;
|
||||||
|
};
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static struct inic_eth_frame *inic_frame, *inic_frame_tail = NULL;
|
||||||
|
static int inic_frame_cnt = 0;
|
||||||
|
#define MAX_INIC_FRAME_NUM 50 //maximum packets for each channel
|
||||||
|
extern void inic_c2h_msg(const char *atcmd, char status, char *msg, u16 msg_len);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct eth_buffer {
|
||||||
|
struct eth_frame *head;
|
||||||
|
struct eth_frame *tail;
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct eth_buffer eth_buffer;
|
||||||
|
|
||||||
|
#ifdef CONFIG_PROMISC
|
||||||
|
#define MAX_PACKET_FILTER_INFO 5
|
||||||
|
#define FILTER_ID_INIT_VALUE 10
|
||||||
|
rtw_packet_filter_info_t paff_array[MAX_PACKET_FILTER_INFO]={0, 0, 0, 0, 0};
|
||||||
|
static u8 packet_filter_enable_num = 0;
|
||||||
|
|
||||||
|
void promisc_init_packet_filter()
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
for(i=0; i<MAX_PACKET_FILTER_INFO; i++){
|
||||||
|
paff_array[i].filter_id = FILTER_ID_INIT_VALUE;
|
||||||
|
paff_array[i].enable = 0;
|
||||||
|
paff_array[i].patt.mask_size = 0;
|
||||||
|
paff_array[i].rule = RTW_POSITIVE_MATCHING;
|
||||||
|
paff_array[i].patt.mask = NULL;
|
||||||
|
paff_array[i].patt.pattern = NULL;
|
||||||
|
}
|
||||||
|
packet_filter_enable_num = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int promisc_add_packet_filter(u8 filter_id, rtw_packet_filter_pattern_t *patt, rtw_packet_filter_rule_e rule)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
while(i < MAX_PACKET_FILTER_INFO){
|
||||||
|
if(paff_array[i].filter_id == FILTER_ID_INIT_VALUE){
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(i == MAX_PACKET_FILTER_INFO)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
paff_array[i].filter_id = filter_id;
|
||||||
|
|
||||||
|
paff_array[i].patt.offset= patt->offset;
|
||||||
|
paff_array[i].patt.mask_size = patt->mask_size;
|
||||||
|
paff_array[i].patt.mask = pvPortMalloc(patt->mask_size);
|
||||||
|
memcpy(paff_array[i].patt.mask, patt->mask, patt->mask_size);
|
||||||
|
paff_array[i].patt.pattern= pvPortMalloc(patt->mask_size);
|
||||||
|
memcpy(paff_array[i].patt.pattern, patt->pattern, patt->mask_size);
|
||||||
|
|
||||||
|
paff_array[i].rule = rule;
|
||||||
|
paff_array[i].enable = 0;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int promisc_enable_packet_filter(u8 filter_id)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
while(i < MAX_PACKET_FILTER_INFO){
|
||||||
|
if(paff_array[i].filter_id == filter_id)
|
||||||
|
break;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(i == MAX_PACKET_FILTER_INFO)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
paff_array[i].enable = 1;
|
||||||
|
packet_filter_enable_num++;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int promisc_disable_packet_filter(u8 filter_id)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
while(i < MAX_PACKET_FILTER_INFO){
|
||||||
|
if(paff_array[i].filter_id == filter_id)
|
||||||
|
break;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(i == MAX_PACKET_FILTER_INFO)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
paff_array[i].enable = 0;
|
||||||
|
packet_filter_enable_num--;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int promisc_remove_packet_filter(u8 filter_id)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
while(i < MAX_PACKET_FILTER_INFO){
|
||||||
|
if(paff_array[i].filter_id == filter_id)
|
||||||
|
break;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(i == MAX_PACKET_FILTER_INFO)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
paff_array[i].filter_id = FILTER_ID_INIT_VALUE;
|
||||||
|
paff_array[i].enable = 0;
|
||||||
|
paff_array[i].patt.mask_size = 0;
|
||||||
|
paff_array[i].rule = 0;
|
||||||
|
if(paff_array[i].patt.mask){
|
||||||
|
vPortFree(paff_array[i].patt.mask);
|
||||||
|
paff_array[i].patt.mask = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(paff_array[i].patt.pattern){
|
||||||
|
vPortFree(paff_array[i].patt.pattern);
|
||||||
|
paff_array[i].patt.pattern = NULL;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Make callback simple to prevent latency to wlan rx when promiscuous mode */
|
||||||
|
static void promisc_callback(unsigned char *buf, unsigned int len, void* userdata)
|
||||||
|
{
|
||||||
|
struct eth_frame *frame = (struct eth_frame *) pvPortMalloc(sizeof(struct eth_frame));
|
||||||
|
|
||||||
|
if(frame) {
|
||||||
|
frame->prev = NULL;
|
||||||
|
frame->next = NULL;
|
||||||
|
memcpy(frame->da, buf, 6);
|
||||||
|
memcpy(frame->sa, buf+6, 6);
|
||||||
|
frame->len = len;
|
||||||
|
frame->rssi = ((ieee80211_frame_info_t *)userdata)->rssi;
|
||||||
|
taskENTER_CRITICAL();
|
||||||
|
|
||||||
|
if(eth_buffer.tail) {
|
||||||
|
eth_buffer.tail->next = frame;
|
||||||
|
frame->prev = eth_buffer.tail;
|
||||||
|
eth_buffer.tail = frame;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
eth_buffer.head = frame;
|
||||||
|
eth_buffer.tail = frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
taskEXIT_CRITICAL();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct eth_frame* retrieve_frame(void)
|
||||||
|
{
|
||||||
|
struct eth_frame *frame = NULL;
|
||||||
|
|
||||||
|
taskENTER_CRITICAL();
|
||||||
|
|
||||||
|
if(eth_buffer.head) {
|
||||||
|
frame = eth_buffer.head;
|
||||||
|
|
||||||
|
if(eth_buffer.head->next) {
|
||||||
|
eth_buffer.head = eth_buffer.head->next;
|
||||||
|
eth_buffer.head->prev = NULL;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
eth_buffer.head = NULL;
|
||||||
|
eth_buffer.tail = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
taskEXIT_CRITICAL();
|
||||||
|
|
||||||
|
return frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void promisc_test(int duration, unsigned char len_used)
|
||||||
|
{
|
||||||
|
int ch;
|
||||||
|
unsigned int start_time;
|
||||||
|
struct eth_frame *frame;
|
||||||
|
eth_buffer.head = NULL;
|
||||||
|
eth_buffer.tail = NULL;
|
||||||
|
|
||||||
|
wifi_enter_promisc_mode();
|
||||||
|
wifi_set_promisc(RTW_PROMISC_ENABLE, promisc_callback, len_used);
|
||||||
|
|
||||||
|
for(ch = 1; ch <= 13; ch ++) {
|
||||||
|
if(wifi_set_channel(ch) == 0)
|
||||||
|
printf("\n\n\rSwitch to channel(%d)", ch);
|
||||||
|
|
||||||
|
start_time = xTaskGetTickCount();
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
unsigned int current_time = xTaskGetTickCount();
|
||||||
|
|
||||||
|
if((current_time - start_time) < (duration * configTICK_RATE_HZ)) {
|
||||||
|
frame = retrieve_frame();
|
||||||
|
|
||||||
|
if(frame) {
|
||||||
|
int i;
|
||||||
|
printf("\n\rDA:");
|
||||||
|
for(i = 0; i < 6; i ++)
|
||||||
|
printf(" %02x", frame->da[i]);
|
||||||
|
printf(", SA:");
|
||||||
|
for(i = 0; i < 6; i ++)
|
||||||
|
printf(" %02x", frame->sa[i]);
|
||||||
|
printf(", len=%d", frame->len);
|
||||||
|
printf(", RSSI=%d", frame->rssi);
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(inic_frame_tail){
|
||||||
|
if(inic_frame_cnt < MAX_INIC_FRAME_NUM){
|
||||||
|
memcpy(inic_frame_tail->da, frame->da, 6);
|
||||||
|
memcpy(inic_frame_tail->sa, frame->sa, 6);
|
||||||
|
inic_frame_tail->len = frame->len;
|
||||||
|
inic_frame_tail++;
|
||||||
|
inic_frame_cnt++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
vPortFree((void *) frame);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
vTaskDelay(1); //delay 1 tick
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(inic_frame){
|
||||||
|
inic_c2h_msg("ATWM", RTW_SUCCESS, (char *)inic_frame, sizeof(struct inic_eth_frame)*inic_frame_cnt);
|
||||||
|
memset(inic_frame, '\0', sizeof(struct inic_eth_frame)*MAX_INIC_FRAME_NUM);
|
||||||
|
inic_frame_tail = inic_frame;
|
||||||
|
inic_frame_cnt = 0;
|
||||||
|
rtw_msleep_os(10);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_set_promisc(RTW_PROMISC_DISABLE, NULL, 0);
|
||||||
|
|
||||||
|
while((frame = retrieve_frame()) != NULL)
|
||||||
|
vPortFree((void *) frame);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void promisc_callback_all(unsigned char *buf, unsigned int len, void* userdata)
|
||||||
|
{
|
||||||
|
struct eth_frame *frame = (struct eth_frame *) pvPortMalloc(sizeof(struct eth_frame));
|
||||||
|
|
||||||
|
if(frame) {
|
||||||
|
frame->prev = NULL;
|
||||||
|
frame->next = NULL;
|
||||||
|
memcpy(frame->da, buf+4, 6);
|
||||||
|
memcpy(frame->sa, buf+10, 6);
|
||||||
|
frame->len = len;
|
||||||
|
frame->type = *buf;
|
||||||
|
frame->rssi = ((ieee80211_frame_info_t *)userdata)->rssi;
|
||||||
|
|
||||||
|
taskENTER_CRITICAL();
|
||||||
|
|
||||||
|
if(eth_buffer.tail) {
|
||||||
|
eth_buffer.tail->next = frame;
|
||||||
|
frame->prev = eth_buffer.tail;
|
||||||
|
eth_buffer.tail = frame;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
eth_buffer.head = frame;
|
||||||
|
eth_buffer.tail = frame;
|
||||||
|
}
|
||||||
|
|
||||||
|
taskEXIT_CRITICAL();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
static void promisc_test_all(int duration, unsigned char len_used)
|
||||||
|
{
|
||||||
|
int ch;
|
||||||
|
unsigned int start_time;
|
||||||
|
struct eth_frame *frame;
|
||||||
|
eth_buffer.head = NULL;
|
||||||
|
eth_buffer.tail = NULL;
|
||||||
|
|
||||||
|
wifi_enter_promisc_mode();
|
||||||
|
wifi_set_promisc(RTW_PROMISC_ENABLE_2, promisc_callback_all, len_used);
|
||||||
|
|
||||||
|
for(ch = 1; ch <= 13; ch ++) {
|
||||||
|
if(wifi_set_channel(ch) == 0)
|
||||||
|
printf("\n\n\rSwitch to channel(%d)", ch);
|
||||||
|
|
||||||
|
start_time = xTaskGetTickCount();
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
unsigned int current_time = xTaskGetTickCount();
|
||||||
|
|
||||||
|
if((current_time - start_time) < (duration * configTICK_RATE_HZ)) {
|
||||||
|
frame = retrieve_frame();
|
||||||
|
|
||||||
|
if(frame) {
|
||||||
|
int i;
|
||||||
|
printf("\n\rTYPE: 0x%x, ", frame->type);
|
||||||
|
printf("DA:");
|
||||||
|
for(i = 0; i < 6; i ++)
|
||||||
|
printf(" %02x", frame->da[i]);
|
||||||
|
printf(", SA:");
|
||||||
|
for(i = 0; i < 6; i ++)
|
||||||
|
printf(" %02x", frame->sa[i]);
|
||||||
|
printf(", len=%d", frame->len);
|
||||||
|
printf(", RSSI=%d", frame->rssi);
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(inic_frame_tail){
|
||||||
|
if(inic_frame_cnt < MAX_INIC_FRAME_NUM){
|
||||||
|
memcpy(inic_frame_tail->da, frame->da, 6);
|
||||||
|
memcpy(inic_frame_tail->sa, frame->sa, 6);
|
||||||
|
inic_frame_tail->len = frame->len;
|
||||||
|
inic_frame_tail->type = frame->type;
|
||||||
|
inic_frame_tail++;
|
||||||
|
inic_frame_cnt++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
vPortFree((void *) frame);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
vTaskDelay(1); //delay 1 tick
|
||||||
|
}
|
||||||
|
else
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(inic_frame){
|
||||||
|
inic_c2h_msg("ATWM", RTW_SUCCESS, (char *)inic_frame, sizeof(struct inic_eth_frame)*inic_frame_cnt);
|
||||||
|
memset(inic_frame, '\0', sizeof(struct inic_eth_frame)*MAX_INIC_FRAME_NUM);
|
||||||
|
inic_frame_tail = inic_frame;
|
||||||
|
inic_frame_cnt = 0;
|
||||||
|
rtw_msleep_os(10);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
wifi_set_promisc(RTW_PROMISC_DISABLE, NULL, 0);
|
||||||
|
|
||||||
|
while((frame = retrieve_frame()) != NULL)
|
||||||
|
vPortFree((void *) frame);
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd_promisc(int argc, char **argv)
|
||||||
|
{
|
||||||
|
int duration;
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
inic_frame_tail = inic_frame = pvPortMalloc(sizeof(struct inic_eth_frame)*MAX_INIC_FRAME_NUM);
|
||||||
|
if(inic_frame == NULL){
|
||||||
|
inic_c2h_msg("ATWM", RTW_BUFFER_UNAVAILABLE_TEMPORARY, NULL, 0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_PROMISC
|
||||||
|
wifi_init_packet_filter();
|
||||||
|
#endif
|
||||||
|
if((argc == 2) && ((duration = atoi(argv[1])) > 0))
|
||||||
|
//promisc_test(duration, 0);
|
||||||
|
promisc_test_all(duration, 0);
|
||||||
|
else if((argc == 3) && ((duration = atoi(argv[1])) > 0) && (strcmp(argv[2], "with_len") == 0))
|
||||||
|
promisc_test(duration, 1);
|
||||||
|
else
|
||||||
|
printf("\n\rUsage: %s DURATION_SECONDS [with_len]", argv[0]);
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(inic_frame)
|
||||||
|
vPortFree(inic_frame);
|
||||||
|
inic_frame_tail = NULL;
|
||||||
|
inic_frame_cnt = 0;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#if CONFIG_WLAN
|
606
component/common/api/wifi/wifi_simple_config.c
Executable file
606
component/common/api/wifi/wifi_simple_config.c
Executable file
|
@ -0,0 +1,606 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "main.h"
|
||||||
|
#include "udp.h"
|
||||||
|
#include <sockets.h>
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <osdep_service.h>
|
||||||
|
#include "platform_stdlib.h"
|
||||||
|
#include "wifi_simple_config_parser.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define STACKSIZE 512
|
||||||
|
|
||||||
|
|
||||||
|
#if CONFIG_WLAN
|
||||||
|
#if (CONFIG_INCLUDE_SIMPLE_CONFIG)
|
||||||
|
#include "wifi/wifi_conf.h"
|
||||||
|
int is_promisc_callback_unlock = 0;
|
||||||
|
static int is_fixed_channel;
|
||||||
|
int fixed_channel_num;
|
||||||
|
unsigned char g_ssid[32];
|
||||||
|
int g_ssid_len;
|
||||||
|
|
||||||
|
extern int promisc_get_fixed_channel( void *, u8 *, int* );
|
||||||
|
struct pattern_test_ops;
|
||||||
|
struct rtk_test_sc;
|
||||||
|
|
||||||
|
typedef int (*sc_test_check_pattern_call_back)(struct pattern_test_ops *pp, struct rtk_test_sc *pSc);
|
||||||
|
typedef int (*sc_test_get_cipher_info_call_back)(struct pattern_test_ops *pp, struct rtk_test_sc *pSc);
|
||||||
|
typedef int (*sc_test_generate_key_call_back)(struct pattern_test_ops *pp, struct rtk_test_sc *pSc);
|
||||||
|
typedef int (*sc_test_decode_profile_call_back)(struct pattern_test_ops *pp, struct rtk_test_sc *pSc);
|
||||||
|
typedef int (*sc_test_get_tlv_info_call_back)(struct pattern_test_ops *pp, struct rtk_test_sc *pSc);
|
||||||
|
|
||||||
|
struct pattern_test_ops {
|
||||||
|
unsigned int index;
|
||||||
|
unsigned flag;
|
||||||
|
unsigned char name[64];
|
||||||
|
sc_test_check_pattern_call_back check_pattern;
|
||||||
|
sc_test_get_cipher_info_call_back get_cipher_info;
|
||||||
|
sc_test_generate_key_call_back generate_key;
|
||||||
|
sc_test_decode_profile_call_back decode_profile;
|
||||||
|
sc_test_get_tlv_info_call_back get_tlv_info;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
struct rtk_test_sc {
|
||||||
|
/* API exposed to user */
|
||||||
|
unsigned char ssid[32];
|
||||||
|
unsigned char password[65];
|
||||||
|
unsigned int ip_addr;
|
||||||
|
};
|
||||||
|
|
||||||
|
enum sc_result {
|
||||||
|
SC_ERROR = -1, /* default error code*/
|
||||||
|
SC_NO_CONTROLLER_FOUND = 1, /* cannot get sta(controller) in the air which starts a simple config session */
|
||||||
|
SC_CONTROLLER_INFO_PARSE_FAIL, /* cannot parse the sta's info */
|
||||||
|
SC_TARGET_CHANNEL_SCAN_FAIL, /* cannot scan the target channel */
|
||||||
|
SC_JOIN_BSS_FAIL, /* fail to connect to target ap */
|
||||||
|
SC_DHCP_FAIL, /* fail to get ip address from target ap */
|
||||||
|
/* fail to create udp socket to send info to controller. note that client isolation
|
||||||
|
must be turned off in ap. we cannot know if ap has configured this */
|
||||||
|
SC_UDP_SOCKET_CREATE_FAIL,
|
||||||
|
SC_SUCCESS, /* default success code */
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||||
|
#include "arch/bpstruct.h"
|
||||||
|
#endif
|
||||||
|
PACK_STRUCT_BEGIN
|
||||||
|
struct ack_msg {
|
||||||
|
PACK_STRUCT_FIELD(u8_t flag);
|
||||||
|
PACK_STRUCT_FIELD(u16_t length);
|
||||||
|
PACK_STRUCT_FIELD(u8_t smac[6]);
|
||||||
|
PACK_STRUCT_FIELD(u8_t status);
|
||||||
|
PACK_STRUCT_FIELD(u16_t device_type);
|
||||||
|
PACK_STRUCT_FIELD(u32_t device_ip);
|
||||||
|
PACK_STRUCT_FIELD(u8_t device_name[64]);
|
||||||
|
};PACK_STRUCT_STRUCT;
|
||||||
|
PACK_STRUCT_END
|
||||||
|
#ifdef PACK_STRUCT_USE_INCLUDES
|
||||||
|
#include "arch/epstruct.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#define MULCAST_PORT (8864)
|
||||||
|
|
||||||
|
#define SCAN_BUFFER_LENGTH (1024)
|
||||||
|
|
||||||
|
#ifndef WLAN0_NAME
|
||||||
|
#define WLAN0_NAME "wlan0"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int simple_config_result;
|
||||||
|
static struct ack_msg *ack_content;
|
||||||
|
struct rtk_test_sc *backup_sc_ctx;
|
||||||
|
extern struct netif xnetif[NET_IF_NUM];
|
||||||
|
void SC_set_ack_content()
|
||||||
|
{
|
||||||
|
memset(ack_content, 0, sizeof(struct ack_msg));
|
||||||
|
ack_content->flag = 0x20;
|
||||||
|
ack_content->length = htons(sizeof(struct ack_msg)-3);
|
||||||
|
memcpy(ack_content->smac, xnetif[0].hwaddr, 6);
|
||||||
|
ack_content->status = 0;
|
||||||
|
ack_content->device_type = 0;
|
||||||
|
ack_content->device_ip = xnetif[0].ip_addr.addr;
|
||||||
|
memset(ack_content->device_name, 0, 64);
|
||||||
|
}
|
||||||
|
|
||||||
|
int SC_send_simple_config_ack()
|
||||||
|
{
|
||||||
|
#if CONFIG_LWIP_LAYER
|
||||||
|
int ack_transmit_round, ack_num_each_sec;
|
||||||
|
int ack_socket;
|
||||||
|
//int sended_data = 0;
|
||||||
|
struct sockaddr_in to_addr;
|
||||||
|
|
||||||
|
SC_set_ack_content();
|
||||||
|
|
||||||
|
ack_socket = socket(PF_INET, SOCK_DGRAM, IP_PROTO_UDP);
|
||||||
|
if (ack_socket == -1) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
FD_ZERO(&to_addr);
|
||||||
|
to_addr.sin_family = AF_INET;
|
||||||
|
to_addr.sin_port = htons(8864);
|
||||||
|
to_addr.sin_addr.s_addr = (backup_sc_ctx->ip_addr);
|
||||||
|
|
||||||
|
for (ack_transmit_round = 0;ack_transmit_round < 10; ack_transmit_round++) {
|
||||||
|
for (ack_num_each_sec = 0;ack_num_each_sec < 10; ack_num_each_sec++) {
|
||||||
|
//sended_data =
|
||||||
|
sendto(ack_socket, (unsigned char *)ack_content, sizeof(struct ack_msg), 0, (struct sockaddr *) &to_addr, sizeof(struct sockaddr));
|
||||||
|
//printf("\r\nAlready send %d bytes data\n", sended_data);
|
||||||
|
vTaskDelay(100); /* delay 100 ms */
|
||||||
|
}
|
||||||
|
}
|
||||||
|
close(ack_socket);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
extern unsigned int inic_sc_ip_addr;
|
||||||
|
inic_sc_ip_addr = backup_sc_ctx->ip_addr;
|
||||||
|
inic_c2h_wifi_info("ATWQ", RTW_SUCCESS);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static enum sc_result SC_check_and_show_connection_info(void)
|
||||||
|
{
|
||||||
|
rtw_wifi_setting_t setting;
|
||||||
|
int ret = -1;
|
||||||
|
|
||||||
|
#if CONFIG_LWIP_LAYER
|
||||||
|
/* If not rise priority, LwIP DHCP may timeout */
|
||||||
|
vTaskPrioritySet(NULL, tskIDLE_PRIORITY + 3);
|
||||||
|
/* Start DHCP Client */
|
||||||
|
ret = LwIP_DHCP(0, DHCP_START);
|
||||||
|
vTaskPrioritySet(NULL, tskIDLE_PRIORITY + 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
wifi_get_setting(WLAN0_NAME, &setting);
|
||||||
|
wifi_show_setting(WLAN0_NAME, &setting);
|
||||||
|
|
||||||
|
#if CONFIG_LWIP_LAYER
|
||||||
|
if (ret != DHCP_ADDRESS_ASSIGNED)
|
||||||
|
return SC_DHCP_FAIL;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
return SC_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void check_and_set_security_in_connection(rtw_security_t security_mode, rtw_network_info_t *wifi)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (security_mode == RTW_SECURITY_WPA2_AES_PSK) {
|
||||||
|
printf("\r\nwifi->security_type = RTW_SECURITY_WPA2_AES_PSK\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_WPA2_AES_PSK;
|
||||||
|
} else if (security_mode == RTW_SECURITY_WEP_PSK) {
|
||||||
|
printf("\r\nwifi->security_type = RTW_SECURITY_WEP_PSK\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_WEP_PSK;
|
||||||
|
wifi->key_id = 0;
|
||||||
|
} else if (security_mode == RTW_SECURITY_WPA_AES_PSK) {
|
||||||
|
printf("\r\nwifi->security_type = RTW_SECURITY_WPA_AES_PSK\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_WPA_AES_PSK;
|
||||||
|
} else {
|
||||||
|
printf("\r\nwifi->security_type = RTW_SECURITY_OPEN\n");
|
||||||
|
wifi->security_type = RTW_SECURITY_OPEN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static int get_connection_info_from_profile(rtw_security_t security_mode, rtw_network_info_t *wifi)
|
||||||
|
{
|
||||||
|
|
||||||
|
printf("\r\n======= Connection Information =======\n");
|
||||||
|
check_and_set_security_in_connection(security_mode, wifi);
|
||||||
|
|
||||||
|
wifi->password = backup_sc_ctx->password;
|
||||||
|
wifi->password_len = (int)strlen((char const *)backup_sc_ctx->password);
|
||||||
|
|
||||||
|
if ( g_ssid_len > 0 && g_ssid_len < 33){
|
||||||
|
wifi->ssid.len = g_ssid_len;
|
||||||
|
rtw_memcpy(wifi->ssid.val, g_ssid, wifi->ssid.len);
|
||||||
|
}else if(strlen(backup_sc_ctx->ssid) > 0 && strlen(backup_sc_ctx->ssid) < 33){
|
||||||
|
wifi->ssid.len = strlen(backup_sc_ctx->ssid);
|
||||||
|
rtw_memcpy(wifi->ssid.val, backup_sc_ctx->ssid, wifi->ssid.len);
|
||||||
|
}else{
|
||||||
|
printf("\r\n SSID is NULL or SSID length is over 32!!");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(wifi->security_type == RTW_SECURITY_WEP_PSK)
|
||||||
|
{
|
||||||
|
if(wifi->password_len == 10)
|
||||||
|
{
|
||||||
|
u32 p[5];
|
||||||
|
u8 pwd[6], i = 0;
|
||||||
|
sscanf((const char*)backup_sc_ctx->password, "%02x%02x%02x%02x%02x", &p[0], &p[1], &p[2], &p[3], &p[4]);
|
||||||
|
for(i=0; i< 5; i++)
|
||||||
|
pwd[i] = (u8)p[i];
|
||||||
|
pwd[5] = '\0';
|
||||||
|
memset(backup_sc_ctx->password, 0, 65);
|
||||||
|
strcpy((char*)backup_sc_ctx->password, (char*)pwd);
|
||||||
|
wifi->password_len = 5;
|
||||||
|
}else if(wifi->password_len == 26){
|
||||||
|
u32 p[13];
|
||||||
|
u8 pwd[14], i = 0;
|
||||||
|
sscanf((const char*)backup_sc_ctx->password, "%02x%02x%02x%02x%02x%02x%02x"\
|
||||||
|
"%02x%02x%02x%02x%02x%02x", &p[0], &p[1], &p[2], &p[3], &p[4],\
|
||||||
|
&p[5], &p[6], &p[7], &p[8], &p[9], &p[10], &p[11], &p[12]);
|
||||||
|
for(i=0; i< 13; i++)
|
||||||
|
pwd[i] = (u8)p[i];
|
||||||
|
pwd[13] = '\0';
|
||||||
|
memset(backup_sc_ctx->password, 0, 64);
|
||||||
|
strcpy((char*)backup_sc_ctx->password, (char*)pwd);
|
||||||
|
wifi->password_len = 13;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf("\r\nwifi.password = %s\n", wifi->password);
|
||||||
|
printf("\r\nwifi.password_len = %d\n", wifi->password_len);
|
||||||
|
printf("\r\nwifi.ssid = %s\n", wifi->ssid.val);
|
||||||
|
printf("\r\nwifi.ssid_len = %d\n", wifi->ssid.len);
|
||||||
|
printf("\r\nwifi.channel = %d\n", fixed_channel_num);
|
||||||
|
printf("\r\n===== start to connect target AP =====\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum sc_result SC_connect_to_AP(void)
|
||||||
|
{
|
||||||
|
enum sc_result ret = SC_ERROR;
|
||||||
|
u8 scan_channel;
|
||||||
|
u8 pscan_config;
|
||||||
|
int max_retry = 10, retry = 0;
|
||||||
|
rtw_security_t security_mode;
|
||||||
|
rtw_network_info_t wifi = {0};
|
||||||
|
if(!(fixed_channel_num == 0)){
|
||||||
|
scan_channel = fixed_channel_num;
|
||||||
|
}
|
||||||
|
pscan_config = PSCAN_ENABLE | PSCAN_SIMPLE_CONFIG;
|
||||||
|
switch(g_security_mode){
|
||||||
|
case RTW_ENCRYPTION_OPEN:
|
||||||
|
security_mode = RTW_SECURITY_OPEN;
|
||||||
|
break;
|
||||||
|
case RTW_ENCRYPTION_WEP40:
|
||||||
|
case RTW_ENCRYPTION_WEP104:
|
||||||
|
security_mode = RTW_SECURITY_WEP_PSK;
|
||||||
|
break;
|
||||||
|
case RTW_ENCRYPTION_WPA_TKIP:
|
||||||
|
case RTW_ENCRYPTION_WPA_AES:
|
||||||
|
case RTW_ENCRYPTION_WPA2_TKIP:
|
||||||
|
case RTW_ENCRYPTION_WPA2_AES:
|
||||||
|
case RTW_ENCRYPTION_WPA2_MIXED:
|
||||||
|
security_mode = RTW_SECURITY_WPA2_AES_PSK;
|
||||||
|
break;
|
||||||
|
case RTW_ENCRYPTION_UNKNOWN:
|
||||||
|
case RTW_ENCRYPTION_UNDEF:
|
||||||
|
default:
|
||||||
|
printf("\r\n unknow security mode,connect fail!");
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
g_security_mode = 0xff;//clear it
|
||||||
|
|
||||||
|
if (-1 == get_connection_info_from_profile(security_mode, &wifi)) {
|
||||||
|
ret = SC_CONTROLLER_INFO_PARSE_FAIL;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
if(wifi_set_pscan_chan(&scan_channel, &pscan_config, 1) < 0){
|
||||||
|
printf("\n\rERROR: wifi set partial scan channel fail");
|
||||||
|
ret = SC_TARGET_CHANNEL_SCAN_FAIL;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
#if 0
|
||||||
|
ret = wifi_connect((char*)wifi.ssid.val,
|
||||||
|
wifi.security_type,
|
||||||
|
(char*)wifi.password,
|
||||||
|
wifi.ssid.len,
|
||||||
|
wifi.password_len,
|
||||||
|
wifi.key_id,
|
||||||
|
NULL);
|
||||||
|
#else
|
||||||
|
ret = wifi_connect_bssid(g_bssid,
|
||||||
|
(char*)wifi.ssid.val,
|
||||||
|
wifi.security_type,
|
||||||
|
(char*)wifi.password,
|
||||||
|
6,
|
||||||
|
wifi.ssid.len,
|
||||||
|
wifi.password_len,
|
||||||
|
wifi.key_id,
|
||||||
|
NULL);
|
||||||
|
#endif
|
||||||
|
if (ret == RTW_SUCCESS) {
|
||||||
|
ret = SC_check_and_show_connection_info();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (retry == max_retry) {
|
||||||
|
ret = SC_JOIN_BSS_FAIL;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
retry ++;
|
||||||
|
if(retry > 3){
|
||||||
|
vTaskDelay(5000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
/* Make callback one by one to wlan rx when promiscuous mode */
|
||||||
|
|
||||||
|
void simple_config_callback(unsigned char *buf, unsigned int len, void* userdata)
|
||||||
|
{
|
||||||
|
unsigned char * da = buf;
|
||||||
|
unsigned char * sa = buf + ETH_ALEN;
|
||||||
|
taskENTER_CRITICAL();
|
||||||
|
if (is_promisc_callback_unlock == 1) {
|
||||||
|
simple_config_result = rtk_start_parse_packet(da, sa, len, userdata, (void *)backup_sc_ctx);
|
||||||
|
//printf("\r\nresult in callback function = %d\n",simple_config_result);
|
||||||
|
}
|
||||||
|
taskEXIT_CRITICAL();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned int simple_config_cmd_start_time;
|
||||||
|
static unsigned int simple_config_cmd_current_time;
|
||||||
|
extern int simple_config_status;
|
||||||
|
extern void rtk_restart_simple_config(void);
|
||||||
|
|
||||||
|
|
||||||
|
extern void rtk_sc_deinit(void);
|
||||||
|
|
||||||
|
void init_simple_config_lib_config(struct simple_config_lib_config* config)
|
||||||
|
{
|
||||||
|
config->free = rtw_mfree;
|
||||||
|
config->malloc = rtw_malloc;
|
||||||
|
config->memcmp = (simple_config_memcmp_fn)_memcmp;
|
||||||
|
config->memcpy = _memcpy;
|
||||||
|
config->memset = _memset;
|
||||||
|
config->printf = printf;
|
||||||
|
config->strcpy = strcpy;
|
||||||
|
config->strlen = strlen;
|
||||||
|
config->zmalloc = rtw_zmalloc;
|
||||||
|
config->_ntohl = lwip_ntohl;
|
||||||
|
|
||||||
|
config->is_promisc_callback_unlock = &is_promisc_callback_unlock;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int init_test_data(char *custom_pin_code)
|
||||||
|
{
|
||||||
|
#if (CONFIG_INCLUDE_SIMPLE_CONFIG)
|
||||||
|
is_promisc_callback_unlock = 1;
|
||||||
|
is_fixed_channel = 0;
|
||||||
|
fixed_channel_num = 0;
|
||||||
|
simple_config_result = 0;
|
||||||
|
rtw_memset(g_ssid, 0, 32);
|
||||||
|
g_ssid_len = 0;
|
||||||
|
simple_config_cmd_start_time = xTaskGetTickCount();
|
||||||
|
|
||||||
|
if (ack_content != NULL) {
|
||||||
|
vPortFree(ack_content);
|
||||||
|
ack_content = NULL;
|
||||||
|
}
|
||||||
|
ack_content = pvPortMalloc(sizeof(struct ack_msg));
|
||||||
|
if (!ack_content) {
|
||||||
|
printf("\n\rrtk_sc_init fail by allocate ack\n");
|
||||||
|
}
|
||||||
|
memset(ack_content, 0, sizeof(struct ack_msg));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
backup_sc_ctx = pvPortMalloc(sizeof(struct rtk_test_sc));
|
||||||
|
if (!backup_sc_ctx) {
|
||||||
|
printf("\n\r[Mem]malloc SC context fail\n");
|
||||||
|
} else {
|
||||||
|
memset(backup_sc_ctx, 0, sizeof(struct rtk_test_sc));
|
||||||
|
struct simple_config_lib_config lib_config;
|
||||||
|
init_simple_config_lib_config(&lib_config);
|
||||||
|
//custom_pin_code can be null
|
||||||
|
if (rtk_sc_init(custom_pin_code, &lib_config) < 0) {
|
||||||
|
printf("\n\rRtk_sc_init fail\n");
|
||||||
|
} else {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
printf("\n\rPlatform no include simple config now\n");
|
||||||
|
#endif
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void deinit_test_data(){
|
||||||
|
#if (CONFIG_INCLUDE_SIMPLE_CONFIG)
|
||||||
|
rtk_sc_deinit();
|
||||||
|
if (backup_sc_ctx != NULL) {
|
||||||
|
vPortFree(backup_sc_ctx);
|
||||||
|
backup_sc_ctx = NULL;
|
||||||
|
}
|
||||||
|
if (ack_content != NULL) {
|
||||||
|
vPortFree(ack_content);
|
||||||
|
ack_content = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
enum sc_result simple_config_test(void)
|
||||||
|
{
|
||||||
|
int channel = 1;
|
||||||
|
enum sc_result ret = SC_SUCCESS;
|
||||||
|
unsigned int start_time;
|
||||||
|
int is_need_connect_to_AP = 0;
|
||||||
|
int fix_channel = 0;
|
||||||
|
int delta_time = 0;
|
||||||
|
wifi_set_promisc(RTW_PROMISC_ENABLE, simple_config_callback, 1);
|
||||||
|
start_time = xTaskGetTickCount();
|
||||||
|
printf("\n\r");
|
||||||
|
wifi_set_channel(channel);
|
||||||
|
while (1) {
|
||||||
|
vTaskDelay(50); //delay 0.5s to release CPU usage
|
||||||
|
simple_config_cmd_current_time = xTaskGetTickCount();
|
||||||
|
if (simple_config_cmd_current_time - simple_config_cmd_start_time < ((120 + delta_time)*configTICK_RATE_HZ)) {
|
||||||
|
unsigned int current_time = xTaskGetTickCount();
|
||||||
|
if (((current_time - start_time)*1000 /configTICK_RATE_HZ < 100)
|
||||||
|
|| (is_fixed_channel == 1)) {
|
||||||
|
if((is_fixed_channel == 0)&&(!((fix_channel = promisc_get_fixed_channel(g_bssid,g_ssid,&g_ssid_len))== 0))){
|
||||||
|
//printf("\r\n in simple_config_test fix channel = %d ",fix_channel);
|
||||||
|
is_fixed_channel = 1;
|
||||||
|
fixed_channel_num = fix_channel;
|
||||||
|
wifi_set_channel(fix_channel);
|
||||||
|
}
|
||||||
|
if (simple_config_result == 1) {
|
||||||
|
is_need_connect_to_AP = 1;
|
||||||
|
is_fixed_channel = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (simple_config_result == -1) {
|
||||||
|
printf("\r\nsimple_config_test restart for result = -1");
|
||||||
|
delta_time = 60;
|
||||||
|
wifi_set_channel(1);
|
||||||
|
is_need_connect_to_AP = 0;
|
||||||
|
is_fixed_channel = 0;
|
||||||
|
fixed_channel_num = 0;
|
||||||
|
memset(g_ssid, 0, 32);
|
||||||
|
g_ssid_len = 0;
|
||||||
|
simple_config_result = 0;
|
||||||
|
g_security_mode = 0xff;
|
||||||
|
rtk_restart_simple_config();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
channel++;
|
||||||
|
if ((1 <= channel) && (channel <= 13)) {
|
||||||
|
if (wifi_set_channel(channel) == 0) {
|
||||||
|
start_time = xTaskGetTickCount();
|
||||||
|
printf("\n\rSwitch to channel(%d)\n", channel);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
channel = 1;
|
||||||
|
if (wifi_set_channel(channel) == 0) {
|
||||||
|
start_time = xTaskGetTickCount();
|
||||||
|
printf("\n\rSwitch to channel(%d)\n", channel);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ret = SC_NO_CONTROLLER_FOUND;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
wifi_set_promisc(RTW_PROMISC_DISABLE, NULL, 0);
|
||||||
|
if (is_need_connect_to_AP == 1) {
|
||||||
|
enum sc_result tmp_res = SC_connect_to_AP();
|
||||||
|
if (SC_SUCCESS == tmp_res) {
|
||||||
|
if(-1 == SC_send_simple_config_ack())
|
||||||
|
ret = SC_UDP_SOCKET_CREATE_FAIL;
|
||||||
|
} else {
|
||||||
|
return tmp_res;
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
ret = SC_NO_CONTROLLER_FOUND;
|
||||||
|
}
|
||||||
|
|
||||||
|
deinit_test_data();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
//Filter packet da[] = {0x01, 0x00, 0x5e}
|
||||||
|
#define MASK_SIZE 3
|
||||||
|
void filter_add_enable(){
|
||||||
|
u8 mask[MASK_SIZE]={0xFF,0xFF,0xFF};
|
||||||
|
u8 pattern[MASK_SIZE]={0x01,0x00,0x5e};
|
||||||
|
|
||||||
|
rtw_packet_filter_pattern_t packet_filter;
|
||||||
|
rtw_packet_filter_rule_e rule;
|
||||||
|
|
||||||
|
packet_filter.offset = 0;
|
||||||
|
packet_filter.mask_size = 3;
|
||||||
|
packet_filter.mask = mask;
|
||||||
|
packet_filter.pattern = pattern;
|
||||||
|
rule = RTW_POSITIVE_MATCHING;
|
||||||
|
|
||||||
|
wifi_init_packet_filter();
|
||||||
|
wifi_add_packet_filter(1, &packet_filter,rule);
|
||||||
|
wifi_enable_packet_filter(1);
|
||||||
|
}
|
||||||
|
void remove_filter(){
|
||||||
|
wifi_disable_packet_filter(1);
|
||||||
|
wifi_remove_packet_filter(1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void print_simple_config_result(enum sc_result sc_code)
|
||||||
|
{
|
||||||
|
printf("\r\n");
|
||||||
|
switch (sc_code) {
|
||||||
|
case SC_NO_CONTROLLER_FOUND:
|
||||||
|
printf("Simple Config timeout!! Can't get Ap profile. Please try again\n");
|
||||||
|
break;
|
||||||
|
case SC_CONTROLLER_INFO_PARSE_FAIL:
|
||||||
|
printf("Simple Config fail, cannot parse target ap info from controller\n");
|
||||||
|
break;
|
||||||
|
case SC_TARGET_CHANNEL_SCAN_FAIL:
|
||||||
|
printf("Simple Config cannot scan the target channel\n");
|
||||||
|
break;
|
||||||
|
case SC_JOIN_BSS_FAIL:
|
||||||
|
printf("Simple Config Join bss failed\n");
|
||||||
|
break;
|
||||||
|
case SC_DHCP_FAIL:
|
||||||
|
printf("Simple Config fail, cannot get dhcp ip address\n");
|
||||||
|
break;
|
||||||
|
case SC_UDP_SOCKET_CREATE_FAIL:
|
||||||
|
printf("Simple Config Ack socket create fail!!!\n");
|
||||||
|
break;
|
||||||
|
case SC_SUCCESS:
|
||||||
|
printf("Simple Config success\n");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case SC_ERROR:
|
||||||
|
default:
|
||||||
|
printf("unknown error when simple config!\n");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //CONFIG_INCLUDE_SIMPLE_CONFIG
|
||||||
|
|
||||||
|
void cmd_simple_config(int argc, char **argv){
|
||||||
|
#if CONFIG_INCLUDE_SIMPLE_CONFIG
|
||||||
|
char *custom_pin_code = NULL;
|
||||||
|
enum sc_result ret = SC_ERROR;
|
||||||
|
|
||||||
|
if(argc > 2){
|
||||||
|
printf("\n\rInput Error!");
|
||||||
|
}
|
||||||
|
|
||||||
|
if(argc == 2)
|
||||||
|
custom_pin_code = (argv[1]);
|
||||||
|
|
||||||
|
wifi_enter_promisc_mode();
|
||||||
|
if(init_test_data(custom_pin_code) == 0){
|
||||||
|
filter_add_enable();
|
||||||
|
ret = simple_config_test();
|
||||||
|
print_simple_config_result(ret);
|
||||||
|
remove_filter();
|
||||||
|
}
|
||||||
|
#if CONFIG_INIC_CMD_RSP
|
||||||
|
if(ret != SC_SUCCESS)
|
||||||
|
inic_c2h_wifi_info("ATWQ", RTW_ERROR);
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif //#if CONFIG_WLAN
|
85
component/common/api/wifi/wifi_simple_config_parser.h
Executable file
85
component/common/api/wifi/wifi_simple_config_parser.h
Executable file
|
@ -0,0 +1,85 @@
|
||||||
|
#ifndef __SIMPLE_CONFIG_H__
|
||||||
|
#define __SIMPLE_CONFIG_H__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* This macro means user take simple config
|
||||||
|
* lib to another platform such as linux, and
|
||||||
|
* have no rom crypto libs of simple config,
|
||||||
|
* so we take simple_config_crypto as a sw lib
|
||||||
|
* This macro is used by Realtek internal to generate simple config lib
|
||||||
|
* Please delete this macro after generation.
|
||||||
|
*/
|
||||||
|
#define SIMPLE_CONFIG_PLATFORM_LIB 0
|
||||||
|
|
||||||
|
#include "platform_opts.h"
|
||||||
|
#include "autoconf.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/* platform related settings */
|
||||||
|
#undef u32
|
||||||
|
#undef s32
|
||||||
|
#undef u8
|
||||||
|
#undef s8
|
||||||
|
#undef u16
|
||||||
|
#undef s16
|
||||||
|
typedef unsigned int u32;
|
||||||
|
typedef signed int s32;
|
||||||
|
typedef unsigned char u8;
|
||||||
|
typedef char s8;
|
||||||
|
typedef unsigned short int u16;
|
||||||
|
typedef signed short int s16;
|
||||||
|
|
||||||
|
typedef s32 (*simple_config_printf_fn) (const s8 *fmt, ...);
|
||||||
|
typedef void* (*simple_config_memset_fn) (void *dst0, s32 Val, u32 length);
|
||||||
|
typedef void* (*simple_config_memcpy_fn) ( void *s1, const void *s2, u32 n );
|
||||||
|
typedef u32 (*simple_config_strlen_fn) (const char *s);
|
||||||
|
typedef char * (*simple_config_strcpy_fn) (s8 *dest, const s8 *src);
|
||||||
|
typedef void (*simple_config_free_fn) (u8 *pbuf, u32 sz);
|
||||||
|
typedef u8* (*simple_config_zmalloc_fn) (u32 sz);
|
||||||
|
typedef u8* (*simple_config_malloc_fn) (u32 sz);
|
||||||
|
typedef int (*simple_config_memcmp_fn) (const void *av, const void *bv, u32 len);
|
||||||
|
typedef u32 (*simple_config_ntohl_fn)(u32 x);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
struct simple_config_lib_config {
|
||||||
|
simple_config_printf_fn printf;
|
||||||
|
simple_config_memset_fn memset;
|
||||||
|
simple_config_memcpy_fn memcpy;
|
||||||
|
simple_config_strlen_fn strlen;
|
||||||
|
simple_config_strcpy_fn strcpy;
|
||||||
|
simple_config_free_fn free;
|
||||||
|
simple_config_zmalloc_fn zmalloc;
|
||||||
|
simple_config_malloc_fn malloc;
|
||||||
|
simple_config_memcmp_fn memcmp;
|
||||||
|
simple_config_ntohl_fn _ntohl;
|
||||||
|
|
||||||
|
|
||||||
|
int *is_promisc_callback_unlock;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/* expose data */
|
||||||
|
extern s32 is_promisc_callback_unlock;
|
||||||
|
extern u8 g_bssid[6];
|
||||||
|
extern u8 g_security_mode;
|
||||||
|
|
||||||
|
/* expose API */
|
||||||
|
extern s32 rtk_sc_init(char *custom_pin_code, struct simple_config_lib_config* config);
|
||||||
|
extern s32 rtk_start_parse_packet(u8 *da, u8 *sa, s32 len, void * user_data, void *backup_sc);
|
||||||
|
extern void rtk_restart_simple_config(void);
|
||||||
|
extern void rtk_sc_deinit();
|
||||||
|
extern void wifi_enter_promisc_mode();
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* __SIMPLE_CONFIG_H__*/
|
1086
component/common/api/wifi/wifi_util.c
Executable file
1086
component/common/api/wifi/wifi_util.c
Executable file
File diff suppressed because it is too large
Load diff
65
component/common/api/wifi/wifi_util.h
Executable file
65
component/common/api/wifi/wifi_util.h
Executable file
|
@ -0,0 +1,65 @@
|
||||||
|
#ifndef _UTIL_H
|
||||||
|
#define _UTIL_H
|
||||||
|
|
||||||
|
#include <wireless.h>
|
||||||
|
#include <wlan_intf.h>
|
||||||
|
#include <wifi_constants.h>
|
||||||
|
#include "wifi_structures.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int wext_get_ssid(const char *ifname, __u8 *ssid);
|
||||||
|
int wext_set_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len);
|
||||||
|
int wext_set_auth_param(const char *ifname, __u16 idx, __u32 value);
|
||||||
|
int wext_set_key_ext(const char *ifname, __u16 alg, const __u8 *addr, int key_idx, int set_tx, const __u8 *seq, __u16 seq_len, __u8 *key, __u16 key_len);
|
||||||
|
int wext_get_enc_ext(const char *ifname, __u16 *alg, __u8 *key_idx, __u8 *passphrase);
|
||||||
|
int wext_set_passphrase(const char *ifname, const __u8 *passphrase, __u16 passphrase_len);
|
||||||
|
int wext_get_passphrase(const char *ifname, __u8 *passphrase);
|
||||||
|
int wext_set_mode(const char *ifname, int mode);
|
||||||
|
int wext_get_mode(const char *ifname, int *mode);
|
||||||
|
int wext_set_ap_ssid(const char *ifname, const __u8 *ssid, __u16 ssid_len);
|
||||||
|
int wext_set_country(const char *ifname, rtw_country_code_t country_code);
|
||||||
|
int wext_get_rssi(const char *ifname, int *rssi);
|
||||||
|
int wext_set_channel(const char *ifname, __u8 ch);
|
||||||
|
int wext_get_channel(const char *ifname, __u8 *ch);
|
||||||
|
int wext_register_multicast_address(const char *ifname, rtw_mac_t *mac);
|
||||||
|
int wext_unregister_multicast_address(const char *ifname, rtw_mac_t *mac);
|
||||||
|
int wext_set_scan(const char *ifname, char *buf, __u16 buf_len, __u16 flags);
|
||||||
|
int wext_get_scan(const char *ifname, char *buf, __u16 buf_len);
|
||||||
|
int wext_set_mac_address(const char *ifname, char * mac);
|
||||||
|
int wext_get_mac_address(const char *ifname, char * mac);
|
||||||
|
int wext_enable_powersave(const char *ifname, __u8 lps_mode, __u8 ips_mode);
|
||||||
|
int wext_disable_powersave(const char *ifname);
|
||||||
|
int wext_set_tdma_param(const char *ifname, __u8 slot_period, __u8 rfon_period_len_1, __u8 rfon_period_len_2, __u8 rfon_period_len_3);
|
||||||
|
int wext_set_lps_dtim(const char *ifname, __u8 lps_dtim);
|
||||||
|
int wext_get_tx_power(const char *ifname, __u8 *poweridx);
|
||||||
|
int wext_set_txpower(const char *ifname, int poweridx);
|
||||||
|
int wext_get_associated_client_list(const char *ifname, void * client_list_buffer, __u16 buffer_length);
|
||||||
|
int wext_get_ap_info(const char *ifname, rtw_bss_info_t * ap_info, rtw_security_t* security);
|
||||||
|
int wext_mp_command(const char *ifname, char *cmd, int show_msg);
|
||||||
|
int wext_private_command(const char *ifname, char *cmd, int show_msg);
|
||||||
|
int wext_private_command_with_retval(const char *ifname, char *cmd, char *ret_buf, int ret_len);
|
||||||
|
void wext_wlan_indicate(unsigned int cmd, union iwreq_data *wrqu, char *extra);
|
||||||
|
int wext_set_pscan_channel(const char *ifname, __u8 *ch, __u8 *pscan_config, __u8 length);
|
||||||
|
int wext_set_autoreconnect(const char *ifname, __u8 mode, __u8 retyr_times, __u16 timeout);
|
||||||
|
int wext_get_autoreconnect(const char *ifname, __u8 *mode);
|
||||||
|
#ifdef CONFIG_CUSTOM_IE
|
||||||
|
int wext_add_custom_ie(const char *ifname, void * cus_ie, int ie_num);
|
||||||
|
int wext_update_custom_ie(const char *ifname, void * cus_ie, int ie_index);
|
||||||
|
int wext_del_custom_ie(const char *ifname);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define wext_handshake_done rltk_wlan_handshake_done
|
||||||
|
|
||||||
|
#ifdef CONFIG_P2P_NEW
|
||||||
|
int wext_send_mgnt(const char *ifname, char *buf, __u16 buf_len, __u16 flags);
|
||||||
|
#endif
|
||||||
|
int wext_set_gen_ie(const char *ifname, char *buf, __u16 buf_len, __u16 flags);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _UTIL_H */
|
41
component/common/api/wifi_interactive_ext.h
Executable file
41
component/common/api/wifi_interactive_ext.h
Executable file
|
@ -0,0 +1,41 @@
|
||||||
|
#define CONFIG_EXTERN_TEST 0
|
||||||
|
#define CONFIG_EXTERN_HW 0
|
||||||
|
#define CONFIG_EXTERN_CLOUD 0
|
||||||
|
#define CONFIG_TTCP 0
|
||||||
|
|
||||||
|
/* External Function */
|
||||||
|
#if CONFIG_EXTERN_TEST
|
||||||
|
extern void cmd_tcpecho(int argc, char **argv);
|
||||||
|
#endif
|
||||||
|
#if CONFIG_EXTERN_HW
|
||||||
|
extern void cmd_led(int argc, char **argv);
|
||||||
|
extern void cmd_tmp75(int argc, char **argv);
|
||||||
|
#endif
|
||||||
|
#if CONFIG_EXTERN_CLOUD
|
||||||
|
extern void cmd_cloud(int argc, char **argv);
|
||||||
|
extern void cmd_reboot(int argc, char **argv);
|
||||||
|
extern void cmd_config(int argc, char **argv);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_TTCP
|
||||||
|
extern void cmd_ttcp(int argc, char **argv);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static const cmd_entry ext_cmd_table[] = {
|
||||||
|
#if CONFIG_EXTERN_TEST
|
||||||
|
{"tcpecho", cmd_tcpecho},
|
||||||
|
#endif
|
||||||
|
#if CONFIG_EXTERN_HW
|
||||||
|
{"led", cmd_led},
|
||||||
|
{"tmp75", cmd_tmp75},
|
||||||
|
#endif
|
||||||
|
#if CONFIG_EXTERN_CLOUD
|
||||||
|
{"cloud", cmd_cloud},
|
||||||
|
{"reboot", cmd_reboot},
|
||||||
|
{"config", cmd_config},
|
||||||
|
#endif
|
||||||
|
#if CONFIG_TTCP
|
||||||
|
{"ttcp", cmd_ttcp},
|
||||||
|
#endif
|
||||||
|
{"", NULL}
|
||||||
|
};
|
1247
component/common/api/wifi_interactive_mode.c
Executable file
1247
component/common/api/wifi_interactive_mode.c
Executable file
File diff suppressed because it is too large
Load diff
66
component/common/application/apple/WACServer/External/Curve25519/rom_wac_curve25519-donna.h
vendored
Executable file
66
component/common/application/apple/WACServer/External/Curve25519/rom_wac_curve25519-donna.h
vendored
Executable file
|
@ -0,0 +1,66 @@
|
||||||
|
/*
|
||||||
|
File: curve25519-donna.h
|
||||||
|
Package: WACServer
|
||||||
|
Version: WACServer-1.14
|
||||||
|
|
||||||
|
Disclaimer: IMPORTANT: This Apple software is supplied to you, by Apple Inc. ("Apple"), in your
|
||||||
|
capacity as a current, and in good standing, Licensee in the MFi Licensing Program. Use of this
|
||||||
|
Apple software is governed by and subject to the terms and conditions of your MFi License,
|
||||||
|
including, but not limited to, the restrictions specified in the provision entitled ”Public
|
||||||
|
Software”, and is further subject to your agreement to the following additional terms, and your
|
||||||
|
agreement that the use, installation, modification or redistribution of this Apple software
|
||||||
|
constitutes acceptance of these additional terms. If you do not agree with these additional terms,
|
||||||
|
please do not use, install, modify or redistribute this Apple software.
|
||||||
|
|
||||||
|
Subject to all of these terms and in consideration of your agreement to abide by them, Apple grants
|
||||||
|
you, for as long as you are a current and in good-standing MFi Licensee, a personal, non-exclusive
|
||||||
|
license, under Apple's copyrights in this original Apple software (the "Apple Software"), to use,
|
||||||
|
reproduce, and modify the Apple Software in source form, and to use, reproduce, modify, and
|
||||||
|
redistribute the Apple Software, with or without modifications, in binary form. While you may not
|
||||||
|
redistribute the Apple Software in source form, should you redistribute the Apple Software in binary
|
||||||
|
form, you must retain this notice and the following text and disclaimers in all such redistributions
|
||||||
|
of the Apple Software. Neither the name, trademarks, service marks, or logos of Apple Inc. may be
|
||||||
|
used to endorse or promote products derived from the Apple Software without specific prior written
|
||||||
|
permission from Apple. Except as expressly stated in this notice, no other rights or licenses,
|
||||||
|
express or implied, are granted by Apple herein, including but not limited to any patent rights that
|
||||||
|
may be infringed by your derivative works or by other works in which the Apple Software may be
|
||||||
|
incorporated.
|
||||||
|
|
||||||
|
Unless you explicitly state otherwise, if you provide any ideas, suggestions, recommendations, bug
|
||||||
|
fixes or enhancements to Apple in connection with this software (“Feedback”), you hereby grant to
|
||||||
|
Apple a non-exclusive, fully paid-up, perpetual, irrevocable, worldwide license to make, use,
|
||||||
|
reproduce, incorporate, modify, display, perform, sell, make or have made derivative works of,
|
||||||
|
distribute (directly or indirectly) and sublicense, such Feedback in connection with Apple products
|
||||||
|
and services. Providing this Feedback is voluntary, but if you do provide Feedback to Apple, you
|
||||||
|
acknowledge and agree that Apple may exercise the license granted above without the payment of
|
||||||
|
royalties or further consideration to Participant.
|
||||||
|
|
||||||
|
The Apple Software is provided by Apple on an "AS IS" basis. APPLE MAKES NO WARRANTIES, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED WARRANTIES OF NON-INFRINGEMENT, MERCHANTABILITY
|
||||||
|
AND FITNESS FOR A PARTICULAR PURPOSE, REGARDING THE APPLE SOFTWARE OR ITS USE AND OPERATION ALONE OR
|
||||||
|
IN COMBINATION WITH YOUR PRODUCTS.
|
||||||
|
|
||||||
|
IN NO EVENT SHALL APPLE BE LIABLE FOR ANY SPECIAL, INDIRECT, INCIDENTAL OR CONSEQUENTIAL DAMAGES
|
||||||
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||||
|
PROFITS; OR BUSINESS INTERRUPTION) ARISING IN ANY WAY OUT OF THE USE, REPRODUCTION, MODIFICATION
|
||||||
|
AND/OR DISTRIBUTION OF THE APPLE SOFTWARE, HOWEVER CAUSED AND WHETHER UNDER THEORY OF CONTRACT, TORT
|
||||||
|
(INCLUDING NEGLIGENCE), STRICT LIABILITY OR OTHERWISE, EVEN IF APPLE HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
Copyright (C) 2009 Apple Inc. All Rights Reserved.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __curve25519_donnaDotH__
|
||||||
|
#define __curve25519_donnaDotH__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void curve25519_donna( unsigned char *outKey, const unsigned char *inSecret, const unsigned char *inBasePoint );
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // __curve25519_donnaDotH__
|
220
component/common/application/apple/WACServer/External/GladmanAES/rom_wac_aes.h
vendored
Executable file
220
component/common/application/apple/WACServer/External/GladmanAES/rom_wac_aes.h
vendored
Executable file
|
@ -0,0 +1,220 @@
|
||||||
|
/*
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
Copyright (c) 1998-2010, Brian Gladman, Worcester, UK. All rights reserved.
|
||||||
|
|
||||||
|
The redistribution and use of this software (with or without changes)
|
||||||
|
is allowed without the payment of fees or royalties provided that:
|
||||||
|
|
||||||
|
source code distributions include the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer;
|
||||||
|
|
||||||
|
binary distributions include the above copyright notice, this list
|
||||||
|
of conditions and the following disclaimer in their documentation.
|
||||||
|
|
||||||
|
This software is provided 'as is' with no explicit or implied warranties
|
||||||
|
in respect of its operation, including, but not limited to, correctness
|
||||||
|
and fitness for purpose.
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
Issue Date: 20/12/2007
|
||||||
|
|
||||||
|
This file contains the definitions required to use AES in C. See aesopt.h
|
||||||
|
for optimisation details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _AES_H
|
||||||
|
#define _AES_H
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
/* This include is used to find 8 & 32 bit unsigned integer types */
|
||||||
|
#include "rom_wac_brg_types.h"
|
||||||
|
|
||||||
|
/* Use AES encrypt/decrypt in wlan ROM codes */
|
||||||
|
#include "rom_aes.h"
|
||||||
|
extern int aes_set_key( aes_context *ctx, u8 *key, int nbits );
|
||||||
|
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define AES_128 /* if a fast 128 bit key scheduler is needed */
|
||||||
|
#define AES_192 /* if a fast 192 bit key scheduler is needed */
|
||||||
|
#define AES_256 /* if a fast 256 bit key scheduler is needed */
|
||||||
|
#define AES_VAR /* if variable key size scheduler is needed */
|
||||||
|
#define AES_MODES /* if support is needed for modes */
|
||||||
|
|
||||||
|
/* The following must also be set in assembler files if being used */
|
||||||
|
|
||||||
|
#define AES_ENCRYPT /* if support for encryption is needed */
|
||||||
|
#define AES_DECRYPT /* if support for decryption is needed */
|
||||||
|
#define AES_REV_DKS /* define to reverse decryption key schedule */
|
||||||
|
|
||||||
|
#define AES_BLOCK_SIZE 16 /* the AES block size in bytes */
|
||||||
|
#define N_COLS 4 /* the number of columns in the state */
|
||||||
|
|
||||||
|
/* The key schedule length is 11, 13 or 15 16-byte blocks for 128, */
|
||||||
|
/* 192 or 256-bit keys respectively. That is 176, 208 or 240 bytes */
|
||||||
|
/* or 44, 52 or 60 32-bit words. */
|
||||||
|
|
||||||
|
#if defined( AES_VAR ) || defined( AES_256 )
|
||||||
|
#define KS_LENGTH 60
|
||||||
|
#elif defined( AES_192 )
|
||||||
|
#define KS_LENGTH 52
|
||||||
|
#else
|
||||||
|
#define KS_LENGTH 44
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define AES_RETURN INT_RETURN
|
||||||
|
|
||||||
|
/* the character array 'inf' in the following structures is used */
|
||||||
|
/* to hold AES context information. This AES code uses cx->inf.b[0] */
|
||||||
|
/* to hold the number of rounds multiplied by 16. The other three */
|
||||||
|
/* elements can be used by code that implements additional modes */
|
||||||
|
|
||||||
|
typedef union
|
||||||
|
{ uint_32t l;
|
||||||
|
uint_8t b[4];
|
||||||
|
} aes_inf;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
uint_32t ks[KS_LENGTH];
|
||||||
|
#else
|
||||||
|
aes_context ctx;
|
||||||
|
#endif
|
||||||
|
aes_inf inf;
|
||||||
|
} aes_encrypt_ctx;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
uint_32t ks[KS_LENGTH];
|
||||||
|
#else
|
||||||
|
aes_context ctx;
|
||||||
|
#endif
|
||||||
|
aes_inf inf;
|
||||||
|
} aes_decrypt_ctx;
|
||||||
|
|
||||||
|
/* This routine must be called before first use if non-static */
|
||||||
|
/* tables are being used */
|
||||||
|
|
||||||
|
AES_RETURN aes_init(void);
|
||||||
|
|
||||||
|
/* Key lengths in the range 16 <= key_len <= 32 are given in bytes, */
|
||||||
|
/* those in the range 128 <= key_len <= 256 are given in bits */
|
||||||
|
|
||||||
|
#if defined( AES_ENCRYPT )
|
||||||
|
|
||||||
|
#if defined( AES_128 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_encrypt_key128(const unsigned char *key, aes_encrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_192 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_encrypt_key192(const unsigned char *key, aes_encrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_256 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_encrypt_key256(const unsigned char *key, aes_encrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_VAR )
|
||||||
|
AES_RETURN aes_encrypt_key(const unsigned char *key, int key_len, aes_encrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
AES_RETURN aes_encrypt(const unsigned char *in, unsigned char *out, const aes_encrypt_ctx cx[1]);
|
||||||
|
#else
|
||||||
|
extern void aes_encrypt( aes_context *ctx, u8 input[16], u8 output[16] );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_DECRYPT )
|
||||||
|
|
||||||
|
#if defined( AES_128 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_decrypt_key128(const unsigned char *key, aes_decrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_192 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_decrypt_key192(const unsigned char *key, aes_decrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_256 ) || defined( AES_VAR)
|
||||||
|
AES_RETURN aes_decrypt_key256(const unsigned char *key, aes_decrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_VAR )
|
||||||
|
AES_RETURN aes_decrypt_key(const unsigned char *key, int key_len, aes_decrypt_ctx cx[1]);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
AES_RETURN aes_decrypt(const unsigned char *in, unsigned char *out, const aes_decrypt_ctx cx[1]);
|
||||||
|
#else
|
||||||
|
extern void aes_decrypt( aes_context *ctx, u8 input[16], u8 output[16] );
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined( AES_MODES )
|
||||||
|
|
||||||
|
/* Multiple calls to the following subroutines for multiple block */
|
||||||
|
/* ECB, CBC, CFB, OFB and CTR mode encryption can be used to handle */
|
||||||
|
/* long messages incremantally provided that the context AND the iv */
|
||||||
|
/* are preserved between all such calls. For the ECB and CBC modes */
|
||||||
|
/* each individual call within a series of incremental calls must */
|
||||||
|
/* process only full blocks (i.e. len must be a multiple of 16) but */
|
||||||
|
/* the CFB, OFB and CTR mode calls can handle multiple incremental */
|
||||||
|
/* calls of any length. Each mode is reset when a new AES key is */
|
||||||
|
/* set but ECB and CBC operations can be reset without setting a */
|
||||||
|
/* new key by setting a new IV value. To reset CFB, OFB and CTR */
|
||||||
|
/* without setting the key, aes_mode_reset() must be called and the */
|
||||||
|
/* IV must be set. NOTE: All these calls update the IV on exit so */
|
||||||
|
/* this has to be reset if a new operation with the same IV as the */
|
||||||
|
/* previous one is required (or decryption follows encryption with */
|
||||||
|
/* the same IV array). */
|
||||||
|
|
||||||
|
AES_RETURN aes_test_alignment_detection(unsigned int n);
|
||||||
|
|
||||||
|
AES_RETURN aes_ecb_encrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, const aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_ecb_decrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, const aes_decrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_cbc_encrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *iv, const aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_cbc_decrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *iv, const aes_decrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_mode_reset(aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_cfb_encrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *iv, aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
AES_RETURN aes_cfb_decrypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *iv, aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
#define aes_ofb_encrypt aes_ofb_crypt
|
||||||
|
#define aes_ofb_decrypt aes_ofb_crypt
|
||||||
|
|
||||||
|
AES_RETURN aes_ofb_crypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *iv, aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
typedef void cbuf_inc(unsigned char *cbuf);
|
||||||
|
|
||||||
|
#define aes_ctr_encrypt aes_ctr_crypt
|
||||||
|
#define aes_ctr_decrypt aes_ctr_crypt
|
||||||
|
|
||||||
|
AES_RETURN aes_ctr_crypt(const unsigned char *ibuf, unsigned char *obuf,
|
||||||
|
int len, unsigned char *cbuf, cbuf_inc ctr_inc, aes_encrypt_ctx cx[1]);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
229
component/common/application/apple/WACServer/External/GladmanAES/rom_wac_brg_types.h
vendored
Executable file
229
component/common/application/apple/WACServer/External/GladmanAES/rom_wac_brg_types.h
vendored
Executable file
|
@ -0,0 +1,229 @@
|
||||||
|
/*
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
Copyright (c) 1998-2010, Brian Gladman, Worcester, UK. All rights reserved.
|
||||||
|
|
||||||
|
The redistribution and use of this software (with or without changes)
|
||||||
|
is allowed without the payment of fees or royalties provided that:
|
||||||
|
|
||||||
|
source code distributions include the above copyright notice, this
|
||||||
|
list of conditions and the following disclaimer;
|
||||||
|
|
||||||
|
binary distributions include the above copyright notice, this list
|
||||||
|
of conditions and the following disclaimer in their documentation.
|
||||||
|
|
||||||
|
This software is provided 'as is' with no explicit or implied warranties
|
||||||
|
in respect of its operation, including, but not limited to, correctness
|
||||||
|
and fitness for purpose.
|
||||||
|
---------------------------------------------------------------------------
|
||||||
|
Issue Date: 20/12/2007
|
||||||
|
|
||||||
|
The unsigned integer types defined here are of the form uint_<nn>t where
|
||||||
|
<nn> is the length of the type; for example, the unsigned 32-bit type is
|
||||||
|
'uint_32t'. These are NOT the same as the 'C99 integer types' that are
|
||||||
|
defined in the inttypes.h and stdint.h headers since attempts to use these
|
||||||
|
types have shown that support for them is still highly variable. However,
|
||||||
|
since the latter are of the form uint<nn>_t, a regular expression search
|
||||||
|
and replace (in VC++ search on 'uint_{:z}t' and replace with 'uint\1_t')
|
||||||
|
can be used to convert the types used here to the C99 standard types.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _BRG_TYPES_H
|
||||||
|
#define _BRG_TYPES_H
|
||||||
|
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <limits.h>
|
||||||
|
#if 0
|
||||||
|
#if defined( _MSC_VER ) && ( _MSC_VER >= 1300 )
|
||||||
|
# include <stddef.h>
|
||||||
|
# define ptrint_t intptr_t
|
||||||
|
#elif defined( __ECOS__ )
|
||||||
|
# define intptr_t unsigned int
|
||||||
|
# define ptrint_t intptr_t
|
||||||
|
#elif defined( __GNUC__ ) && ( __GNUC__ >= 3 )
|
||||||
|
# include <stdint.h>
|
||||||
|
# define ptrint_t intptr_t
|
||||||
|
#else
|
||||||
|
# define ptrint_t int
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
# include <stdint.h>
|
||||||
|
# define ptrint_t intptr_t
|
||||||
|
#ifndef u8
|
||||||
|
typedef uint8_t u8;
|
||||||
|
#endif
|
||||||
|
#ifndef u32
|
||||||
|
typedef uint32_t u32;
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef BRG_UI8
|
||||||
|
# define BRG_UI8
|
||||||
|
# if UCHAR_MAX == 255u
|
||||||
|
typedef unsigned char uint_8t;
|
||||||
|
# else
|
||||||
|
# error Please define uint_8t as an 8-bit unsigned integer type in brg_types.h
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef BRG_UI16
|
||||||
|
# define BRG_UI16
|
||||||
|
# if USHRT_MAX == 65535u
|
||||||
|
typedef unsigned short uint_16t;
|
||||||
|
# else
|
||||||
|
# error Please define uint_16t as a 16-bit unsigned short type in brg_types.h
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef BRG_UI32
|
||||||
|
# define BRG_UI32
|
||||||
|
# if UINT_MAX == 4294967295u
|
||||||
|
# define li_32(h) 0x##h##u
|
||||||
|
typedef unsigned int uint_32t;
|
||||||
|
# elif ULONG_MAX == 4294967295u
|
||||||
|
# define li_32(h) 0x##h##ul
|
||||||
|
typedef unsigned long uint_32t;
|
||||||
|
# elif defined( _CRAY )
|
||||||
|
# error This code needs 32-bit data types, which Cray machines do not provide
|
||||||
|
# else
|
||||||
|
# error Please define uint_32t as a 32-bit unsigned integer type in brg_types.h
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef BRG_UI64
|
||||||
|
# if defined( __BORLANDC__ ) && !defined( __MSDOS__ )
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ui64
|
||||||
|
typedef unsigned __int64 uint_64t;
|
||||||
|
# elif defined( _MSC_VER ) && ( _MSC_VER < 1300 ) /* 1300 == VC++ 7.0 */
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ui64
|
||||||
|
typedef unsigned __int64 uint_64t;
|
||||||
|
# elif defined( __sun ) && defined( ULONG_MAX ) && ULONG_MAX == 0xfffffffful
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ull
|
||||||
|
typedef unsigned long long uint_64t;
|
||||||
|
# elif defined( __MVS__ )
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ull
|
||||||
|
typedef unsigned int long long uint_64t;
|
||||||
|
# elif defined( UINT_MAX ) && UINT_MAX > 4294967295u
|
||||||
|
# if UINT_MAX == 18446744073709551615u
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##u
|
||||||
|
typedef unsigned int uint_64t;
|
||||||
|
# endif
|
||||||
|
# elif defined( ULONG_MAX ) && ULONG_MAX > 4294967295u
|
||||||
|
# if ULONG_MAX == 18446744073709551615ul
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ul
|
||||||
|
typedef unsigned long uint_64t;
|
||||||
|
# endif
|
||||||
|
# elif defined( ULLONG_MAX ) && ULLONG_MAX > 4294967295u
|
||||||
|
# if ULLONG_MAX == 18446744073709551615ull
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ull
|
||||||
|
typedef unsigned long long uint_64t;
|
||||||
|
# endif
|
||||||
|
# elif defined( ULONG_LONG_MAX ) && ULONG_LONG_MAX > 4294967295u
|
||||||
|
# if ULONG_LONG_MAX == 18446744073709551615ull
|
||||||
|
# define BRG_UI64
|
||||||
|
# define li_64(h) 0x##h##ull
|
||||||
|
typedef unsigned long long uint_64t;
|
||||||
|
# endif
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined( BRG_UI64 )
|
||||||
|
# if defined( NEED_UINT_64T )
|
||||||
|
# error Please define uint_64t as an unsigned 64 bit type in brg_types.h
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef RETURN_VALUES
|
||||||
|
# define RETURN_VALUES
|
||||||
|
# if defined( DLL_EXPORT )
|
||||||
|
# if defined( _MSC_VER ) || defined ( __INTEL_COMPILER )
|
||||||
|
# define VOID_RETURN __declspec( dllexport ) void __stdcall
|
||||||
|
# define INT_RETURN __declspec( dllexport ) int __stdcall
|
||||||
|
# elif defined( __GNUC__ )
|
||||||
|
# define VOID_RETURN __declspec( __dllexport__ ) void
|
||||||
|
# define INT_RETURN __declspec( __dllexport__ ) int
|
||||||
|
# else
|
||||||
|
# error Use of the DLL is only available on the Microsoft, Intel and GCC compilers
|
||||||
|
# endif
|
||||||
|
# elif defined( DLL_IMPORT )
|
||||||
|
# if defined( _MSC_VER ) || defined ( __INTEL_COMPILER )
|
||||||
|
# define VOID_RETURN __declspec( dllimport ) void __stdcall
|
||||||
|
# define INT_RETURN __declspec( dllimport ) int __stdcall
|
||||||
|
# elif defined( __GNUC__ )
|
||||||
|
# define VOID_RETURN __declspec( __dllimport__ ) void
|
||||||
|
# define INT_RETURN __declspec( __dllimport__ ) int
|
||||||
|
# else
|
||||||
|
# error Use of the DLL is only available on the Microsoft, Intel and GCC compilers
|
||||||
|
# endif
|
||||||
|
# elif defined( __WATCOMC__ )
|
||||||
|
# define VOID_RETURN void __cdecl
|
||||||
|
# define INT_RETURN int __cdecl
|
||||||
|
# else
|
||||||
|
# define VOID_RETURN void
|
||||||
|
# define INT_RETURN int
|
||||||
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* These defines are used to detect and set the memory alignment of pointers.
|
||||||
|
Note that offsets are in bytes.
|
||||||
|
|
||||||
|
ALIGN_OFFSET(x,n) return the positive or zero offset of
|
||||||
|
the memory addressed by the pointer 'x'
|
||||||
|
from an address that is aligned on an
|
||||||
|
'n' byte boundary ('n' is a power of 2)
|
||||||
|
|
||||||
|
ALIGN_FLOOR(x,n) return a pointer that points to memory
|
||||||
|
that is aligned on an 'n' byte boundary
|
||||||
|
and is not higher than the memory address
|
||||||
|
pointed to by 'x' ('n' is a power of 2)
|
||||||
|
|
||||||
|
ALIGN_CEIL(x,n) return a pointer that points to memory
|
||||||
|
that is aligned on an 'n' byte boundary
|
||||||
|
and is not lower than the memory address
|
||||||
|
pointed to by 'x' ('n' is a power of 2)
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define ALIGN_OFFSET(x,n) (((ptrint_t)(x)) & ((n) - 1))
|
||||||
|
#define ALIGN_FLOOR(x,n) ((uint_8t*)(x) - ( ((ptrint_t)(x)) & ((n) - 1)))
|
||||||
|
#define ALIGN_CEIL(x,n) ((uint_8t*)(x) + (-((ptrint_t)(x)) & ((n) - 1)))
|
||||||
|
|
||||||
|
/* These defines are used to declare buffers in a way that allows
|
||||||
|
faster operations on longer variables to be used. In all these
|
||||||
|
defines 'size' must be a power of 2 and >= 8. NOTE that the
|
||||||
|
buffer size is in bytes but the type length is in bits
|
||||||
|
|
||||||
|
UNIT_TYPEDEF(x,size) declares a variable 'x' of length
|
||||||
|
'size' bits
|
||||||
|
|
||||||
|
BUFR_TYPEDEF(x,size,bsize) declares a buffer 'x' of length 'bsize'
|
||||||
|
bytes defined as an array of variables
|
||||||
|
each of 'size' bits (bsize must be a
|
||||||
|
multiple of size / 8)
|
||||||
|
|
||||||
|
UNIT_CAST(x,size) casts a variable to a type of
|
||||||
|
length 'size' bits
|
||||||
|
|
||||||
|
UPTR_CAST(x,size) casts a pointer to a pointer to a
|
||||||
|
varaiable of length 'size' bits
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define UI_TYPE(size) uint_##size##t
|
||||||
|
#define UNIT_TYPEDEF(x,size) typedef UI_TYPE(size) x
|
||||||
|
#define BUFR_TYPEDEF(x,size,bsize) typedef UI_TYPE(size) x[bsize / (size >> 3)]
|
||||||
|
#define UNIT_CAST(x,size) ((UI_TYPE(size) )(x))
|
||||||
|
#define UPTR_CAST(x,size) ((UI_TYPE(size)*)(x))
|
||||||
|
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
23
component/common/application/google/google_nest.h
Executable file
23
component/common/application/google/google_nest.h
Executable file
|
@ -0,0 +1,23 @@
|
||||||
|
#ifndef GOOGLENEST_H
|
||||||
|
#define GOOGLENEST_H
|
||||||
|
|
||||||
|
#include <polarssl/ssl.h>
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
int socket;
|
||||||
|
char *host;
|
||||||
|
ssl_context ssl;
|
||||||
|
} googlenest_context;
|
||||||
|
|
||||||
|
int gn_connect(googlenest_context *googlenest, char *host, int port);
|
||||||
|
void gn_close(googlenest_context *googlenest);
|
||||||
|
int gn_put(googlenest_context *googlenest, char *uri, char *content);
|
||||||
|
int gn_patch(googlenest_context *googlenest, char *uri, char *content);
|
||||||
|
int gn_post(googlenest_context *googlenest, char *uri, char *content, unsigned char *out_buffer, size_t out_len);
|
||||||
|
int gn_get(googlenest_context *googlenest, char *uri, unsigned char *out_buffer, size_t out_len);
|
||||||
|
int gn_delete(googlenest_context *googlenest, char *uri);
|
||||||
|
int gn_stream(googlenest_context *googlenest, char *uri);
|
||||||
|
void google_retrieve_data_hook_callback(void (*callback)(char *));
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
2093
component/common/application/uart_adapter/uart_adapter.c
Executable file
2093
component/common/application/uart_adapter/uart_adapter.c
Executable file
File diff suppressed because it is too large
Load diff
251
component/common/application/uart_adapter/uart_adapter.h
Executable file
251
component/common/application/uart_adapter/uart_adapter.h
Executable file
|
@ -0,0 +1,251 @@
|
||||||
|
#include "osdep_api.h"
|
||||||
|
#include "serial_api.h"
|
||||||
|
#include <timer_api.h>
|
||||||
|
#include "freertos_pmu.h"
|
||||||
|
#include <mDNS/mDNS.h>
|
||||||
|
/******************************************************
|
||||||
|
* Macros
|
||||||
|
******************************************************/
|
||||||
|
#define UA_ERROR 0
|
||||||
|
#define UA_WARNING 1
|
||||||
|
#define UA_INFO 2
|
||||||
|
#define UA_DEBUG 3
|
||||||
|
#define UA_NONE 0xFF
|
||||||
|
#define UA_DEBUG_LEVEL UA_INFO
|
||||||
|
|
||||||
|
#define UA_UART_THREAD_PRIORITY 5
|
||||||
|
#define UA_UART_THREAD_STACKSIZE 512
|
||||||
|
|
||||||
|
#define UA_TCP_SERVER_FD_NUM 1
|
||||||
|
#define UA_TCP_CLIENT_FD_NUM 1
|
||||||
|
|
||||||
|
#define UA_UART_RECV_BUFFER_LEN 8196
|
||||||
|
#define UA_UART_FRAME_LEN 1400
|
||||||
|
#define UA_UART_MAX_DELAY_TIME 100
|
||||||
|
|
||||||
|
#define UA_CHAT_SOCKET_PORT 5001
|
||||||
|
#define UA_CONTROL_SOCKET_PORT 6001
|
||||||
|
|
||||||
|
#define UA_UART_TX_PIN PA_7
|
||||||
|
#define UA_UART_RX_PIN PA_6
|
||||||
|
|
||||||
|
#define UA_GPIO_LED_PIN PC_5
|
||||||
|
#define UA_GPIO_IRQ_PIN PC_4
|
||||||
|
|
||||||
|
#define UA_CONTROL_PREFIX "AMEBA_UART"
|
||||||
|
|
||||||
|
#define UA_PS_ENABLE 0
|
||||||
|
#define UA_GPIO_WAKEUP_PIN PC_3
|
||||||
|
#define UA_WAKELOCK WAKELOCK_USER_BASE
|
||||||
|
|
||||||
|
#if (UA_DEBUG_LEVEL== UA_NONE)
|
||||||
|
#define ua_printf(level, ...)
|
||||||
|
#else
|
||||||
|
#define ua_printf(level, ...) \
|
||||||
|
do {\
|
||||||
|
if (level <= UA_DEBUG_LEVEL) {\
|
||||||
|
if (level <= UA_ERROR) {\
|
||||||
|
printf("\r\nERROR: " __VA_ARGS__);\
|
||||||
|
} \
|
||||||
|
else {\
|
||||||
|
printf("\r\n" __VA_ARGS__);\
|
||||||
|
} \
|
||||||
|
}\
|
||||||
|
}while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define UA_PRINT_DATA(_HexData, _HexDataLen) \
|
||||||
|
if(UA_DEBUG_LEVEL == UA_DEBUG) \
|
||||||
|
{ \
|
||||||
|
int __i; \
|
||||||
|
u8 *ptr = (u8 *)_HexData; \
|
||||||
|
printf("--------Len=%d\n\r", _HexDataLen); \
|
||||||
|
for( __i=0; __i<(int)_HexDataLen; __i++ ) \
|
||||||
|
{ \
|
||||||
|
printf("%02X%s", ptr[__i], (((__i + 1) % 4) == 0)?" ":" "); \
|
||||||
|
if (((__i + 1) % 16) == 0) printf("\n\r"); \
|
||||||
|
} \
|
||||||
|
printf("\n\r"); \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define UA_SOCKET_CHECK(_ua_socket) \
|
||||||
|
if(_ua_socket == NULL) \
|
||||||
|
{ \
|
||||||
|
printf("ERROR: ua_socket = NULL\n\r"); \
|
||||||
|
return; \
|
||||||
|
}
|
||||||
|
|
||||||
|
#define UA_SOCKET_CHECK_2(_ua_socket) \
|
||||||
|
if(_ua_socket == NULL) \
|
||||||
|
{ \
|
||||||
|
printf("ERROR: ua_socket = NULL\n\r"); \
|
||||||
|
return -1; \
|
||||||
|
}
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Constants
|
||||||
|
******************************************************/
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
UART_ADAPTER_LED_ON = 0,
|
||||||
|
UART_ADAPTER_LED_OFF = 1,
|
||||||
|
UART_ADAPTER_LED_FAST_TWINKLE = 2,
|
||||||
|
UART_ADAPTER_LED_SLOW_TWINKLE = 3,
|
||||||
|
}ua_led_mode_t;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
UART_CTRL_MODE_SET_REQ = 0,
|
||||||
|
UART_CTRL_MODE_SET_RSP = 1,
|
||||||
|
UART_CTRL_MODE_GET_REQ = 2,
|
||||||
|
UART_CTRL_MODE_GET_RSP = 3,
|
||||||
|
}ua_ctrl_mode_t;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
UART_CTRL_TYPE_BAUD_RATE = 0x01,
|
||||||
|
UART_CTRL_TYPE_WORD_LEN = 0x02,
|
||||||
|
UART_CTRL_TYPE_PARITY = 0x04,
|
||||||
|
UART_CTRL_TYPE_STOP_BIT = 0x08,
|
||||||
|
UART_CTRL_TYPE_TCP_SERVER_CREATE = 0x10,
|
||||||
|
UART_CTRL_TYPE_TCP_SERVER_DELETE = 0x20,
|
||||||
|
UART_CTRL_TYPE_TCP_CLIENT_CONNECT = 0x40,
|
||||||
|
UART_CTRL_TYPE_TCP_CLIENT_DISCONNECT = 0x80,
|
||||||
|
UART_CTRL_TYPE_TCP_GROUP_ID = 0x100,
|
||||||
|
}ua_ctrl_type_t;
|
||||||
|
|
||||||
|
enum sc_result {
|
||||||
|
SC_ERROR = -1, /* default error code*/
|
||||||
|
SC_NO_CONTROLLER_FOUND = 1, /* cannot get sta(controller) in the air which starts a simple config session */
|
||||||
|
SC_CONTROLLER_INFO_PARSE_FAIL, /* cannot parse the sta's info */
|
||||||
|
SC_TARGET_CHANNEL_SCAN_FAIL, /* cannot scan the target channel */
|
||||||
|
SC_JOIN_BSS_FAIL, /* fail to connect to target ap */
|
||||||
|
SC_DHCP_FAIL, /* fail to get ip address from target ap */
|
||||||
|
/* fail to create udp socket to send info to controller. note that client isolation
|
||||||
|
must be turned off in ap. we cannot know if ap has configured this */
|
||||||
|
SC_UDP_SOCKET_CREATE_FAIL,
|
||||||
|
SC_SUCCESS, /* default success code */
|
||||||
|
};
|
||||||
|
|
||||||
|
/******************************************************
|
||||||
|
* Structures
|
||||||
|
******************************************************/
|
||||||
|
typedef struct _ua_uart_param_t
|
||||||
|
{
|
||||||
|
u8 WordLen;
|
||||||
|
u8 Parity;
|
||||||
|
u8 StopBit;
|
||||||
|
u8 FlowControl;
|
||||||
|
int BaudRate;
|
||||||
|
}ua_uart_param_t;
|
||||||
|
|
||||||
|
typedef struct _ua_uart_socket_t
|
||||||
|
{
|
||||||
|
int fd;
|
||||||
|
char rcv_ch;
|
||||||
|
volatile char overlap;
|
||||||
|
int recv_bytes;
|
||||||
|
volatile int pread;
|
||||||
|
volatile int pwrite;
|
||||||
|
|
||||||
|
volatile unsigned int tick_last_update;
|
||||||
|
unsigned int tick_current;
|
||||||
|
|
||||||
|
volatile int tx_busy;
|
||||||
|
|
||||||
|
volatile int uart_ps;
|
||||||
|
volatile int uart_ps_cnt;
|
||||||
|
|
||||||
|
char recv_buf[UA_UART_RECV_BUFFER_LEN];
|
||||||
|
|
||||||
|
long rx_cnt;
|
||||||
|
long miss_cnt;
|
||||||
|
|
||||||
|
serial_t uart_sobj;
|
||||||
|
ua_uart_param_t uart_param;
|
||||||
|
|
||||||
|
_Sema action_sema;
|
||||||
|
_Sema dma_tx;
|
||||||
|
}ua_uart_socket_t;
|
||||||
|
|
||||||
|
typedef struct _ua_tcp_socket_t
|
||||||
|
{
|
||||||
|
int chat_socket;
|
||||||
|
int control_socket;
|
||||||
|
int chat_server_listen_socket;
|
||||||
|
int control_server_listen_socket;
|
||||||
|
|
||||||
|
int transmit_recv_socket;
|
||||||
|
int transmit_send_socket;
|
||||||
|
int transmit_server_listen_socket;
|
||||||
|
|
||||||
|
int group_id;
|
||||||
|
|
||||||
|
int send_flag;
|
||||||
|
int recv_flag;
|
||||||
|
long rx_cnt;
|
||||||
|
long tx_cnt;
|
||||||
|
|
||||||
|
volatile int tcp_ps;
|
||||||
|
volatile int tcp_ps_cnt;
|
||||||
|
}ua_tcp_socket_t;
|
||||||
|
|
||||||
|
typedef struct _ua_gpio_t
|
||||||
|
{
|
||||||
|
gpio_t gpio_led;
|
||||||
|
gpio_t gpio_btn;
|
||||||
|
gpio_irq_t gpio_btn_irq;
|
||||||
|
gtimer_t gpio_timer;
|
||||||
|
}ua_gpio_t;
|
||||||
|
|
||||||
|
typedef struct _ua_socket_t
|
||||||
|
{
|
||||||
|
ua_uart_socket_t uart;
|
||||||
|
ua_tcp_socket_t tcp;
|
||||||
|
ua_gpio_t gpio;
|
||||||
|
ip_addr_t ip;
|
||||||
|
DNSServiceRef dnsServiceRef;
|
||||||
|
DNSServiceRef dnsServiceRef2;
|
||||||
|
}ua_socket_t;
|
||||||
|
|
||||||
|
typedef struct _ua_mbox_buffer
|
||||||
|
{
|
||||||
|
char data[UA_UART_FRAME_LEN];
|
||||||
|
int data_len;
|
||||||
|
}ua_mbox_buffer_t;
|
||||||
|
|
||||||
|
//Save Uart Settings when get uart information
|
||||||
|
typedef struct _ua_uart_get_str
|
||||||
|
{
|
||||||
|
int BaudRate; //The baud rate
|
||||||
|
char number; //The number of data bits
|
||||||
|
char parity; //The parity(0: none, 1:odd, 2:evn, default:0)
|
||||||
|
char StopBits; //The number of stop bits
|
||||||
|
char FlowControl; //support flow control is 1
|
||||||
|
}ua_uart_get_str;
|
||||||
|
|
||||||
|
//Uart Setting information
|
||||||
|
typedef struct _ua_uart_set_str
|
||||||
|
{
|
||||||
|
char UartName[8]; // the name of uart
|
||||||
|
int BaudRate; //The baud rate
|
||||||
|
char number; //The number of data bits
|
||||||
|
char parity; //The parity(default NONE)
|
||||||
|
char StopBits; //The number of stop bits
|
||||||
|
char FlowControl; //support flow control is 1
|
||||||
|
}ua_uart_set_str;
|
||||||
|
|
||||||
|
|
||||||
|
int uartadapter_init();
|
||||||
|
void uartadapter_tcp_send_data(ua_socket_t *ua_socket, char *buffer, int size);
|
||||||
|
void uartadapter_tcp_send_control(ua_socket_t *ua_socket, char *buffer, int size);
|
||||||
|
void uartadapter_tcp_transmit_server_thread(void *param);
|
||||||
|
void uartadapter_tcp_transmit_client_thread(void *param);
|
||||||
|
int uartadapter_tcpclient(ua_socket_t *ua_socket, const char *host_ip, unsigned short usPort);
|
||||||
|
|
||||||
|
|
||||||
|
void example_uart_adapter_init();
|
||||||
|
void cmd_uart_adapter(int argc, char **argv);
|
||||||
|
|
||||||
|
void uartadapter_tcp_transmit_socket_handler(ua_socket_t *ua_socket, char *tcp_rxbuf);
|
||||||
|
|
82
component/common/application/wigadget/cloud_link.c
Executable file
82
component/common/application/wigadget/cloud_link.c
Executable file
|
@ -0,0 +1,82 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#include "wifi_ind.h"
|
||||||
|
#include "google_nest.h"
|
||||||
|
#include "flash_api.h"
|
||||||
|
#include "wigadget.h"
|
||||||
|
#include <lwip/netif.h>
|
||||||
|
#include "shtc1.h"
|
||||||
|
|
||||||
|
#define CLOUD_PORT 443
|
||||||
|
extern struct netif xnetif[NET_IF_NUM];
|
||||||
|
|
||||||
|
void cloud_link_task(void *param){
|
||||||
|
googlenest_context googlenest;
|
||||||
|
unsigned char URI[64];
|
||||||
|
unsigned char data[97] = NULL;
|
||||||
|
unsigned char host_addr[64] = NULL;
|
||||||
|
flash_t cloud_flash;
|
||||||
|
u8 *mac = (u8 *)LwIP_GetMAC(&xnetif[0]);
|
||||||
|
char i[16], j[16];
|
||||||
|
float temperature = 1.123f;
|
||||||
|
float humidity = 2.456f;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
vTaskDelay(2000);
|
||||||
|
|
||||||
|
|
||||||
|
sprintf(URI, "ht_sensor/%02x%02x%02x%02x%02x%02x.json", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
|
||||||
|
|
||||||
|
memset(host_addr, 0, sizeof(host_addr));
|
||||||
|
if(flash_stream_read(&cloud_flash, FLASH_IOT_DATA, 97, (uint8_t *) data) == 1){
|
||||||
|
|
||||||
|
memset(host_addr, 0 , 64);
|
||||||
|
memcpy(host_addr, data+33, 64);
|
||||||
|
while(1) {
|
||||||
|
printf("\r\n\r\n\r\n\r\n\r\n\r\n=====>START CLOUD LINKING\r\n\r\n");
|
||||||
|
memset(i, 0, 16);
|
||||||
|
memset(j, 0, 16);
|
||||||
|
#if PSEUDO_DATA
|
||||||
|
sprintf(i,"%.2f", temperature++);
|
||||||
|
sprintf(j, "%.2f", humidity++);
|
||||||
|
if(temperature > 60)
|
||||||
|
temperature = 1.123f;
|
||||||
|
if(humidity > 98)
|
||||||
|
humidity = 2.456f;
|
||||||
|
#else
|
||||||
|
ret = SHTC_GetTempAndHumi(&temperature, &humidity);
|
||||||
|
sprintf(i,"%.2f", temperature);
|
||||||
|
sprintf(j, "%.2f", humidity);
|
||||||
|
#endif
|
||||||
|
if(ret < 0)
|
||||||
|
printf("\r\n\r\n<-----LOCAL LINK FAILED!!(get infor failed)\r\n\r\n");
|
||||||
|
else{
|
||||||
|
gen_json_data(i,j, data);
|
||||||
|
printf("\r\nCLOUD-LINK--Sending data : \r\n%s\r\n", data);
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, host_addr, CLOUD_PORT) == 0) {
|
||||||
|
if(gn_put(&googlenest, URI, data) != 0)
|
||||||
|
printf("\r\n\r\nPUT data failed!\r\n\r\n");
|
||||||
|
gn_close(&googlenest);
|
||||||
|
printf("\r\n\r\n<=====CLOUD LINK OK!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
printf("\r\n\r\n<=====CLOUD LINK FAILED!!(google nest connecting)\r\n\r\n");
|
||||||
|
}
|
||||||
|
free(data);
|
||||||
|
vTaskDelay(10000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\r\n\r\n<=====CLOUD LINK FAILED!!(flash reading)\r\n\r\n");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void start_cloud_link(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(cloud_link_task, ((const char*)"cloud_link_task"), 3584, NULL, tskIDLE_PRIORITY + 4, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate failed", __FUNCTION__);
|
||||||
|
}
|
11
component/common/application/wigadget/cloud_link.h
Executable file
11
component/common/application/wigadget/cloud_link.h
Executable file
|
@ -0,0 +1,11 @@
|
||||||
|
#ifndef CLOUD_LINK_H
|
||||||
|
#define CLOUD_LINK_THREAD_H
|
||||||
|
|
||||||
|
#include "wigadget.h"
|
||||||
|
|
||||||
|
void start_cloud_link(void);
|
||||||
|
void cloud_link_task(void *param);
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
185
component/common/application/wigadget/shtc1.c
Executable file
185
component/common/application/wigadget/shtc1.c
Executable file
|
@ -0,0 +1,185 @@
|
||||||
|
#include "device.h"
|
||||||
|
#include "PinNames.h"
|
||||||
|
#include "basic_types.h"
|
||||||
|
#include "diag.h"
|
||||||
|
#include "osdep_api.h"
|
||||||
|
#include "i2c_api.h"
|
||||||
|
#include "pinmap.h"
|
||||||
|
#include "shtc1.h"
|
||||||
|
|
||||||
|
#define MBED_I2C_MTR_SDA PB_3
|
||||||
|
#define MBED_I2C_MTR_SCL PB_2
|
||||||
|
|
||||||
|
#define MBED_I2C_SLAVE_ADDR0 0x70
|
||||||
|
#define POLYNOMIAL 0x131 // P(x) = x^8 + x^5 + x^4 + 1 = 100110001
|
||||||
|
|
||||||
|
#define MBED_I2C_BUS_CLK 100000 //hz
|
||||||
|
#define I2C_DATA_MAX_LENGTH 16
|
||||||
|
|
||||||
|
static uint8_t i2cdata_write[I2C_DATA_MAX_LENGTH];
|
||||||
|
static uint8_t i2cdata_read[I2C_DATA_MAX_LENGTH];
|
||||||
|
static int i2cdata_read_pos;
|
||||||
|
|
||||||
|
static i2c_t i2cmaster;
|
||||||
|
|
||||||
|
// Sensor Commands
|
||||||
|
#define READ_ID 0xEFC8 // command: read ID register
|
||||||
|
#define SOFT_RESET 0x805D // soft resetSample Code for SHTC1
|
||||||
|
#define MEAS_T_RH_POLLING 0x7866 // meas. read T first, clock stretching disabled
|
||||||
|
#define MEAS_T_RH_CLOCKSTR 0x7CA2 // meas. read T first, clock stretching enabled
|
||||||
|
#define MEAS_RH_T_POLLING 0x58E0 // meas. read RH first, clock stretching disabled
|
||||||
|
#define MEAS_RH_T_CLOCKSTR 0x5C24 // meas. read RH first, clock stretching enabled
|
||||||
|
|
||||||
|
|
||||||
|
static int SHTC1_GetID(uint16_t *id);
|
||||||
|
static void SHTC1_WriteCommand(uint16_t cmd);
|
||||||
|
static int SHTC1_Read2BytesAndCrc(uint16_t *data);
|
||||||
|
static int SHTC1_CheckCrc(uint8_t data[], uint8_t nbrOfBytes, uint8_t checksum);
|
||||||
|
static float SHTC1_CalcTemperature(uint16_t rawValue);
|
||||||
|
static float SHTC1_CalcHumidity(uint16_t rawValue);
|
||||||
|
|
||||||
|
|
||||||
|
int SHTC_Init(uint16_t *pID)
|
||||||
|
{
|
||||||
|
int error = NO_ERROR;
|
||||||
|
|
||||||
|
DiagPrintf("SHTC1_Init \r\n");
|
||||||
|
|
||||||
|
i2c_init((i2c_t*)&i2cmaster, MBED_I2C_MTR_SDA ,MBED_I2C_MTR_SCL);
|
||||||
|
i2c_frequency((i2c_t*)&i2cmaster,MBED_I2C_BUS_CLK);
|
||||||
|
|
||||||
|
if (pID == NULL )
|
||||||
|
return NULL_ERROR;
|
||||||
|
error = SHTC1_GetID(pID);
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int SHTC1_GetID(uint16_t *id)
|
||||||
|
{
|
||||||
|
int error = NO_ERROR;
|
||||||
|
uint8_t bytes[2];
|
||||||
|
uint8_t checksum;
|
||||||
|
|
||||||
|
SHTC1_WriteCommand(READ_ID);
|
||||||
|
|
||||||
|
i2c_read((i2c_t*)&i2cmaster, MBED_I2C_SLAVE_ADDR0, (char*)&i2cdata_read[0], 3, 1);
|
||||||
|
i2cdata_read_pos = 0;
|
||||||
|
error = SHTC1_Read2BytesAndCrc(id);
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int SHTC1_Read2BytesAndCrc(uint16_t *data)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
int readed;
|
||||||
|
uint8_t bytes[2];
|
||||||
|
uint8_t checksum;
|
||||||
|
|
||||||
|
bytes[0] = i2cdata_read[i2cdata_read_pos++];
|
||||||
|
bytes[1] = i2cdata_read[i2cdata_read_pos++];
|
||||||
|
checksum = i2cdata_read[i2cdata_read_pos++];
|
||||||
|
|
||||||
|
error = SHTC1_CheckCrc(bytes, 2, checksum);
|
||||||
|
*data = (bytes[0] << 8) | bytes[1];
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int SHTC1_CheckCrc(uint8_t data[], uint8_t nbrOfBytes, uint8_t checksum)
|
||||||
|
{
|
||||||
|
uint8_t bit; // bit mask
|
||||||
|
uint8_t crc = 0xFF; // calculated checksum
|
||||||
|
uint8_t byteCtr; // byte counter
|
||||||
|
|
||||||
|
for(byteCtr = 0; byteCtr < nbrOfBytes; byteCtr++){
|
||||||
|
crc ^= (data[byteCtr]);
|
||||||
|
for(bit = 8; bit > 0; --bit){
|
||||||
|
if(crc & 0x80)
|
||||||
|
crc = (crc << 1) ^ POLYNOMIAL;
|
||||||
|
else
|
||||||
|
crc = (crc << 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(crc != checksum)
|
||||||
|
return CHECKSUM_ERROR;
|
||||||
|
else
|
||||||
|
return NO_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void SHTC1_WriteCommand(uint16_t cmd)
|
||||||
|
{
|
||||||
|
int writebytes;
|
||||||
|
|
||||||
|
i2cdata_write[0] = (uint8_t)(cmd >>8);
|
||||||
|
i2cdata_write[1] = (uint8_t)(cmd&0xFF);
|
||||||
|
i2c_write((i2c_t*)&i2cmaster, MBED_I2C_SLAVE_ADDR0, &i2cdata_write[0], 2, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static float SHTC1_CalcTemperature(uint16_t rawValue)
|
||||||
|
{
|
||||||
|
return 175.0 * (float)rawValue / 65536.0 - 45.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static float SHTC1_CalcHumidity(uint16_t rawValue)
|
||||||
|
{
|
||||||
|
return 100.0 * (float)rawValue / 65536.0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int SHTC_GetTempAndHumi(float *temp, float *humi)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
uint16_t rawValueTemp;
|
||||||
|
uint16_t rawValueHumi;
|
||||||
|
|
||||||
|
SHTC1_WriteCommand(MEAS_T_RH_CLOCKSTR);
|
||||||
|
|
||||||
|
i2c_read((i2c_t*)&i2cmaster, MBED_I2C_SLAVE_ADDR0, (char*)&i2cdata_read[0], 6, 1);
|
||||||
|
i2cdata_read_pos = 0;
|
||||||
|
error = NO_ERROR;
|
||||||
|
error |= SHTC1_Read2BytesAndCrc(&rawValueTemp);
|
||||||
|
error |= SHTC1_Read2BytesAndCrc(&rawValueHumi);
|
||||||
|
|
||||||
|
if ( error == NO_ERROR ) {
|
||||||
|
*temp = SHTC1_CalcTemperature(rawValueTemp);
|
||||||
|
*humi = SHTC1_CalcHumidity(rawValueHumi);
|
||||||
|
}
|
||||||
|
|
||||||
|
return error;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void example_shtc1_thread(void *param)
|
||||||
|
{
|
||||||
|
int error;
|
||||||
|
uint16_t shtc1_id;
|
||||||
|
float temperature = 1.123f;
|
||||||
|
float humidity = 2.456f;
|
||||||
|
|
||||||
|
DBG_8195A("sleep 10 sec. to wait for UART console\n");
|
||||||
|
RtlMsleepOS(10000);
|
||||||
|
DBG_8195A("start i2c example - SHTC1\n");
|
||||||
|
|
||||||
|
error = SHTC_Init(&shtc1_id);
|
||||||
|
if ( error == NO_ERROR )
|
||||||
|
DiagPrintf("SHTC1 init ok, id=0x%x\r\n", shtc1_id);
|
||||||
|
else {
|
||||||
|
DiagPrintf("SHTC1 init FAILED! \r\n");
|
||||||
|
for(;;);
|
||||||
|
}
|
||||||
|
|
||||||
|
while(1){
|
||||||
|
error = SHTC_GetTempAndHumi(&temperature, &humidity);
|
||||||
|
rtl_printf("temp=%f, humidity=%f, error=%d\n", temperature, humidity, error);
|
||||||
|
RtlMsleepOS(1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_shtc1(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(example_shtc1_thread, ((const char*)"example_shtc1_thread"), 512, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate(init_thread) failed", __FUNCTION__);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
13
component/common/application/wigadget/shtc1.h
Executable file
13
component/common/application/wigadget/shtc1.h
Executable file
|
@ -0,0 +1,13 @@
|
||||||
|
#ifndef SHTC1_H
|
||||||
|
#define SHTC1_H
|
||||||
|
|
||||||
|
#define NO_ERROR 0x00
|
||||||
|
#define ACK_ERROR 0x01
|
||||||
|
#define CHECKSUM_ERROR 0x02
|
||||||
|
#define NULL_ERROR 0x03
|
||||||
|
|
||||||
|
int SHTC_GetTempAndHumi(float *temp, float *humi);
|
||||||
|
int SHTC_Init(uint16_t *pID);
|
||||||
|
void example_shtc1(void);
|
||||||
|
|
||||||
|
#endif
|
727
component/common/application/wigadget/wigadget.c
Executable file
727
component/common/application/wigadget/wigadget.c
Executable file
|
@ -0,0 +1,727 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#include "wifi_ind.h"
|
||||||
|
#include "sockets.h"
|
||||||
|
#include <mDNS/mDNS.h>
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <lwip/netif.h>
|
||||||
|
#include "flash_api.h"
|
||||||
|
#include <rom_wac_aes.h>
|
||||||
|
#include "rom_wac_curve25519-donna.h"
|
||||||
|
#include "gpio_api.h"
|
||||||
|
#include "gpio_irq_api.h"
|
||||||
|
#include "cJSON.h"
|
||||||
|
#include "cloud_link.h"
|
||||||
|
#include "wigadget.h"
|
||||||
|
#include "shtc1.h"
|
||||||
|
|
||||||
|
#define PORT 6866
|
||||||
|
#define MAX_BUFFER_SIZE 256
|
||||||
|
#define ENC_SIZE 64
|
||||||
|
#define CONTROL_TYPE 1
|
||||||
|
#define GPIO_SOFTAP_RESET_PIN PC_4
|
||||||
|
|
||||||
|
flash_t iot_flash;
|
||||||
|
uint8_t aes_key[16];
|
||||||
|
static unsigned char tx_buffer[MAX_BUFFER_SIZE];
|
||||||
|
static unsigned char rx_buffer[MAX_BUFFER_SIZE];
|
||||||
|
|
||||||
|
extern struct netif xnetif[NET_IF_NUM];
|
||||||
|
|
||||||
|
#define DEBUG_IOT 1
|
||||||
|
|
||||||
|
#define IOT_LOG(level, fmt, ...) printf("\n\r[IOT %s] %s: " fmt "\n", level, __FUNCTION__, ##__VA_ARGS__)
|
||||||
|
#if DEBUG_IOT == 2
|
||||||
|
#define IOT_DEBUG(fmt, ...) IOT_LOG("DEBUG", fmt, ##__VA_ARGS__)
|
||||||
|
#else
|
||||||
|
#define IOT_DEBUG(fmt, ...)
|
||||||
|
#endif
|
||||||
|
#if DEBUG_IOT
|
||||||
|
#define IOT_ERROR(fmt, ...) IOT_LOG("ERROR", fmt, ##__VA_ARGS__)
|
||||||
|
#else
|
||||||
|
#define IOT_ERROR(fmt, ...)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void encrypt_data_aes(unsigned char *plaint_text, unsigned char *enc_data);
|
||||||
|
void decrypt_data_aes(unsigned char *enc_data, unsigned char *dec_data, int data_len);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
static unsigned int arc4random(void)
|
||||||
|
{
|
||||||
|
unsigned int res = xTaskGetTickCount();
|
||||||
|
static unsigned int seed = 0xDEADB00B;
|
||||||
|
|
||||||
|
seed = ((seed & 0x007F00FF) << 7) ^
|
||||||
|
((seed & 0x0F80FF00) >> 8) ^ // be sure to stir those low bits
|
||||||
|
(res << 13) ^ (res >> 9); // using the clock too!
|
||||||
|
return seed;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static char *iot_itoa(int value)
|
||||||
|
{
|
||||||
|
char *val_str;
|
||||||
|
int tmp = value, len = 1;
|
||||||
|
|
||||||
|
while((tmp /= 10) > 0)
|
||||||
|
len ++;
|
||||||
|
|
||||||
|
val_str = (char *) malloc(len + 1);
|
||||||
|
sprintf(val_str, "%d", value);
|
||||||
|
|
||||||
|
return val_str;
|
||||||
|
}
|
||||||
|
|
||||||
|
void gen_json_data(char *i, char *j, unsigned char *json_data)
|
||||||
|
{
|
||||||
|
cJSON_Hooks memoryHook;
|
||||||
|
|
||||||
|
memoryHook.malloc_fn = malloc;
|
||||||
|
memoryHook.free_fn = free;
|
||||||
|
cJSON_InitHooks(&memoryHook);
|
||||||
|
memset(json_data, 0, ENC_SIZE);
|
||||||
|
|
||||||
|
|
||||||
|
cJSON *IOTJSObject = NULL;
|
||||||
|
char *data;
|
||||||
|
|
||||||
|
|
||||||
|
if((IOTJSObject = cJSON_CreateObject()) != NULL) {
|
||||||
|
|
||||||
|
cJSON_AddItemToObject(IOTJSObject, "TEM", cJSON_CreateString(i));
|
||||||
|
cJSON_AddItemToObject(IOTJSObject, "HUM", cJSON_CreateString(j));
|
||||||
|
|
||||||
|
data = cJSON_Print(IOTJSObject);
|
||||||
|
memcpy(json_data, data, strlen(data));
|
||||||
|
cJSON_Delete(IOTJSObject);
|
||||||
|
free(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void encrypt_data_aes(unsigned char *plaint_text, unsigned char *enc_data)
|
||||||
|
{
|
||||||
|
unsigned char iv[16] = NULL;
|
||||||
|
unsigned char* iv_bak = "AAAAAAAAAAAAAAAA";
|
||||||
|
aes_encrypt_ctx enc_ctx;
|
||||||
|
|
||||||
|
memset(&enc_ctx, 0, sizeof(enc_ctx));
|
||||||
|
memset(iv, 0, sizeof(iv));
|
||||||
|
memcpy(iv, iv_bak, sizeof(iv));
|
||||||
|
memset(enc_data, 0, sizeof(enc_data));
|
||||||
|
|
||||||
|
aes_init();
|
||||||
|
aes_encrypt_key(aes_key, 16, &enc_ctx);
|
||||||
|
aes_cbc_encrypt(plaint_text, enc_data, ENC_SIZE, iv, &enc_ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void decrypt_data_aes(unsigned char *enc_data, unsigned char *dec_data, int data_len)
|
||||||
|
{
|
||||||
|
unsigned char iv[16] = NULL;
|
||||||
|
unsigned char* iv_bak = "AAAAAAAAAAAAAAAA";
|
||||||
|
aes_decrypt_ctx dec_ctx;
|
||||||
|
|
||||||
|
memset(&dec_ctx, 0, sizeof(dec_ctx));
|
||||||
|
memset(iv, 0, sizeof(iv));
|
||||||
|
memcpy(iv, iv_bak, sizeof(iv));
|
||||||
|
memset(dec_data, 0, sizeof(dec_data));
|
||||||
|
|
||||||
|
aes_init();
|
||||||
|
aes_decrypt_key(aes_key, 16, &dec_ctx);
|
||||||
|
aes_cbc_decrypt(enc_data, dec_data, data_len, iv, &dec_ctx);
|
||||||
|
IOT_DEBUG("Decrypt data: %s\r\n",dec_data);
|
||||||
|
}
|
||||||
|
|
||||||
|
void iotapp_platform_reset(void)
|
||||||
|
{
|
||||||
|
HAL_WRITE32(SYSTEM_CTRL_BASE, 0x14, 0x00000021);
|
||||||
|
osDelay(100);
|
||||||
|
HAL_WRITE32(0xE000ED00, 0x0C, (0x5FA << 16) |
|
||||||
|
(HAL_READ32(0xE000ED00, 0x0C) & (7 << 8)) |
|
||||||
|
(1 << 2));
|
||||||
|
while(1) osDelay(1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
void iotapp_reset_irq_handler(uint32_t id, gpio_irq_event event)
|
||||||
|
{
|
||||||
|
printf("\n\r\n\r\n\r\n\r<<<<<<Reset the device using PC_4>>>>>>>\n\r\n\r\n\r\n\r");
|
||||||
|
flash_erase_sector(&iot_flash, FLASH_IOT_DATA);
|
||||||
|
iotapp_platform_reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
int local_link(unsigned char *tx_data)
|
||||||
|
{
|
||||||
|
int sockfd, newsockfd;
|
||||||
|
socklen_t client;
|
||||||
|
struct sockaddr_in serv_addr, cli_addr;
|
||||||
|
uint8_t rx_data[ENC_SIZE];
|
||||||
|
unsigned char enc_data[ENC_SIZE];
|
||||||
|
unsigned char dec_data[ENC_SIZE];
|
||||||
|
int ret = 0, opt = 1, k = 1, j;
|
||||||
|
char *result = NULL, *backup = NULL;
|
||||||
|
unsigned char *data = NULL;
|
||||||
|
char *delims = ", ";
|
||||||
|
|
||||||
|
sockfd = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
|
if (sockfd < 0) {
|
||||||
|
IOT_ERROR("ERROR opening socket");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (const char *)&opt, sizeof(opt))) < 0){
|
||||||
|
IOT_ERROR("ERROR on setting socket option");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
|
||||||
|
memset((char *)&serv_addr, 0, sizeof(serv_addr));
|
||||||
|
serv_addr.sin_family = AF_INET;
|
||||||
|
serv_addr.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
serv_addr.sin_port = htons(PORT);
|
||||||
|
|
||||||
|
if (bind(sockfd, (struct sockaddr *)&serv_addr,sizeof(serv_addr)) < 0) {
|
||||||
|
IOT_ERROR("ERROR on binding");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
if(listen(sockfd , 20) < 0){
|
||||||
|
IOT_ERROR("ERROR on listening");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
client = sizeof(cli_addr);
|
||||||
|
if((newsockfd = accept(sockfd,(struct sockaddr *) &cli_addr,&client)) < 0){
|
||||||
|
IOT_ERROR("ERROR on accept");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
if ((ret = read(newsockfd,rx_buffer,sizeof(rx_buffer))) < 0){
|
||||||
|
IOT_ERROR("ERROR reading from socket");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
IOT_DEBUG("cmd received: %s, length: %d\r\n",rx_buffer, ret);
|
||||||
|
|
||||||
|
//Changing received data to string
|
||||||
|
if (!strncmp(rx_buffer, "[", strlen("["))){
|
||||||
|
data = rx_buffer + strlen("[");
|
||||||
|
for(j = 1; j < 5; j++){
|
||||||
|
if (data[ret - j] == ']')
|
||||||
|
data[ret -j] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
strcpy(data, rx_buffer);
|
||||||
|
memset(rx_data, 0, sizeof(rx_data));
|
||||||
|
result = strtok_r(data, delims, &backup);
|
||||||
|
rx_data[0]=(uint8_t)atoi(result);
|
||||||
|
while((result = strtok_r(NULL, delims, &backup)) != NULL)
|
||||||
|
rx_data[k++]=(uint8_t)atoi(result);
|
||||||
|
memset(dec_data, 0, sizeof(dec_data));
|
||||||
|
|
||||||
|
//Decrpyt the received data
|
||||||
|
decrypt_data_aes(rx_data, dec_data, 16);
|
||||||
|
|
||||||
|
if(strncmp(dec_data, "request", strlen("request")) == 0){
|
||||||
|
//Encrypt the sending data
|
||||||
|
memset(enc_data, 0, strlen(enc_data));
|
||||||
|
encrypt_data_aes(tx_data, enc_data);
|
||||||
|
//Changing encrpyt data to JAVA type string
|
||||||
|
for (j = 0; j < ENC_SIZE; j++){
|
||||||
|
char *temp;
|
||||||
|
temp = iot_itoa(enc_data[j]);
|
||||||
|
if(j == 0)
|
||||||
|
strcpy(tx_buffer, "[");
|
||||||
|
strcat(tx_buffer,temp);
|
||||||
|
if (j == (ENC_SIZE - 1))
|
||||||
|
strcat(tx_buffer,"]");
|
||||||
|
else
|
||||||
|
strcat(tx_buffer,",");
|
||||||
|
free(temp);
|
||||||
|
temp = NULL;
|
||||||
|
}
|
||||||
|
IOT_DEBUG("Data reply to APP: %s\r\nLength of data: %d\r\n", tx_buffer, strlen(tx_buffer));
|
||||||
|
|
||||||
|
if ((ret = write(newsockfd,tx_buffer,strlen(tx_buffer))) < 0){
|
||||||
|
IOT_ERROR("ERROR writing to socket");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
IOT_DEBUG("Sending %d bytes data OK!\r\n", ret);
|
||||||
|
}
|
||||||
|
else if(strncmp(dec_data, "remove", strlen("remove")) == 0){
|
||||||
|
printf("\n\r\n\r\n\r\n\r<<<<<<Reset the device >>>>>>>\n\r\n\r\n\r\n\r");
|
||||||
|
flash_erase_sector(&iot_flash, FLASH_IOT_DATA);
|
||||||
|
write(newsockfd,"Remove OK",strlen("Remove OK"));
|
||||||
|
close(newsockfd);
|
||||||
|
close(sockfd);
|
||||||
|
iotapp_platform_reset();
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
IOT_ERROR("ERROR wrong KEY or wrong request!");
|
||||||
|
write(newsockfd,"The KEY or the request is not correct!",strlen("The KEY or the request is not correct!"));
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
if(close(newsockfd) != 0)
|
||||||
|
goto exit;
|
||||||
|
|
||||||
|
exit2:
|
||||||
|
if(close(sockfd) != 0)
|
||||||
|
goto exit2;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void local_link_task(void *param)
|
||||||
|
{
|
||||||
|
unsigned char data[ENC_SIZE] = NULL;
|
||||||
|
vTaskDelay(1000);
|
||||||
|
char i[16], j[16];
|
||||||
|
float temperature = 1.123f;
|
||||||
|
float humidity = 2.456f;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
while(1){
|
||||||
|
memset(i, 0, 16);
|
||||||
|
memset(j, 0, 16);
|
||||||
|
#if PSEUDO_DATA
|
||||||
|
sprintf(i,"%.2f", temperature++);
|
||||||
|
sprintf(j, "%.2f", humidity++);
|
||||||
|
if(temperature > 60)
|
||||||
|
temperature = 1.123f;
|
||||||
|
if(humidity > 98)
|
||||||
|
humidity = 2.456f;
|
||||||
|
#else
|
||||||
|
ret = SHTC_GetTempAndHumi(&temperature, &humidity);
|
||||||
|
sprintf(i,"%.2f", temperature);
|
||||||
|
sprintf(j, "%.2f", humidity);
|
||||||
|
#endif
|
||||||
|
if(ret < 0)
|
||||||
|
printf("\r\n\r\n<-----LOCAL LINK FAILED!!(get infor failed)\r\n\r\n");
|
||||||
|
else{
|
||||||
|
printf("\r\n\r\n----->START LOCAL LINKING\r\n\r\n");
|
||||||
|
gen_json_data(i, j, data);
|
||||||
|
printf("Sending data : %s\r\n", data);
|
||||||
|
if (local_link(data) < 0)
|
||||||
|
printf("\r\n\r\n<-----LOCAL LINK FAILED!!\r\n\r\n");
|
||||||
|
else
|
||||||
|
printf("\r\n\r\n<-----LOCAL LINK OK!!\r\n\r\n");
|
||||||
|
vTaskDelay(1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void start_local_link(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(local_link_task, ((const char*)"local_link_task"), 5376, NULL, tskIDLE_PRIORITY + 4, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate failed", __FUNCTION__);
|
||||||
|
}
|
||||||
|
int pair_device(unsigned char *tx_buffer, unsigned char *rx_buffer, int handshake)
|
||||||
|
{
|
||||||
|
int sockfd, newsockfd;
|
||||||
|
socklen_t clilen;
|
||||||
|
struct sockaddr_in serv_addr, cli_addr;
|
||||||
|
int ret = 0;
|
||||||
|
int opt = 1;
|
||||||
|
|
||||||
|
sockfd = socket(AF_INET, SOCK_STREAM, 0);
|
||||||
|
if (sockfd < 0) {
|
||||||
|
IOT_ERROR("ERROR opening socket");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if((setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (const char *)&opt, sizeof(opt))) < 0){
|
||||||
|
IOT_ERROR("ERROR on setting socket option");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
memset((char *)&serv_addr, 0, sizeof(serv_addr));
|
||||||
|
serv_addr.sin_family = AF_INET;
|
||||||
|
serv_addr.sin_len = sizeof(serv_addr);
|
||||||
|
serv_addr.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
serv_addr.sin_port = htons(PORT);
|
||||||
|
|
||||||
|
if ((bind(sockfd, (struct sockaddr *)&serv_addr, sizeof(serv_addr))) < 0) {
|
||||||
|
IOT_ERROR("ERROR on binding");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
if ((listen(sockfd, 5)) < 0){
|
||||||
|
IOT_ERROR("ERROR on listening tcp server socket fd");
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
clilen = sizeof(cli_addr);
|
||||||
|
newsockfd = accept(sockfd, (struct sockaddr *) &cli_addr, (socklen_t*)&clilen);
|
||||||
|
if (newsockfd < 0) {
|
||||||
|
IOT_ERROR("ERROR on accept");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
ret = read(newsockfd, rx_buffer, MAX_BUFFER_SIZE);
|
||||||
|
if (ret <= 0){
|
||||||
|
IOT_ERROR("ERROR reading from socket");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
IOT_DEBUG("Request received: %s, byte: %d\r\n",rx_buffer, ret);
|
||||||
|
if(handshake == 1){
|
||||||
|
if(strncmp(rx_buffer,"PAIR", strlen("PAIR")) != 0){
|
||||||
|
write(newsockfd, "ERROR", strlen("ERROR"));
|
||||||
|
IOT_ERROR("ERROR on first handshake!");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(handshake == 2){
|
||||||
|
if((rx_buffer == NULL) ||(strlen(rx_buffer) < 32)){
|
||||||
|
write(newsockfd, "ERROR", strlen("ERROR"));
|
||||||
|
IOT_ERROR("ERROR on second handshake!");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(handshake == 3){
|
||||||
|
unsigned char account[64];
|
||||||
|
unsigned char enc_acc[64];
|
||||||
|
char *result = NULL, *backup = NULL;
|
||||||
|
unsigned char *data = NULL;
|
||||||
|
char *delims = ", ";
|
||||||
|
int j, k = 1;
|
||||||
|
if (!strncmp(rx_buffer, "[", strlen("["))){
|
||||||
|
data = rx_buffer + strlen("[");
|
||||||
|
for(j = 1; j < 5; j++){
|
||||||
|
if (data[ret - j] == ']')
|
||||||
|
data[ret -j] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
strcpy(data, rx_buffer);
|
||||||
|
memset(enc_acc, 0, sizeof(enc_acc));
|
||||||
|
result = strtok_r(data, delims, &backup);
|
||||||
|
enc_acc[0]=(uint8_t)atoi(result);
|
||||||
|
while((result = strtok_r(NULL, delims, &backup)) != NULL)
|
||||||
|
enc_acc[k++]=(uint8_t)atoi(result);
|
||||||
|
IOT_DEBUG("The value of k: %d", k);
|
||||||
|
memset(account, 0, sizeof(account));
|
||||||
|
decrypt_data_aes(enc_acc, account, k);
|
||||||
|
|
||||||
|
if((strncmp(account,"https://", strlen("https://"))) != 0){
|
||||||
|
write(newsockfd, "ERROR", strlen("ERROR"));
|
||||||
|
IOT_ERROR("ERROR on third handshake!");
|
||||||
|
ret = -1;
|
||||||
|
goto exit2;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
IOT_DEBUG("The received Firebase URL:%s", account);
|
||||||
|
memset(rx_buffer, 0, strlen(rx_buffer));
|
||||||
|
memcpy(rx_buffer, (account+strlen("https://")), (strlen(account) + strlen("https://")));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
ret = write(newsockfd, tx_buffer, strlen(tx_buffer));
|
||||||
|
IOT_DEBUG("Data send: %s\r\n",tx_buffer);
|
||||||
|
|
||||||
|
if (ret < 0){
|
||||||
|
IOT_ERROR("ERROR writing to socket");
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
if(close(newsockfd) != 0)
|
||||||
|
goto exit;
|
||||||
|
|
||||||
|
exit2:
|
||||||
|
if(close(sockfd) != 0)
|
||||||
|
goto exit2;
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static void pair_device_task(void)
|
||||||
|
{
|
||||||
|
int i, j, k, HANDSHAKE;
|
||||||
|
uint8_t PAIR_STATE[1] = NULL;
|
||||||
|
|
||||||
|
if(CONTROL_TYPE == 1){
|
||||||
|
printf("\r\n\r\n<<<<<<CONTROL_TYPE = 1 Need 3 times handshake>>>>>>\r\n\r\n");
|
||||||
|
HANDSHAKE = 3;
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
printf("\r\n\r\n<<<<<<CONTROL_TYPE = 0 Need 2 times handshake>>>>>>\r\n\r\n");
|
||||||
|
HANDSHAKE = 2;
|
||||||
|
}
|
||||||
|
printf("\r\n\r\n=========>PAIR_STATE = 0 Start to pair\r\n\r\n");
|
||||||
|
for(i = 0; i < HANDSHAKE; i++){
|
||||||
|
static const uint8_t basepoint[32] = {9};
|
||||||
|
uint8_t mysecret[32];
|
||||||
|
uint8_t mypublic[32];
|
||||||
|
uint8_t theirpublic[32] = NULL;
|
||||||
|
uint8_t shared_key[32];
|
||||||
|
//First handshake
|
||||||
|
if(i == 0){
|
||||||
|
printf("\r\n\r\n===>Start the first handshake\r\n\r\n");
|
||||||
|
memset(tx_buffer, 0, sizeof(tx_buffer));
|
||||||
|
memset(rx_buffer, 0, sizeof(rx_buffer));
|
||||||
|
for(j = 0; j < 32; j ++)
|
||||||
|
mysecret[j] = (uint8_t) arc4random();
|
||||||
|
mysecret[j] = '\0';
|
||||||
|
curve25519_donna(mypublic, mysecret, basepoint);
|
||||||
|
for (j = 0; j < 32; j++){
|
||||||
|
char *temp;
|
||||||
|
temp = iot_itoa(mypublic[j]);
|
||||||
|
if(j == 0)
|
||||||
|
strcpy(tx_buffer, "[");
|
||||||
|
strcat(tx_buffer,temp);
|
||||||
|
if (j == 31)
|
||||||
|
strcat(tx_buffer,"]");
|
||||||
|
else
|
||||||
|
strcat(tx_buffer,",");
|
||||||
|
free(temp);
|
||||||
|
temp = NULL;
|
||||||
|
}
|
||||||
|
if(pair_device(tx_buffer, rx_buffer, 1) >= 0)
|
||||||
|
printf("\r\n\r\n<===First handshake OK!!\r\n\r\n");
|
||||||
|
else{
|
||||||
|
i--;
|
||||||
|
printf("\r\n\r\n<===First handshake FAILED!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Second handshake
|
||||||
|
if(i == 1){
|
||||||
|
printf("\r\n\r\n=====>Start the second handshake\r\n\r\n");
|
||||||
|
vTaskDelay(200);
|
||||||
|
memset(tx_buffer, 0, sizeof(tx_buffer));
|
||||||
|
if(CONTROL_TYPE == 1)
|
||||||
|
memcpy(tx_buffer, "FIREBASE URL", sizeof("FIREBASE URL"));
|
||||||
|
else
|
||||||
|
memcpy(tx_buffer, "PAIR OK", sizeof("PAIR OK"));
|
||||||
|
memset(rx_buffer, 0, sizeof(rx_buffer));
|
||||||
|
|
||||||
|
if(pair_device(tx_buffer, rx_buffer, 2) >= 0){
|
||||||
|
char *result = NULL, *backup = NULL;
|
||||||
|
unsigned char *data = NULL;
|
||||||
|
char *delims = ", ";
|
||||||
|
k = 1;
|
||||||
|
if (!strncmp(rx_buffer, "[", strlen("["))){
|
||||||
|
data = rx_buffer + strlen("[");
|
||||||
|
int len;
|
||||||
|
len = strlen(data);
|
||||||
|
for(j = 1; j < 5; j++){
|
||||||
|
if (data[len - j] == ']')
|
||||||
|
data[len -j] = '\0';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
strcpy(data, rx_buffer);
|
||||||
|
|
||||||
|
memset(theirpublic, 0, sizeof(theirpublic));
|
||||||
|
|
||||||
|
result = strtok_r(data, delims, &backup);
|
||||||
|
theirpublic[0]=(uint8_t)atoi(result);
|
||||||
|
|
||||||
|
while((result = strtok_r(NULL, delims, &backup)) != NULL)
|
||||||
|
theirpublic[k++] = (uint8_t)atoi(result);
|
||||||
|
|
||||||
|
curve25519_donna(shared_key, mysecret, theirpublic);
|
||||||
|
for(j = 0; j < 16; j ++)
|
||||||
|
aes_key[j] = shared_key[j];
|
||||||
|
//Store the KEY in FLASH
|
||||||
|
if(CONTROL_TYPE == 0){
|
||||||
|
PAIR_STATE[0] = 1;
|
||||||
|
uint8_t data[33];
|
||||||
|
memset(data, 0, 33);
|
||||||
|
memcpy(data, PAIR_STATE, 1);
|
||||||
|
memcpy(data+1, shared_key, 32);
|
||||||
|
flash_erase_sector(&iot_flash, FLASH_IOT_DATA);
|
||||||
|
flash_stream_write(&iot_flash, FLASH_IOT_DATA, 33, (uint8_t *) data);
|
||||||
|
IOT_DEBUG("PAIR_STATE: %d\r\n", PAIR_STATE[0]);
|
||||||
|
}
|
||||||
|
printf("\r\n\r\n<=====Second handshake OK!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
i = i - 2;
|
||||||
|
printf("\r\n\r\n<=====Second handshake FAILED!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//Third handshake
|
||||||
|
if(i == 2){
|
||||||
|
printf("\r\n\r\n=======>Start the third handshake\r\n\r\n");
|
||||||
|
vTaskDelay(200);
|
||||||
|
|
||||||
|
memset(tx_buffer, 0, sizeof(tx_buffer));
|
||||||
|
memcpy(tx_buffer, "PAIR OK", sizeof("PAIR OK"));
|
||||||
|
memset(rx_buffer, 0, sizeof(rx_buffer));
|
||||||
|
|
||||||
|
if(pair_device(tx_buffer, rx_buffer, 3) >= 0){
|
||||||
|
IOT_DEBUG("rx_buffer: %s, sizeof rx_buffer:%d\r\n", rx_buffer, sizeof(rx_buffer));
|
||||||
|
PAIR_STATE[0] = 1;
|
||||||
|
uint8_t data[97];
|
||||||
|
memset(data, 0, 97);
|
||||||
|
memcpy(data, PAIR_STATE, 1);
|
||||||
|
memcpy(data+1, shared_key, 32);
|
||||||
|
memcpy(data+33, rx_buffer, 64);
|
||||||
|
flash_erase_sector(&iot_flash, FLASH_IOT_DATA);
|
||||||
|
flash_stream_write(&iot_flash, FLASH_IOT_DATA, 97, (uint8_t *) data);
|
||||||
|
IOT_DEBUG("PAIR_STATE: %d\r\n", PAIR_STATE[0]);
|
||||||
|
|
||||||
|
printf("\r\n\r\n<=======Third handshake OK!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
i = i - 3;
|
||||||
|
printf("\r\n\r\n<=======Third handshake FAILED!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
printf("\r\n\r\n<=========Pairing OK!!\r\n\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
static void mdns_task(void *param)
|
||||||
|
{
|
||||||
|
DNSServiceRef dnsServiceRef = NULL;
|
||||||
|
TXTRecordRef txtRecord;
|
||||||
|
unsigned char txt_buf[128];
|
||||||
|
uint8_t *mac, *ip;
|
||||||
|
int j, ret = 0;
|
||||||
|
uint8_t *flash_data;
|
||||||
|
uint8_t PAIR_STATE[1] = NULL;
|
||||||
|
static unsigned char MAC_ADD[21];
|
||||||
|
static unsigned char IP[16];
|
||||||
|
static unsigned char port[6];
|
||||||
|
uint16_t shtc1_id;
|
||||||
|
|
||||||
|
// Delay to wait for IP by DHCP and get the information of IP and MAC
|
||||||
|
printf("\n\r\n\r\n\r\n\r<<<<<<Waiting for 20 seconds to connect Wi-Fi>>>>>>>\n\r\n\r\n\r\n\r");
|
||||||
|
vTaskDelay(20000);
|
||||||
|
ip = LwIP_GetIP(&xnetif[0]);
|
||||||
|
mac = LwIP_GetMAC(&xnetif[0]);
|
||||||
|
|
||||||
|
sprintf(MAC_ADD, "%02x%02x%02x%02x%02x%02x", mac[0], mac[1], mac[2], mac[3], mac[4], mac[5]);
|
||||||
|
sprintf(IP, "%d.%d.%d.%d", ip[0], ip[1], ip[2], ip[3]);
|
||||||
|
sprintf(port, "%d", PORT);
|
||||||
|
|
||||||
|
IOT_DEBUG("MAC => %s\r\n", MAC_ADD) ;
|
||||||
|
IOT_DEBUG("IP => %s\r\n", IP);
|
||||||
|
IOT_DEBUG("PORT => %s\r\n", port);
|
||||||
|
|
||||||
|
//Get the value of PAIR_STATE and the AES key in flash
|
||||||
|
flash_data = (uint8_t *)malloc(33);
|
||||||
|
flash_stream_read(&iot_flash, FLASH_IOT_DATA, 33, (uint8_t *)flash_data);
|
||||||
|
memcpy(PAIR_STATE, flash_data, 1);
|
||||||
|
if(PAIR_STATE[0] != 0x1)
|
||||||
|
PAIR_STATE[0] = 0;
|
||||||
|
else{
|
||||||
|
for(j = 0;j < 16; j++){
|
||||||
|
aes_key[j] = flash_data[j+1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
free(flash_data);
|
||||||
|
IOT_DEBUG("PAIR_STATE now: %d\r\n", PAIR_STATE[0]);
|
||||||
|
|
||||||
|
IOT_DEBUG("=>mDNS Init\r\n");
|
||||||
|
if(mDNSResponderInit() == 0) {
|
||||||
|
printf("\r\n\r\n========>Start to register mDNS service\r\n\r\n");
|
||||||
|
//The device not paired before
|
||||||
|
if(PAIR_STATE[0] == 0){
|
||||||
|
TXTRecordCreate(&txtRecord, sizeof(txt_buf), txt_buf);
|
||||||
|
|
||||||
|
TXTRecordSetValue(&txtRecord, "IP", strlen(IP), IP);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PORT", strlen(port), port);
|
||||||
|
TXTRecordSetValue(&txtRecord, "MAC_ADDR", strlen(MAC_ADD), MAC_ADD);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PAIR_STATE", strlen("0"), "0");
|
||||||
|
TXTRecordSetValue(&txtRecord, "SERVICE_NAME", strlen("ht_sensor"), "ht_sensor");
|
||||||
|
if(CONTROL_TYPE == 1)
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("1"), "1");
|
||||||
|
else
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("0"), "0");
|
||||||
|
dnsServiceRef = mDNSRegisterService("ht_sensor", "_Ameba._tcp", "local", PORT, &txtRecord);
|
||||||
|
TXTRecordDeallocate(&txtRecord);
|
||||||
|
printf("\r\n\r\n<========Registering mDNS service OK!!\r\n\r\n");
|
||||||
|
pair_device_task();
|
||||||
|
}
|
||||||
|
//The device was paired
|
||||||
|
else if(PAIR_STATE[0] == 0x1){
|
||||||
|
TXTRecordCreate(&txtRecord, sizeof(txt_buf), txt_buf);
|
||||||
|
|
||||||
|
TXTRecordSetValue(&txtRecord, "IP", strlen(ip), ip);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PORT", strlen(port), port);
|
||||||
|
TXTRecordSetValue(&txtRecord, "MAC_ADDR", strlen(MAC_ADD), MAC_ADD);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PAIR_STATE", strlen("1"), "1");
|
||||||
|
TXTRecordSetValue(&txtRecord, "SERVICE_NAME", strlen("ht_sensor"), "ht_sensor");
|
||||||
|
if(CONTROL_TYPE == 1)
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("1"), "1");
|
||||||
|
else
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("0"), "0");
|
||||||
|
|
||||||
|
dnsServiceRef = mDNSRegisterService("ht_sensor", "_Ameba._tcp", "local", PORT, &txtRecord);
|
||||||
|
TXTRecordDeallocate(&txtRecord);
|
||||||
|
printf("\r\n\r\n<========Registering mDNS service OK!! PAIR_STATE = 1\r\n\r\n");
|
||||||
|
}
|
||||||
|
#if PSEUDO_DATA
|
||||||
|
printf("\r\n\r\n========>Using the speudo data\r\n\r\n");
|
||||||
|
if(CONTROL_TYPE == 1) start_cloud_link();
|
||||||
|
start_local_link();
|
||||||
|
#else
|
||||||
|
//Init the shtc1 sensor
|
||||||
|
printf("\r\n\r\n========>Init the temperature and humidity sensor\r\n\r\n");
|
||||||
|
ret = SHTC_Init(&shtc1_id);
|
||||||
|
if ( ret == NO_ERROR ){
|
||||||
|
printf("\r\n\r\n<========Senser init OK! ID = 0x%x \r\n\r\n", shtc1_id);
|
||||||
|
if(CONTROL_TYPE == 1) start_cloud_link();
|
||||||
|
start_local_link();
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("\r\n\r\n<========Senser init FAILED! ID = 0x%x \r\n\r\n", shtc1_id);
|
||||||
|
ret = -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
ret = -1;
|
||||||
|
if(ret == 0){
|
||||||
|
while(1){
|
||||||
|
IOT_DEBUG("Update the mDNS textrecord!\r\n");
|
||||||
|
TXTRecordCreate(&txtRecord, sizeof(txt_buf), txt_buf);
|
||||||
|
TXTRecordSetValue(&txtRecord, "IP", strlen(IP), IP);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PORT", strlen(port), port);
|
||||||
|
TXTRecordSetValue(&txtRecord, "MAC_ADDR", strlen(MAC_ADD), MAC_ADD);
|
||||||
|
TXTRecordSetValue(&txtRecord, "PAIR_STATE", strlen("1"), "1");
|
||||||
|
if(CONTROL_TYPE == 1)
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("1"), "1");
|
||||||
|
else
|
||||||
|
TXTRecordSetValue(&txtRecord, "CONTROL_TYPE", strlen("0"), "0");
|
||||||
|
TXTRecordSetValue(&txtRecord, "SERVICE_NAME", strlen("ht_sensor"), "ht_sensor");
|
||||||
|
|
||||||
|
mDNSUpdateService(dnsServiceRef, &txtRecord, 0);
|
||||||
|
TXTRecordDeallocate(&txtRecord);
|
||||||
|
vTaskDelay(2*60*1000);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
if(dnsServiceRef)
|
||||||
|
mDNSDeregisterService(dnsServiceRef);
|
||||||
|
IOT_DEBUG("<=mDNS Deinit\r\n\r\n");
|
||||||
|
mDNSResponderDeinit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_wigadget(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(mdns_task, ((const char*)"mdns_task"), 3072, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate failed", __FUNCTION__);
|
||||||
|
|
||||||
|
gpio_t gpio_softap_reset_button;
|
||||||
|
gpio_irq_t gpioirq_softap_reset_button;
|
||||||
|
|
||||||
|
gpio_irq_init(&gpioirq_softap_reset_button, GPIO_SOFTAP_RESET_PIN, iotapp_reset_irq_handler, (uint32_t)(&gpio_softap_reset_button));
|
||||||
|
gpio_irq_set(&gpioirq_softap_reset_button, IRQ_FALL, 1);
|
||||||
|
gpio_irq_enable(&gpioirq_softap_reset_button);
|
||||||
|
}
|
||||||
|
|
11
component/common/application/wigadget/wigadget.h
Executable file
11
component/common/application/wigadget/wigadget.h
Executable file
|
@ -0,0 +1,11 @@
|
||||||
|
#ifndef WIGADGET_H
|
||||||
|
#define WIGADGET_H
|
||||||
|
|
||||||
|
#define FLASH_IOT_DATA (0x0007E000)
|
||||||
|
#define PSEUDO_DATA 1
|
||||||
|
|
||||||
|
void example_wigadget(void);
|
||||||
|
void gen_json_data(char *i, char *j, unsigned char *json_data);
|
||||||
|
|
||||||
|
#endif /* WIGADGET_H */
|
||||||
|
|
369
component/common/drivers/wlan/realtek/include/autoconf.h
Executable file
369
component/common/drivers/wlan/realtek/include/autoconf.h
Executable file
|
@ -0,0 +1,369 @@
|
||||||
|
#ifndef WLANCONFIG_H
|
||||||
|
#define WLANCONFIG_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Include user defined options first. Anything not defined in these files
|
||||||
|
* will be set to standard values. Override anything you dont like!
|
||||||
|
*/
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#include "platform_opts.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define CONFIG_PLATFORM_AMEBA_X
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define PLATFORM_FREERTOS 1
|
||||||
|
#define CONFIG_GSPI_HCI
|
||||||
|
#else
|
||||||
|
#define CONFIG_LX_HCI
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_INIC_EN
|
||||||
|
#define CONFIG_INIC_EN 0 //For iNIC project
|
||||||
|
#if CONFIG_INIC_EN
|
||||||
|
#define CONFIG_LWIP_LAYER 0
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define CONFIG_LITTLE_ENDIAN
|
||||||
|
#define CONFIG_80211N_HT
|
||||||
|
//#define CONFIG_RECV_REORDERING_CTRL
|
||||||
|
#define RTW_NOTCH_FILTER 0
|
||||||
|
#define CONFIG_EMBEDDED_FWIMG 1
|
||||||
|
#define CONFIG_PHY_SETTING_WITH_ODM
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_ODM_REFRESH_RAMASK
|
||||||
|
#define HAL_MAC_ENABLE 1
|
||||||
|
#define HAL_BB_ENABLE 1
|
||||||
|
#define HAL_RF_ENABLE 1
|
||||||
|
#endif
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
/* Patch when dynamic mechanism is not ready */
|
||||||
|
//#define CONFIG_DM_PATCH
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//#define CONFIG_DEBUG
|
||||||
|
//#define CONFIG_DEBUG_RTL871X
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_MEM_MONITOR MEM_MONITOR_SIMPLE
|
||||||
|
#define WLAN_INTF_DBG 0
|
||||||
|
#define CONFIG_DEBUG_DYNAMIC
|
||||||
|
//#define DBG_TX 1
|
||||||
|
//#define DBG_XMIT_BUF 1
|
||||||
|
//#define DBG_XMIT_BUF_EXT 1
|
||||||
|
#define DBG_TX_DROP_FRAME
|
||||||
|
#else
|
||||||
|
#define CONFIG_MEM_MONITOR MEM_MONITOR_LEAK
|
||||||
|
//#define CONFIG_TRACE_SKB
|
||||||
|
//#define WLAN_INTF_DBG
|
||||||
|
#endif // CONFIG_PLATFORM_AMEBA_X
|
||||||
|
|
||||||
|
//#define CONFIG_DONT_CARE_TP
|
||||||
|
//#define CONFIG_MEMORY_ACCESS_ALIGNED
|
||||||
|
#define CONFIG_POWER_SAVING
|
||||||
|
#ifdef CONFIG_POWER_SAVING
|
||||||
|
#define CONFIG_IPS
|
||||||
|
#define CONFIG_LPS
|
||||||
|
//#define CONFIG_LPS_LCLK
|
||||||
|
#define CONFIG_LPS_32K
|
||||||
|
#define TDMA_POWER_SAVING
|
||||||
|
#define CONFIG_WAIT_PS_ACK
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#if !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define CONFIG_USE_TCM_HEAP 1 /* USE TCM HEAP */
|
||||||
|
#endif
|
||||||
|
#define CONFIG_RECV_TASKLET_THREAD
|
||||||
|
#define CONFIG_XMIT_TASKLET_THREAD
|
||||||
|
#else
|
||||||
|
#define CONFIG_XMIT_THREAD_MODE
|
||||||
|
#endif // CONFIG_PLATFORM_AMEBA_X
|
||||||
|
//#define CONFIG_RECV_THREAD_MODE /* Wlan IRQ Polling Mode*/
|
||||||
|
//#define CONFIG_ISR_THREAD_MODE_POLLING /* Wlan IRQ Polling Mode*/
|
||||||
|
|
||||||
|
//1 Chris
|
||||||
|
#ifndef CONFIG_SDIO_HCI
|
||||||
|
#define CONFIG_ISR_THREAD_MODE_INTERRUPT /* Wlan IRQ Interrupt Mode*/
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_ISR_THREAD_MODE_POLLING) && defined(CONFIG_ISR_THREAD_MODE_INTERRUPT)
|
||||||
|
#error "CONFIG_ISR_THREAD_MODE_POLLING and CONFIG_ISR_THREAD_MODE_INTERRUPT are mutually exclusive. "
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
/* CRC DMEM optimized mode consume 1k less SRM memory consumption */
|
||||||
|
#define CRC_IMPLEMENTATION_MODE CRC_IMPLEMENTATION_DMEM_OPTIMIZED
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* AES DMEM optimized mode comsume 10k less memory compare to
|
||||||
|
IMEM optimized mode AES_IMPLEMENTATION_IMEM_OPTIMIZED */
|
||||||
|
#define AES_IMPLEMENTATION_MODE AES_IMPLEMENTATION_DMEM_OPTIMIZED
|
||||||
|
|
||||||
|
#define USE_SKB_AS_XMITBUF 1
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define USE_XMIT_EXTBUFF 1
|
||||||
|
#else
|
||||||
|
#define USE_XMIT_EXTBUFF 0
|
||||||
|
#endif
|
||||||
|
#define USE_MUTEX_FOR_SPINLOCK 1
|
||||||
|
#define SUPPORT_5G_CHANNEL 0
|
||||||
|
#define SUPPORT_ONLY_HT_1T 1
|
||||||
|
#define SUPPORT_FAKE_EFUSE 0
|
||||||
|
|
||||||
|
#define CONFIG_AUTO_RECONNECT 1
|
||||||
|
#define ENABLE_HWPDN_PIN
|
||||||
|
#define SUPPORT_SCAN_BUF 1
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define BE_I_CUT 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For WPA2 */
|
||||||
|
#define CONFIG_INCLUDE_WPA_PSK
|
||||||
|
#ifdef CONFIG_INCLUDE_WPA_PSK
|
||||||
|
#define CONFIG_MULTIPLE_WPA_STA
|
||||||
|
//#define CONFIG_WPA2_PREAUTH
|
||||||
|
#define PSK_SUPPORT_TKIP 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For promiscuous mode */
|
||||||
|
#define CONFIG_PROMISC
|
||||||
|
|
||||||
|
#define PROMISC_DENY_PAIRWISE 0
|
||||||
|
|
||||||
|
/* For Simple Link */
|
||||||
|
#ifndef CONFIG_INCLUDE_SIMPLE_CONFIG
|
||||||
|
//#define CONFIG_INCLUDE_SIMPLE_CONFIG 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// for probe request with custom vendor specific IE
|
||||||
|
#define CONFIG_CUSTOM_IE
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
/* For multicast */
|
||||||
|
#define CONFIG_MULTICAST
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For STA+AP Concurrent MODE */
|
||||||
|
#if !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define CONFIG_CONCURRENT_MODE
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_CONCURRENT_MODE
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A)
|
||||||
|
#define CONFIG_RUNTIME_PORT_SWITCH
|
||||||
|
#endif
|
||||||
|
#define NET_IF_NUM 2
|
||||||
|
#else
|
||||||
|
#define NET_IF_NUM 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
/* For WPS and P2P */
|
||||||
|
#ifndef CONFIG_WPS
|
||||||
|
#define CONFIG_WPS
|
||||||
|
#if defined(CONFIG_WPS)
|
||||||
|
#define CONFIG_ENABLE_WPS 1
|
||||||
|
#endif
|
||||||
|
#if 0//def CONFIG_WPS
|
||||||
|
#define CONFIG_WPS_AP
|
||||||
|
#define CONFIG_P2P_NEW
|
||||||
|
#if (!defined(SUPPORT_SCAN_BUF)||!defined(CONFIG_WPS_AP)) && defined(CONFIG_P2P_NEW)
|
||||||
|
#error "If CONFIG_P2P_NEW, need to SUPPORT_SCAN_BUF"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_NEW_SIGNAL_STAT_PROCESS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For AP_MODE */
|
||||||
|
#define CONFIG_AP_MODE
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define AP_STA_NUM 3 //2014/10/27 modify to 3
|
||||||
|
#define USE_DEDICATED_BCN_TX 0
|
||||||
|
#if USE_DEDICATED_BCN_TX
|
||||||
|
#error "WLAN driver for Ameba should not enable USE_DEDICATED_BCN_TX"
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
extern unsigned int g_ap_sta_num;
|
||||||
|
#define AP_STA_NUM g_ap_sta_num
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_AP_MODE
|
||||||
|
#define CONFIG_NATIVEAP_MLME
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_INTERRUPT_BASED_TXBCN
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_INTERRUPT_BASED_TXBCN
|
||||||
|
//#define CONFIG_INTERRUPT_BASED_TXBCN_EARLY_INT
|
||||||
|
#define CONFIG_INTERRUPT_BASED_TXBCN_BCN_OK_ERR
|
||||||
|
#endif
|
||||||
|
// #define CONFIG_GK_REKEY
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define USE_DEDICATED_BCN_TX 1
|
||||||
|
#endif
|
||||||
|
#if CONFIG_INIC_EN
|
||||||
|
#define REPORT_STA_EVENT
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define USE_DEDICATED_BCN_TX 0
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_AP_MODE) && defined(CONFIG_GK_REKEY) && !defined(CONFIG_MULTIPLE_WPA_STA)
|
||||||
|
#error "If CONFIG_GK_REKEY when CONFIG_AP_MODE, need to CONFIG_MULTIPLE_WPA_STA"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#if !defined(CONFIG_AP_MODE) && defined(CONFIG_CONCURRENT_MODE)
|
||||||
|
#error "If CONFIG_CONCURRENT_MODEE, need to CONFIG_AP_MODE"
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For efuse or flash config */
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_RW_PHYSICAL_EFUSE 0 // Mask efuse user blocks
|
||||||
|
#define CONFIG_HIDE_PROTECT_EFUSE 1
|
||||||
|
#define CONFIG_ADAPTOR_INFO_CACHING_FLASH 1
|
||||||
|
#define CHECK_FLASH_VALID_MASK 1
|
||||||
|
/* For K-free */
|
||||||
|
#if !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define CONFIG_RF_GAIN_OFFSET
|
||||||
|
#endif
|
||||||
|
#endif // CONFIG_PLATFORM_AMEBA_X
|
||||||
|
|
||||||
|
/* For MP_MODE */
|
||||||
|
//#define CONFIG_MP_INCLUDED
|
||||||
|
#ifdef CONFIG_MP_INCLUDED
|
||||||
|
#define MP_DRIVER 1
|
||||||
|
#define CONFIG_MP_IWPRIV_SUPPORT
|
||||||
|
// #define HAL_EFUSE_MEMORY
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define MP_REG_TEST
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#define MP_DRIVER 0
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
//Control wifi mcu function
|
||||||
|
#define CONFIG_LITTLE_WIFI_MCU_FUNCTION_THREAD
|
||||||
|
#define CONFIG_ODM_REFRESH_RAMASK
|
||||||
|
#endif
|
||||||
|
#endif // #ifdef CONFIG_MP_INCLUDED
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#if defined(CONFIG_PLATFORM_8195A)
|
||||||
|
#define CONFIG_RTL8195A
|
||||||
|
#endif
|
||||||
|
#if defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define CONFIG_RTL8711B
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#define CONFIG_RTL8188E
|
||||||
|
#endif
|
||||||
|
#define RTL8192C_SUPPORT 0
|
||||||
|
#define RTL8192CE_SUPPORT 0
|
||||||
|
#define RTL8192CU_SUPPORT 0
|
||||||
|
#define RTL8192D_SUPPORT 0
|
||||||
|
#define RTL8192DE_SUPPORT 0
|
||||||
|
#define RTL8192DU_SUPPORT 0
|
||||||
|
#define RTL8723A_SUPPORT 0
|
||||||
|
#define RTL8723AU_SUPPORT 0
|
||||||
|
#define RTL8723AS_SUPPORT 0
|
||||||
|
#define RTL8192E_SUPPORT 0
|
||||||
|
#define RTL8812A_SUPPORT 0
|
||||||
|
#define RTL8821A_SUPPORT 0
|
||||||
|
#define RTL8723B_SUPPORT 0
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define RTL8195A_SUPPORT 1
|
||||||
|
#define RTL8188E_SUPPORT 0
|
||||||
|
#else
|
||||||
|
#define RTL8188E_SUPPORT 1
|
||||||
|
#define RTL8195A_SUPPORT 0
|
||||||
|
#endif
|
||||||
|
#define TEST_CHIP_SUPPORT 0
|
||||||
|
|
||||||
|
#define RTL8188E_FOR_TEST_CHIP 0
|
||||||
|
#define RTL8188E_FPGA_TRUE_PHY_VERIFICATION 0
|
||||||
|
|
||||||
|
// for Debug message
|
||||||
|
#define DBG 0
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#if(DBG == 0)
|
||||||
|
#define ROM_E_RTW_MSG 1
|
||||||
|
/* For DM debug*/
|
||||||
|
// BB
|
||||||
|
#define DBG_RX_INFO 1
|
||||||
|
#define DBG_TX_RATE 1 // DebugComponents: bit9
|
||||||
|
#define DBG_DM_RA 1 // DebugComponents: bit9
|
||||||
|
#define DBG_DM_DIG 1 // DebugComponents: bit0
|
||||||
|
// RF
|
||||||
|
#define DBG_PWR_TRACKING 1 // DebugComponents: bit24
|
||||||
|
#define DBG_RF_IQK 1 // DebugComponents: bit26
|
||||||
|
// Common
|
||||||
|
#define DBG_PWR_INDEX 1 // DebugComponents: bit30
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* For DM support */
|
||||||
|
#define RATE_ADAPTIVE_SUPPORT 1
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_EN 0
|
||||||
|
#define RTW_ADAPTIVITY_MODE_NORMAL 0
|
||||||
|
#define RTW_ADAPTIVITY_MODE_CARRIER_SENSE 1
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_MODE RTW_ADAPTIVITY_MODE_CARRIER_SENSE
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define CONFIG_POWER_TRAINING_WIL 0 // in RA
|
||||||
|
#else
|
||||||
|
#define POWER_BY_RATE_SUPPORT 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_PLATFORM_AMEBA_X)
|
||||||
|
#define RTL8195A_FOR_TEST_CHIP 0
|
||||||
|
|
||||||
|
//#define CONFIG_WIFI_TEST 1
|
||||||
|
//#define CONFIG_MAC_LOOPBACK_DRIVER 1
|
||||||
|
//#define CONFIG_WLAN_HAL_TEST 1
|
||||||
|
//#define SKB_PRE_ALLOCATE_TX 1
|
||||||
|
#define SKB_PRE_ALLOCATE_RX 0
|
||||||
|
#define TX_CHECK_DSEC_ALWAYS 1
|
||||||
|
#define CONFIG_DBG_DISABLE_RDU_INTERRUPT
|
||||||
|
//#define CONFIG_WLAN_HAL_RX_TASK
|
||||||
|
#if (SKB_PRE_ALLOCATE_RX == 1)
|
||||||
|
#define EXCHANGE_LXBUS_RX_SKB 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//Enable mac loopback for test mode (Ameba)
|
||||||
|
//#define ENABLE_MAC_LB_FOR_TEST_MODE // for test mode
|
||||||
|
#ifdef ENABLE_MAC_LB_FOR_TEST_MODE
|
||||||
|
#define CONFIG_SUDO_PHY_SETTING
|
||||||
|
#define INT_HANDLE_IN_ISR 1
|
||||||
|
#define CONFIG_LWIP_LAYER 0
|
||||||
|
#define CONFIG_WLAN_HAL_TEST
|
||||||
|
#define CONFIG_WLAN_HAL_RX_TASK
|
||||||
|
#define CONFIG_MAC_LOOPBACK_DRIVER_RTL8195A 1
|
||||||
|
//#define CONFIG_TWO_MAC_TEST_MODE
|
||||||
|
#define DISABLE_BB_RF 1
|
||||||
|
#else
|
||||||
|
//#define CONFIG_TWO_MAC_DRIVER //for mornal driver; two mac
|
||||||
|
#ifdef CONFIG_TWO_MAC_DRIVER
|
||||||
|
#define CONFIG_SUDO_PHY_SETTING
|
||||||
|
#define DISABLE_BB_RF 1
|
||||||
|
#else
|
||||||
|
#define HAL_MAC_ENABLE 1
|
||||||
|
#define HAL_BB_ENABLE 1
|
||||||
|
#define HAL_RF_ENABLE 1
|
||||||
|
#define DISABLE_BB_RF 0
|
||||||
|
#endif
|
||||||
|
//#define INT_HANDLE_IN_ISR 1
|
||||||
|
#endif
|
||||||
|
#endif // CONFIG_PLATFORM_AMEBA_X
|
||||||
|
|
||||||
|
#ifndef CONFIG_LWIP_LAYER
|
||||||
|
#define CONFIG_LWIP_LAYER 1
|
||||||
|
#endif
|
||||||
|
#define CONFIG_MAC_ADDRESS 0
|
||||||
|
//fast reconnection
|
||||||
|
//#define CONFIG_FAST_RECONNECTION 1
|
||||||
|
#endif //WLANCONFIG_H
|
106
component/common/drivers/wlan/realtek/include/drv_conf.h
Executable file
106
component/common/drivers/wlan/realtek/include/drv_conf.h
Executable file
|
@ -0,0 +1,106 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __DRV_CONF_H__
|
||||||
|
#define __DRV_CONF_H__
|
||||||
|
|
||||||
|
#include "autoconf.h"
|
||||||
|
#if (RTL8195A_SUPPORT==1)
|
||||||
|
#include "platform_autoconf.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (PLATFORM_LINUX) && defined (PLATFORM_WINDOWS)
|
||||||
|
|
||||||
|
#error "Shall be Linux or Windows, but not both!\n"
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//Older Android kernel doesn't has CONFIG_ANDROID defined,
|
||||||
|
//add this to force CONFIG_ANDROID defined
|
||||||
|
#ifdef CONFIG_PLATFORM_ANDROID
|
||||||
|
#define CONFIG_ANDROID
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_ANDROID
|
||||||
|
//Some Android build will restart the UI while non-printable ascii is passed
|
||||||
|
//between java and c/c++ layer (JNI). We force CONFIG_VALIDATE_SSID
|
||||||
|
//for Android here. If you are sure there is no risk on your system about this,
|
||||||
|
//mask this macro define to support non-printable ascii ssid.
|
||||||
|
//#define CONFIG_VALIDATE_SSID
|
||||||
|
#ifdef CONFIG_PLATFORM_ARM_SUNxI
|
||||||
|
#ifdef CONFIG_VALIDATE_SSID
|
||||||
|
#undef CONFIG_VALIDATE_SSID
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//Android expect dbm as the rx signal strength unit
|
||||||
|
#define CONFIG_SIGNAL_DISPLAY_DBM
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_HAS_EARLYSUSPEND) && defined (CONFIG_RESUME_IN_WORKQUEUE)
|
||||||
|
#warning "You have CONFIG_HAS_EARLYSUSPEND enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
|
||||||
|
#undef CONFIG_RESUME_IN_WORKQUEUE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_ANDROID_POWER) && defined (CONFIG_RESUME_IN_WORKQUEUE)
|
||||||
|
#warning "You have CONFIG_ANDROID_POWER enabled in your system, we disable CONFIG_RESUME_IN_WORKQUEUE automatically"
|
||||||
|
#undef CONFIG_RESUME_IN_WORKQUEUE
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_RESUME_IN_WORKQUEUE //this can be removed, because there is no case for this...
|
||||||
|
#if !defined( CONFIG_WAKELOCK) && !defined(CONFIG_ANDROID_POWER)
|
||||||
|
#error "enable CONFIG_RESUME_IN_WORKQUEUE without CONFIG_WAKELOCK or CONFIG_ANDROID_POWER will suffer from the danger of wifi's unfunctionality..."
|
||||||
|
#error "If you still want to enable CONFIG_RESUME_IN_WORKQUEUE in this case, mask this preprossor checking and GOOD LUCK..."
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//About USB VENDOR REQ
|
||||||
|
#if defined(CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC) && !defined(CONFIG_USB_VENDOR_REQ_MUTEX)
|
||||||
|
#warning "define CONFIG_USB_VENDOR_REQ_MUTEX for CONFIG_USB_VENDOR_REQ_BUFFER_PREALLOC automatically"
|
||||||
|
#define CONFIG_USB_VENDOR_REQ_MUTEX
|
||||||
|
#endif
|
||||||
|
#if defined(CONFIG_VENDOR_REQ_RETRY) && !defined(CONFIG_USB_VENDOR_REQ_MUTEX)
|
||||||
|
#warning "define CONFIG_USB_VENDOR_REQ_MUTEX for CONFIG_VENDOR_REQ_RETRY automatically"
|
||||||
|
#define CONFIG_USB_VENDOR_REQ_MUTEX
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_RTW_ADAPTIVITY_EN
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_EN 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_RTW_ADAPTIVITY_MODE
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_MODE 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_RTW_ADAPTIVITY_DML
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_DML 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_RTW_ADAPTIVITY_DC_BACKOFF
|
||||||
|
#define CONFIG_RTW_ADAPTIVITY_DC_BACKOFF 4
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef CONFIG_RTW_NHM_EN
|
||||||
|
#define CONFIG_RTW_NHM_EN 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
//#include <rtl871x_byteorder.h>
|
||||||
|
|
||||||
|
#endif // __DRV_CONF_H__
|
||||||
|
|
38
component/common/drivers/wlan/realtek/include/rom_aes.h
Executable file
38
component/common/drivers/wlan/realtek/include/rom_aes.h
Executable file
|
@ -0,0 +1,38 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2014 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This is ROM code section.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef ROM_AES_H
|
||||||
|
#define ROM_AES_H
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
u32 erk[64]; /* encryption round keys */
|
||||||
|
u32 drk[64]; /* decryption round keys */
|
||||||
|
int nr; /* number of rounds */
|
||||||
|
}aes_context;
|
||||||
|
|
||||||
|
|
||||||
|
#define AES_BLOCKSIZE8 8
|
||||||
|
#define AES_BLK_SIZE 16 // # octets in an AES block
|
||||||
|
typedef union _aes_block // AES cipher block
|
||||||
|
{
|
||||||
|
unsigned long x[AES_BLK_SIZE/4]; // access as 8-bit octets or 32-bit words
|
||||||
|
unsigned char b[AES_BLK_SIZE];
|
||||||
|
}aes_block;
|
||||||
|
|
||||||
|
|
||||||
|
void AES_WRAP(unsigned char * plain, int plain_len,
|
||||||
|
unsigned char * iv, int iv_len,
|
||||||
|
unsigned char * kek, int kek_len,
|
||||||
|
unsigned char *cipher, unsigned short *cipher_len);
|
||||||
|
|
||||||
|
void AES_UnWRAP(unsigned char * cipher, int cipher_len,
|
||||||
|
unsigned char * kek, int kek_len,
|
||||||
|
unsigned char * plain);
|
||||||
|
|
||||||
|
#endif
|
456
component/common/drivers/wlan/realtek/include/rtw_debug.h
Executable file
456
component/common/drivers/wlan/realtek/include/rtw_debug.h
Executable file
|
@ -0,0 +1,456 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2011 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#ifndef __RTW_DEBUG_H__
|
||||||
|
#define __RTW_DEBUG_H__
|
||||||
|
|
||||||
|
|
||||||
|
#define _drv_always_ 1
|
||||||
|
#define _drv_emerg_ 2
|
||||||
|
#define _drv_alert_ 3
|
||||||
|
#define _drv_crit_ 4
|
||||||
|
#define _drv_err_ 5
|
||||||
|
#define _drv_warning_ 6
|
||||||
|
#define _drv_notice_ 7
|
||||||
|
#define _drv_info_ 8
|
||||||
|
#define _drv_dump_ 9
|
||||||
|
#define _drv_debug_ 10
|
||||||
|
|
||||||
|
|
||||||
|
#define _module_rtl871x_xmit_c_ BIT(0)
|
||||||
|
#define _module_xmit_osdep_c_ BIT(1)
|
||||||
|
#define _module_rtl871x_recv_c_ BIT(2)
|
||||||
|
#define _module_recv_osdep_c_ BIT(3)
|
||||||
|
#define _module_rtl871x_mlme_c_ BIT(4)
|
||||||
|
#define _module_mlme_osdep_c_ BIT(5)
|
||||||
|
#define _module_rtl871x_sta_mgt_c_ BIT(6)
|
||||||
|
#define _module_rtl871x_cmd_c_ BIT(7)
|
||||||
|
#define _module_cmd_osdep_c_ BIT(8)
|
||||||
|
#define _module_rtl871x_io_c_ BIT(9)
|
||||||
|
#define _module_io_osdep_c_ BIT(10)
|
||||||
|
#define _module_os_intfs_c_ BIT(11)
|
||||||
|
#define _module_rtl871x_security_c_ BIT(12)
|
||||||
|
#define _module_rtl871x_eeprom_c_ BIT(13)
|
||||||
|
#define _module_hal_init_c_ BIT(14)
|
||||||
|
#define _module_hci_hal_init_c_ BIT(15)
|
||||||
|
#define _module_rtl871x_ioctl_c_ BIT(16)
|
||||||
|
#define _module_rtl871x_ioctl_set_c_ BIT(17)
|
||||||
|
#define _module_rtl871x_ioctl_query_c_ BIT(18)
|
||||||
|
#define _module_rtl871x_pwrctrl_c_ BIT(19)
|
||||||
|
#define _module_hci_intfs_c_ BIT(20)
|
||||||
|
#define _module_hci_ops_c_ BIT(21)
|
||||||
|
#define _module_osdep_service_c_ BIT(22)
|
||||||
|
#define _module_mp_ BIT(23)
|
||||||
|
#define _module_hci_ops_os_c_ BIT(24)
|
||||||
|
#define _module_rtl871x_ioctl_os_c BIT(25)
|
||||||
|
#define _module_rtl8712_cmd_c_ BIT(26)
|
||||||
|
#define _module_fwcmd_c_ BIT(27)
|
||||||
|
#define _module_rtl8192c_xmit_c_ BIT(28)
|
||||||
|
#define _module_hal_xmit_c_ BIT(28)
|
||||||
|
#define _module_efuse_ BIT(29)
|
||||||
|
#define _module_rtl8712_recv_c_ BIT(30)
|
||||||
|
#define _module_rtl8712_led_c_ BIT(31)
|
||||||
|
|
||||||
|
#undef _MODULE_DEFINE_
|
||||||
|
|
||||||
|
#if defined _RTW_XMIT_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_xmit_c_
|
||||||
|
#elif defined _XMIT_OSDEP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_xmit_osdep_c_
|
||||||
|
#elif defined _RTW_RECV_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_recv_c_
|
||||||
|
#elif defined _RECV_OSDEP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_recv_osdep_c_
|
||||||
|
#elif defined _RTW_MLME_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_mlme_c_
|
||||||
|
#elif defined _MLME_OSDEP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_mlme_osdep_c_
|
||||||
|
#elif defined _RTW_MLME_EXT_C_
|
||||||
|
#define _MODULE_DEFINE_ 1
|
||||||
|
#elif defined _RTW_STA_MGT_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_sta_mgt_c_
|
||||||
|
#elif defined _RTW_CMD_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_cmd_c_
|
||||||
|
#elif defined _CMD_OSDEP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_cmd_osdep_c_
|
||||||
|
#elif defined _RTW_IO_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_io_c_
|
||||||
|
#elif defined _IO_OSDEP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_io_osdep_c_
|
||||||
|
#elif defined _OS_INTFS_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_os_intfs_c_
|
||||||
|
#elif defined _RTW_SECURITY_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_security_c_
|
||||||
|
#elif defined _RTW_EEPROM_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_eeprom_c_
|
||||||
|
#elif defined _HAL_INTF_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_hal_init_c_
|
||||||
|
#elif (defined _HCI_HAL_INIT_C_) || (defined _SDIO_HALINIT_C_)
|
||||||
|
#define _MODULE_DEFINE_ _module_hci_hal_init_c_
|
||||||
|
#elif defined _RTL871X_IOCTL_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_ioctl_c_
|
||||||
|
#elif defined _RTL871X_IOCTL_SET_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_ioctl_set_c_
|
||||||
|
#elif defined _RTL871X_IOCTL_QUERY_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_ioctl_query_c_
|
||||||
|
#elif defined _RTL871X_PWRCTRL_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_pwrctrl_c_
|
||||||
|
#elif defined _RTW_PWRCTRL_C_
|
||||||
|
#define _MODULE_DEFINE_ 1
|
||||||
|
#elif defined _HCI_INTF_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_hci_intfs_c_
|
||||||
|
#elif defined _HCI_OPS_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_hci_ops_c_
|
||||||
|
#elif defined _SDIO_OPS_C_
|
||||||
|
#define _MODULE_DEFINE_ 1
|
||||||
|
#elif defined _OSDEP_HCI_INTF_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_hci_intfs_c_
|
||||||
|
#elif defined _OSDEP_SERVICE_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_osdep_service_c_
|
||||||
|
#elif defined _HCI_OPS_OS_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_hci_ops_os_c_
|
||||||
|
#elif defined _RTL871X_IOCTL_LINUX_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl871x_ioctl_os_c
|
||||||
|
#elif defined _RTL8712_CMD_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl8712_cmd_c_
|
||||||
|
#elif defined _RTL8192C_XMIT_C_
|
||||||
|
#define _MODULE_DEFINE_ 1
|
||||||
|
#elif defined _RTL8723AS_XMIT_C_
|
||||||
|
#define _MODULE_DEFINE_ 1
|
||||||
|
#elif defined _RTL8712_RECV_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl8712_recv_c_
|
||||||
|
#elif defined _RTL8192CU_RECV_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_rtl8712_recv_c_
|
||||||
|
#elif defined _RTL871X_MLME_EXT_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_mlme_osdep_c_
|
||||||
|
#elif defined _RTW_MP_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_mp_
|
||||||
|
#elif defined _RTW_MP_IOCTL_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_mp_
|
||||||
|
#elif defined _RTW_EFUSE_C_
|
||||||
|
#define _MODULE_DEFINE_ _module_efuse_
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef PLATFORM_OS_CE
|
||||||
|
extern void rtl871x_cedbg(const char *fmt, ...);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define RT_TRACE(_Comp, _Level, Fmt) do{}while(0)
|
||||||
|
#define _func_enter_ do{}while(0)
|
||||||
|
#define _func_exit_ do{}while(0)
|
||||||
|
#define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen) do{}while(0)
|
||||||
|
|
||||||
|
#ifdef PLATFORM_WINDOWS
|
||||||
|
#define DBG_871X do {} while(0)
|
||||||
|
#define MSG_8192C do {} while(0)
|
||||||
|
#define DBG_8192C do {} while(0)
|
||||||
|
#define DBG_871X_LEVEL do {} while(0)
|
||||||
|
#else
|
||||||
|
#define DBG_871X(x, ...) do {} while(0)
|
||||||
|
#define MSG_8192C(x, ...) do {} while(0)
|
||||||
|
#define DBG_8192C(x,...) do {} while(0)
|
||||||
|
#define DBG_871X_LEVEL(x,...) do {} while(0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#undef _dbgdump
|
||||||
|
#ifdef PLATFORM_WINDOWS
|
||||||
|
|
||||||
|
#ifdef PLATFORM_OS_XP
|
||||||
|
#define _dbgdump DbgPrint
|
||||||
|
#elif defined PLATFORM_OS_CE
|
||||||
|
#define _dbgdump rtl871x_cedbg
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#elif defined PLATFORM_LINUX
|
||||||
|
#define _dbgdump printk
|
||||||
|
#elif defined PLATFORM_ECOS
|
||||||
|
#define _dbgdump diag_printf
|
||||||
|
#elif defined PLATFORM_FREERTOS
|
||||||
|
#define _dbgdump printf("\n\r"); printf
|
||||||
|
#elif defined PLATFORM_FREEBSD
|
||||||
|
#define _dbgdump printf
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if !defined(CONFIG_PLATFORM_8195A) && !defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define DRIVER_PREFIX "RTL871X: "
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define DEBUG_LEVEL (_drv_err_)
|
||||||
|
#if defined (_dbgdump)
|
||||||
|
#undef DBG_871X_LEVEL
|
||||||
|
#if defined (__ICCARM__) || defined (__CC_ARM) || defined(CONFIG_PLATFORM_8195A) || defined(CONFIG_PLATFORM_8711B)
|
||||||
|
#define DBG_871X_LEVEL(level, ...) \
|
||||||
|
do {\
|
||||||
|
_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
|
||||||
|
}while(0)
|
||||||
|
#else
|
||||||
|
#define DBG_871X_LEVEL(level, fmt, arg...) \
|
||||||
|
do {\
|
||||||
|
if (level <= DEBUG_LEVEL) {\
|
||||||
|
if (level <= _drv_err_ && level > _drv_always_) {\
|
||||||
|
_dbgdump(DRIVER_PREFIX"ERROR " fmt, ##arg);\
|
||||||
|
} \
|
||||||
|
else {\
|
||||||
|
_dbgdump(DRIVER_PREFIX fmt, ##arg);\
|
||||||
|
} \
|
||||||
|
}\
|
||||||
|
}while(0)
|
||||||
|
#endif //#ifdef __CC_ARM
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_DEBUG
|
||||||
|
#if defined (_dbgdump)
|
||||||
|
#undef DBG_871X
|
||||||
|
#define DBG_871X(...) do {\
|
||||||
|
_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
|
||||||
|
}while(0)
|
||||||
|
|
||||||
|
#undef MSG_8192C
|
||||||
|
#define MSG_8192C(...) do {\
|
||||||
|
_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
|
||||||
|
}while(0)
|
||||||
|
|
||||||
|
#undef DBG_8192C
|
||||||
|
#define DBG_8192C(...) do {\
|
||||||
|
_dbgdump(DRIVER_PREFIX __VA_ARGS__);\
|
||||||
|
}while(0)
|
||||||
|
#endif
|
||||||
|
#endif /* CONFIG_DEBUG */
|
||||||
|
|
||||||
|
#ifdef CONFIG_DEBUG_RTL871X
|
||||||
|
#ifndef _RTL871X_DEBUG_C_
|
||||||
|
extern u32 GlobalDebugLevel;
|
||||||
|
extern u64 GlobalDebugComponents;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined (_dbgdump) && defined (_MODULE_DEFINE_)
|
||||||
|
|
||||||
|
#undef RT_TRACE
|
||||||
|
#define RT_TRACE(_Comp, _Level, Fmt)\
|
||||||
|
do {\
|
||||||
|
if((_Comp & GlobalDebugComponents) && (_Level <= GlobalDebugLevel)) {\
|
||||||
|
_dbgdump("%s [0x%08x,%d]", DRIVER_PREFIX, (unsigned int)_Comp, _Level);\
|
||||||
|
_dbgdump Fmt;\
|
||||||
|
}\
|
||||||
|
}while(0)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
#if defined (_dbgdump)
|
||||||
|
|
||||||
|
#undef _func_enter_
|
||||||
|
#define _func_enter_ \
|
||||||
|
do { \
|
||||||
|
if (GlobalDebugLevel >= _drv_debug_) \
|
||||||
|
{ \
|
||||||
|
_dbgdump("\n %s : %s enters at %d\n", DRIVER_PREFIX, __FUNCTION__, __LINE__);\
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#undef _func_exit_
|
||||||
|
#define _func_exit_ \
|
||||||
|
do { \
|
||||||
|
if (GlobalDebugLevel >= _drv_debug_) \
|
||||||
|
{ \
|
||||||
|
_dbgdump("\n %s : %s exits at %d\n", DRIVER_PREFIX, __FUNCTION__, __LINE__); \
|
||||||
|
} \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#undef RT_PRINT_DATA
|
||||||
|
#define RT_PRINT_DATA(_Comp, _Level, _TitleString, _HexData, _HexDataLen) \
|
||||||
|
if(((_Comp) & GlobalDebugComponents) && (_Level <= GlobalDebugLevel)) \
|
||||||
|
{ \
|
||||||
|
int __i; \
|
||||||
|
u8 *ptr = (u8 *)_HexData; \
|
||||||
|
printf("\r\n%s", DRIVER_PREFIX); \
|
||||||
|
printf(_TitleString "--------Len=%d\n\r", _HexDataLen); \
|
||||||
|
for( __i=0; __i<(int)_HexDataLen; __i++ ) \
|
||||||
|
{ \
|
||||||
|
printf("%02X%s", ptr[__i], (((__i + 1) % 4) == 0)?" ":" "); \
|
||||||
|
if (((__i + 1) % 16) == 0) printf("\n\r"); \
|
||||||
|
} \
|
||||||
|
printf("\n\r"); \
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* CONFIG_DEBUG_RTL871X */
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef CONFIG_PROC_DEBUG
|
||||||
|
|
||||||
|
int proc_get_drv_version(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_write_reg(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_write_reg(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
|
||||||
|
int proc_get_read_reg(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_read_reg(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
|
||||||
|
|
||||||
|
int proc_get_fwstate(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_sec_info(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_mlmext_state(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_qos_option(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_ht_option(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rf_info(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_ap_info(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_adapter_state(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_trx_info(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_mac_reg_dump1(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_mac_reg_dump2(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_mac_reg_dump3(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_bb_reg_dump1(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_bb_reg_dump2(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_bb_reg_dump3(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rf_reg_dump1(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rf_reg_dump2(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rf_reg_dump3(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rf_reg_dump4(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
#ifdef CONFIG_AP_MODE
|
||||||
|
|
||||||
|
int proc_get_all_sta_info(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef DBG_MEMORY_LEAK
|
||||||
|
int proc_get_malloc_cnt(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_FIND_BEST_CHANNEL
|
||||||
|
int proc_get_best_channel(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int proc_get_rx_signal(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_rx_signal(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
#ifdef CONFIG_80211N_HT
|
||||||
|
int proc_get_cbw40_enable(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_cbw40_enable(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
|
||||||
|
int proc_get_ampdu_enable(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_ampdu_enable(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
|
||||||
|
int proc_get_rx_stbc(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_rx_stbc(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
#endif //CONFIG_80211N_HT
|
||||||
|
|
||||||
|
int proc_get_two_path_rssi(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_get_rssi_disp(char *page, char **start,
|
||||||
|
off_t offset, int count,
|
||||||
|
int *eof, void *data);
|
||||||
|
|
||||||
|
int proc_set_rssi_disp(struct file *file, const char *buffer,
|
||||||
|
unsigned long count, void *data);
|
||||||
|
|
||||||
|
|
||||||
|
#endif //CONFIG_PROC_DEBUG
|
||||||
|
|
||||||
|
#endif //__RTW_DEBUG_H__
|
||||||
|
|
432
component/common/drivers/wlan/realtek/include/wifi_constants.h
Executable file
432
component/common/drivers/wlan/realtek/include/wifi_constants.h
Executable file
|
@ -0,0 +1,432 @@
|
||||||
|
#ifndef _WIFI_CONSTANTS_H
|
||||||
|
#define _WIFI_CONSTANTS_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define WEP_ENABLED 0x0001
|
||||||
|
#define TKIP_ENABLED 0x0002
|
||||||
|
#define AES_ENABLED 0x0004
|
||||||
|
#define WSEC_SWFLAG 0x0008
|
||||||
|
|
||||||
|
#define SHARED_ENABLED 0x00008000
|
||||||
|
#define WPA_SECURITY 0x00200000
|
||||||
|
#define WPA2_SECURITY 0x00400000
|
||||||
|
#define WPS_ENABLED 0x10000000
|
||||||
|
|
||||||
|
#define RTW_MAX_PSK_LEN (64)
|
||||||
|
#define RTW_MIN_PSK_LEN (8)
|
||||||
|
|
||||||
|
#define MCSSET_LEN 16
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
RTW_SUCCESS = 0, /**< Success */
|
||||||
|
RTW_PENDING = 1, /**< Pending */
|
||||||
|
RTW_TIMEOUT = 2, /**< Timeout */
|
||||||
|
RTW_PARTIAL_RESULTS = 3, /**< Partial results */
|
||||||
|
RTW_INVALID_KEY = 4, /**< Invalid key */
|
||||||
|
RTW_DOES_NOT_EXIST = 5, /**< Does not exist */
|
||||||
|
RTW_NOT_AUTHENTICATED = 6, /**< Not authenticated */
|
||||||
|
RTW_NOT_KEYED = 7, /**< Not keyed */
|
||||||
|
RTW_IOCTL_FAIL = 8, /**< IOCTL fail */
|
||||||
|
RTW_BUFFER_UNAVAILABLE_TEMPORARY = 9, /**< Buffer unavailable temporarily */
|
||||||
|
RTW_BUFFER_UNAVAILABLE_PERMANENT = 10, /**< Buffer unavailable permanently */
|
||||||
|
RTW_WPS_PBC_OVERLAP = 11, /**< WPS PBC overlap */
|
||||||
|
RTW_CONNECTION_LOST = 12, /**< Connection lost */
|
||||||
|
|
||||||
|
RTW_ERROR = -1, /**< Generic Error */
|
||||||
|
RTW_BADARG = -2, /**< Bad Argument */
|
||||||
|
RTW_BADOPTION = -3, /**< Bad option */
|
||||||
|
RTW_NOTUP = -4, /**< Not up */
|
||||||
|
RTW_NOTDOWN = -5, /**< Not down */
|
||||||
|
RTW_NOTAP = -6, /**< Not AP */
|
||||||
|
RTW_NOTSTA = -7, /**< Not STA */
|
||||||
|
RTW_BADKEYIDX = -8, /**< BAD Key Index */
|
||||||
|
RTW_RADIOOFF = -9, /**< Radio Off */
|
||||||
|
RTW_NOTBANDLOCKED = -10, /**< Not band locked */
|
||||||
|
RTW_NOCLK = -11, /**< No Clock */
|
||||||
|
RTW_BADRATESET = -12, /**< BAD Rate valueset */
|
||||||
|
RTW_BADBAND = -13, /**< BAD Band */
|
||||||
|
RTW_BUFTOOSHORT = -14, /**< Buffer too short */
|
||||||
|
RTW_BUFTOOLONG = -15, /**< Buffer too long */
|
||||||
|
RTW_BUSY = -16, /**< Busy */
|
||||||
|
RTW_NOTASSOCIATED = -17, /**< Not Associated */
|
||||||
|
RTW_BADSSIDLEN = -18, /**< Bad SSID len */
|
||||||
|
RTW_OUTOFRANGECHAN = -19, /**< Out of Range Channel */
|
||||||
|
RTW_BADCHAN = -20, /**< Bad Channel */
|
||||||
|
RTW_BADADDR = -21, /**< Bad Address */
|
||||||
|
RTW_NORESOURCE = -22, /**< Not Enough Resources */
|
||||||
|
RTW_UNSUPPORTED = -23, /**< Unsupported */
|
||||||
|
RTW_BADLEN = -24, /**< Bad length */
|
||||||
|
RTW_NOTREADY = -25, /**< Not Ready */
|
||||||
|
RTW_EPERM = -26, /**< Not Permitted */
|
||||||
|
RTW_NOMEM = -27, /**< No Memory */
|
||||||
|
RTW_ASSOCIATED = -28, /**< Associated */
|
||||||
|
RTW_RANGE = -29, /**< Not In Range */
|
||||||
|
RTW_NOTFOUND = -30, /**< Not Found */
|
||||||
|
RTW_WME_NOT_ENABLED = -31, /**< WME Not Enabled */
|
||||||
|
RTW_TSPEC_NOTFOUND = -32, /**< TSPEC Not Found */
|
||||||
|
RTW_ACM_NOTSUPPORTED = -33, /**< ACM Not Supported */
|
||||||
|
RTW_NOT_WME_ASSOCIATION = -34, /**< Not WME Association */
|
||||||
|
RTW_SDIO_ERROR = -35, /**< SDIO Bus Error */
|
||||||
|
RTW_WLAN_DOWN = -36, /**< WLAN Not Accessible */
|
||||||
|
RTW_BAD_VERSION = -37, /**< Incorrect version */
|
||||||
|
RTW_TXFAIL = -38, /**< TX failure */
|
||||||
|
RTW_RXFAIL = -39, /**< RX failure */
|
||||||
|
RTW_NODEVICE = -40, /**< Device not present */
|
||||||
|
RTW_UNFINISHED = -41, /**< To be finished */
|
||||||
|
RTW_NONRESIDENT = -42, /**< access to nonresident overlay */
|
||||||
|
RTW_DISABLED = -43 /**< Disabled in this build */
|
||||||
|
} rtw_result_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_SECURITY_OPEN = 0, /**< Open security */
|
||||||
|
RTW_SECURITY_WEP_PSK = WEP_ENABLED, /**< WEP Security with open authentication */
|
||||||
|
RTW_SECURITY_WEP_SHARED = ( WEP_ENABLED | SHARED_ENABLED ), /**< WEP Security with shared authentication */
|
||||||
|
RTW_SECURITY_WPA_TKIP_PSK = ( WPA_SECURITY | TKIP_ENABLED ), /**< WPA Security with TKIP */
|
||||||
|
RTW_SECURITY_WPA_AES_PSK = ( WPA_SECURITY | AES_ENABLED ), /**< WPA Security with AES */
|
||||||
|
RTW_SECURITY_WPA2_AES_PSK = ( WPA2_SECURITY | AES_ENABLED ), /**< WPA2 Security with AES */
|
||||||
|
RTW_SECURITY_WPA2_TKIP_PSK = ( WPA2_SECURITY | TKIP_ENABLED ), /**< WPA2 Security with TKIP */
|
||||||
|
RTW_SECURITY_WPA2_MIXED_PSK = ( WPA2_SECURITY | AES_ENABLED | TKIP_ENABLED ), /**< WPA2 Security with AES & TKIP */
|
||||||
|
RTW_SECURITY_WPA_WPA2_MIXED = ( WPA_SECURITY | WPA2_SECURITY ), /**< WPA/WPA2 Security */
|
||||||
|
|
||||||
|
RTW_SECURITY_WPS_OPEN = WPS_ENABLED, /**< WPS with open security */
|
||||||
|
RTW_SECURITY_WPS_SECURE = (WPS_ENABLED | AES_ENABLED), /**< WPS with AES security */
|
||||||
|
|
||||||
|
RTW_SECURITY_UNKNOWN = -1, /**< May be returned by scan function if security is unknown. Do not pass this to the join function! */
|
||||||
|
|
||||||
|
RTW_SECURITY_FORCE_32_BIT = 0x7fffffff /**< Exists only to force rtw_security_t type to 32 bits */
|
||||||
|
} rtw_security_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_ENCRYPTION_UNKNOWN = 0,
|
||||||
|
RTW_ENCRYPTION_OPEN = 1,
|
||||||
|
RTW_ENCRYPTION_WEP40 = 2,
|
||||||
|
RTW_ENCRYPTION_WPA_TKIP = 3,
|
||||||
|
RTW_ENCRYPTION_WPA_AES = 4,
|
||||||
|
RTW_ENCRYPTION_WPA2_TKIP = 5,
|
||||||
|
RTW_ENCRYPTION_WPA2_AES = 6,
|
||||||
|
RTW_ENCRYPTION_WPA2_MIXED = 7,
|
||||||
|
RTW_ENCRYPTION_WEP104 = 9,
|
||||||
|
RTW_ENCRYPTION_UNDEF = 0xFF,
|
||||||
|
} rtw_encryption_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_FALSE = 0,
|
||||||
|
RTW_TRUE = 1
|
||||||
|
} rtw_bool_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_802_11_BAND_5GHZ = 0, /**< Denotes 5GHz radio band */
|
||||||
|
RTW_802_11_BAND_2_4GHZ = 1 /**< Denotes 2.4GHz radio band */
|
||||||
|
} rtw_802_11_band_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
|
||||||
|
|
||||||
|
/* SPECIAL */
|
||||||
|
RTW_COUNTRY_WORLD,
|
||||||
|
RTW_COUNTRY_EU,
|
||||||
|
|
||||||
|
/* JAPANESE */
|
||||||
|
RTW_COUNTRY_JP,
|
||||||
|
|
||||||
|
/* FCC , 19 countries*/
|
||||||
|
RTW_COUNTRY_AS,
|
||||||
|
RTW_COUNTRY_BM,
|
||||||
|
RTW_COUNTRY_CA,
|
||||||
|
RTW_COUNTRY_DM,
|
||||||
|
RTW_COUNTRY_DO,
|
||||||
|
RTW_COUNTRY_FM,
|
||||||
|
RTW_COUNTRY_GD,
|
||||||
|
RTW_COUNTRY_GT,
|
||||||
|
RTW_COUNTRY_GU,
|
||||||
|
RTW_COUNTRY_HT,
|
||||||
|
RTW_COUNTRY_MH,
|
||||||
|
RTW_COUNTRY_MP,
|
||||||
|
RTW_COUNTRY_NI,
|
||||||
|
RTW_COUNTRY_PA,
|
||||||
|
RTW_COUNTRY_PR,
|
||||||
|
RTW_COUNTRY_PW,
|
||||||
|
RTW_COUNTRY_TW,
|
||||||
|
RTW_COUNTRY_US,
|
||||||
|
RTW_COUNTRY_VI,
|
||||||
|
|
||||||
|
/* others, ETSI */
|
||||||
|
RTW_COUNTRY_AD,
|
||||||
|
RTW_COUNTRY_AE,
|
||||||
|
RTW_COUNTRY_AF,
|
||||||
|
RTW_COUNTRY_AI,
|
||||||
|
RTW_COUNTRY_AL,
|
||||||
|
RTW_COUNTRY_AM,
|
||||||
|
RTW_COUNTRY_AN,
|
||||||
|
RTW_COUNTRY_AR,
|
||||||
|
RTW_COUNTRY_AT,
|
||||||
|
RTW_COUNTRY_AU,
|
||||||
|
RTW_COUNTRY_AW,
|
||||||
|
RTW_COUNTRY_AZ,
|
||||||
|
RTW_COUNTRY_BA,
|
||||||
|
RTW_COUNTRY_BB,
|
||||||
|
RTW_COUNTRY_BD,
|
||||||
|
RTW_COUNTRY_BE,
|
||||||
|
RTW_COUNTRY_BF,
|
||||||
|
RTW_COUNTRY_BG,
|
||||||
|
RTW_COUNTRY_BH,
|
||||||
|
RTW_COUNTRY_BL,
|
||||||
|
RTW_COUNTRY_BN,
|
||||||
|
RTW_COUNTRY_BO,
|
||||||
|
RTW_COUNTRY_BR,
|
||||||
|
RTW_COUNTRY_BS,
|
||||||
|
RTW_COUNTRY_BT,
|
||||||
|
RTW_COUNTRY_BY,
|
||||||
|
RTW_COUNTRY_BZ,
|
||||||
|
RTW_COUNTRY_CF,
|
||||||
|
RTW_COUNTRY_CH,
|
||||||
|
RTW_COUNTRY_CI,
|
||||||
|
RTW_COUNTRY_CL,
|
||||||
|
RTW_COUNTRY_CN,
|
||||||
|
RTW_COUNTRY_CO,
|
||||||
|
RTW_COUNTRY_CR,
|
||||||
|
RTW_COUNTRY_CX,
|
||||||
|
RTW_COUNTRY_CY,
|
||||||
|
RTW_COUNTRY_CZ,
|
||||||
|
RTW_COUNTRY_DE,
|
||||||
|
RTW_COUNTRY_DK,
|
||||||
|
RTW_COUNTRY_DZ,
|
||||||
|
RTW_COUNTRY_EC,
|
||||||
|
RTW_COUNTRY_EE,
|
||||||
|
RTW_COUNTRY_EG,
|
||||||
|
RTW_COUNTRY_ES,
|
||||||
|
RTW_COUNTRY_ET,
|
||||||
|
RTW_COUNTRY_FI,
|
||||||
|
RTW_COUNTRY_FR,
|
||||||
|
RTW_COUNTRY_GB,
|
||||||
|
RTW_COUNTRY_GE,
|
||||||
|
RTW_COUNTRY_GF,
|
||||||
|
RTW_COUNTRY_GH,
|
||||||
|
RTW_COUNTRY_GL,
|
||||||
|
RTW_COUNTRY_GP,
|
||||||
|
RTW_COUNTRY_GR,
|
||||||
|
RTW_COUNTRY_GY,
|
||||||
|
RTW_COUNTRY_HK,
|
||||||
|
RTW_COUNTRY_HN,
|
||||||
|
RTW_COUNTRY_HR,
|
||||||
|
RTW_COUNTRY_HU,
|
||||||
|
RTW_COUNTRY_ID,
|
||||||
|
RTW_COUNTRY_IE,
|
||||||
|
RTW_COUNTRY_IL,
|
||||||
|
RTW_COUNTRY_IN,
|
||||||
|
RTW_COUNTRY_IQ,
|
||||||
|
RTW_COUNTRY_IR,
|
||||||
|
RTW_COUNTRY_IS,
|
||||||
|
RTW_COUNTRY_IT,
|
||||||
|
RTW_COUNTRY_JM,
|
||||||
|
RTW_COUNTRY_JO,
|
||||||
|
RTW_COUNTRY_KE,
|
||||||
|
RTW_COUNTRY_KH,
|
||||||
|
RTW_COUNTRY_KN,
|
||||||
|
RTW_COUNTRY_KP,
|
||||||
|
RTW_COUNTRY_KR,
|
||||||
|
RTW_COUNTRY_KW,
|
||||||
|
RTW_COUNTRY_KY,
|
||||||
|
RTW_COUNTRY_KZ,
|
||||||
|
RTW_COUNTRY_LA,
|
||||||
|
RTW_COUNTRY_LB,
|
||||||
|
RTW_COUNTRY_LC,
|
||||||
|
RTW_COUNTRY_LI,
|
||||||
|
RTW_COUNTRY_LK,
|
||||||
|
RTW_COUNTRY_LR,
|
||||||
|
RTW_COUNTRY_LS,
|
||||||
|
RTW_COUNTRY_LT,
|
||||||
|
RTW_COUNTRY_LU,
|
||||||
|
RTW_COUNTRY_LV,
|
||||||
|
RTW_COUNTRY_MA,
|
||||||
|
RTW_COUNTRY_MC,
|
||||||
|
RTW_COUNTRY_MD,
|
||||||
|
RTW_COUNTRY_ME,
|
||||||
|
RTW_COUNTRY_MF,
|
||||||
|
RTW_COUNTRY_MK,
|
||||||
|
RTW_COUNTRY_MN,
|
||||||
|
RTW_COUNTRY_MO,
|
||||||
|
RTW_COUNTRY_MQ,
|
||||||
|
RTW_COUNTRY_MR,
|
||||||
|
RTW_COUNTRY_MT,
|
||||||
|
RTW_COUNTRY_MU,
|
||||||
|
RTW_COUNTRY_MV,
|
||||||
|
RTW_COUNTRY_MW,
|
||||||
|
RTW_COUNTRY_MX,
|
||||||
|
RTW_COUNTRY_MY,
|
||||||
|
RTW_COUNTRY_NG,
|
||||||
|
RTW_COUNTRY_NL,
|
||||||
|
RTW_COUNTRY_NO,
|
||||||
|
RTW_COUNTRY_NP,
|
||||||
|
RTW_COUNTRY_NZ,
|
||||||
|
RTW_COUNTRY_OM,
|
||||||
|
RTW_COUNTRY_PE,
|
||||||
|
RTW_COUNTRY_PF,
|
||||||
|
RTW_COUNTRY_PG,
|
||||||
|
RTW_COUNTRY_PH,
|
||||||
|
RTW_COUNTRY_PK,
|
||||||
|
RTW_COUNTRY_PL,
|
||||||
|
RTW_COUNTRY_PM,
|
||||||
|
RTW_COUNTRY_PT,
|
||||||
|
RTW_COUNTRY_PY,
|
||||||
|
RTW_COUNTRY_QA,
|
||||||
|
RTW_COUNTRY_RS,
|
||||||
|
RTW_COUNTRY_RU,
|
||||||
|
RTW_COUNTRY_RW,
|
||||||
|
RTW_COUNTRY_SA,
|
||||||
|
RTW_COUNTRY_SE,
|
||||||
|
RTW_COUNTRY_SG,
|
||||||
|
RTW_COUNTRY_SI,
|
||||||
|
RTW_COUNTRY_SK,
|
||||||
|
RTW_COUNTRY_SN,
|
||||||
|
RTW_COUNTRY_SR,
|
||||||
|
RTW_COUNTRY_SV,
|
||||||
|
RTW_COUNTRY_SY,
|
||||||
|
RTW_COUNTRY_TC,
|
||||||
|
RTW_COUNTRY_TD,
|
||||||
|
RTW_COUNTRY_TG,
|
||||||
|
RTW_COUNTRY_TH,
|
||||||
|
RTW_COUNTRY_TN,
|
||||||
|
RTW_COUNTRY_TR,
|
||||||
|
RTW_COUNTRY_TT,
|
||||||
|
RTW_COUNTRY_TZ,
|
||||||
|
RTW_COUNTRY_UA,
|
||||||
|
RTW_COUNTRY_UG,
|
||||||
|
RTW_COUNTRY_UY,
|
||||||
|
RTW_COUNTRY_UZ,
|
||||||
|
RTW_COUNTRY_VC,
|
||||||
|
RTW_COUNTRY_VE,
|
||||||
|
RTW_COUNTRY_VN,
|
||||||
|
RTW_COUNTRY_VU,
|
||||||
|
RTW_COUNTRY_WF,
|
||||||
|
RTW_COUNTRY_WS,
|
||||||
|
RTW_COUNTRY_YE,
|
||||||
|
RTW_COUNTRY_YT,
|
||||||
|
RTW_COUNTRY_ZA,
|
||||||
|
RTW_COUNTRY_ZW,
|
||||||
|
|
||||||
|
RTW_COUNTRY_MAX
|
||||||
|
|
||||||
|
}rtw_country_code_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_ADAPTIVITY_DISABLE = 0,
|
||||||
|
RTW_ADAPTIVITY_NORMAL, // CE
|
||||||
|
RTW_ADAPTIVITY_CARRIER_SENSE // MKK
|
||||||
|
} rtw_adaptivity_mode_t;
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_MODE_NONE = 0,
|
||||||
|
RTW_MODE_STA,
|
||||||
|
RTW_MODE_AP,
|
||||||
|
RTW_MODE_STA_AP,
|
||||||
|
RTW_MODE_PROMISC,
|
||||||
|
RTW_MODE_P2P
|
||||||
|
}rtw_mode_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_SCAN_FULL = 0,
|
||||||
|
RTW_SCAN_SOCIAL,
|
||||||
|
RTW_SCAN_ONE
|
||||||
|
}rtw_scan_mode_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_LINK_DISCONNECTED = 0,
|
||||||
|
RTW_LINK_CONNECTED
|
||||||
|
} rtw_link_status_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_SCAN_TYPE_ACTIVE = 0x00, /**< Actively scan a network by sending 802.11 probe(s) */
|
||||||
|
RTW_SCAN_TYPE_PASSIVE = 0x01, /**< Passively scan a network by listening for beacons from APs */
|
||||||
|
RTW_SCAN_TYPE_PROHIBITED_CHANNELS = 0x04 /**< Passively scan on channels not enabled by the country code */
|
||||||
|
} rtw_scan_type_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_BSS_TYPE_INFRASTRUCTURE = 0, /**< Denotes infrastructure network */
|
||||||
|
RTW_BSS_TYPE_ADHOC = 1, /**< Denotes an 802.11 ad-hoc IBSS network */
|
||||||
|
RTW_BSS_TYPE_ANY = 2, /**< Denotes either infrastructure or ad-hoc network */
|
||||||
|
|
||||||
|
RTW_BSS_TYPE_UNKNOWN = -1 /**< May be returned by scan function if BSS type is unknown. Do not pass this to the Join function */
|
||||||
|
} rtw_bss_type_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_SCAN_COMMAMD = 0x01
|
||||||
|
} rtw_scan_command_t;
|
||||||
|
|
||||||
|
typedef enum{
|
||||||
|
COMMAND1 = 0x01
|
||||||
|
}rtw_command_type;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_WPS_TYPE_DEFAULT = 0x0000,
|
||||||
|
RTW_WPS_TYPE_USER_SPECIFIED = 0x0001,
|
||||||
|
RTW_WPS_TYPE_MACHINE_SPECIFIED = 0x0002,
|
||||||
|
RTW_WPS_TYPE_REKEY = 0x0003,
|
||||||
|
RTW_WPS_TYPE_PUSHBUTTON = 0x0004,
|
||||||
|
RTW_WPS_TYPE_REGISTRAR_SPECIFIED = 0x0005,
|
||||||
|
RTW_WPS_TYPE_NONE = 0x0006
|
||||||
|
} rtw_wps_type_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_NETWORK_B = 1,
|
||||||
|
RTW_NETWORK_BG = 3,
|
||||||
|
RTW_NETWORK_BGN = 11
|
||||||
|
} rtw_network_mode_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_STA_INTERFACE = 0, /**< STA or Client Interface */
|
||||||
|
RTW_AP_INTERFACE = 1, /**< softAP Interface */
|
||||||
|
} rtw_interface_t;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Enumeration of packet filter rules
|
||||||
|
*/
|
||||||
|
typedef enum {
|
||||||
|
RTW_POSITIVE_MATCHING = 0, /**< Specifies that a filter should match a given pattern */
|
||||||
|
RTW_NEGATIVE_MATCHING = 1 /**< Specifies that a filter should NOT match a given pattern */
|
||||||
|
} rtw_packet_filter_rule_e;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RTW_PROMISC_DISABLE = 0, /**< disable the promisc */
|
||||||
|
RTW_PROMISC_ENABLE = 1, /**< fetch all ethernet packets */
|
||||||
|
RTW_PROMISC_ENABLE_1 = 2, /**< fetch only B/M packets */
|
||||||
|
RTW_PROMISC_ENABLE_2 = 3, /**< fetch all 802.11 packets*/
|
||||||
|
RTW_PROMISC_ENABLE_3 = 4, /**< fetch only B/M 802.11 packets*/
|
||||||
|
} rtw_rcr_level_t;
|
||||||
|
|
||||||
|
typedef enum{
|
||||||
|
RTW_NO_ERROR = 0,
|
||||||
|
RTW_NONE_NETWORK = 1,
|
||||||
|
RTW_CONNECT_FAIL = 2,
|
||||||
|
RTW_WRONG_PASSWORD = 3 ,
|
||||||
|
RTW_DHCP_FAIL = 4,
|
||||||
|
RTW_UNKNOWN,
|
||||||
|
}rtw_connect_error_flag_t;
|
||||||
|
|
||||||
|
typedef enum _WIFI_EVENT_INDICATE{
|
||||||
|
WIFI_EVENT_CONNECT = 0,
|
||||||
|
WIFI_EVENT_DISCONNECT = 1,
|
||||||
|
WIFI_EVENT_FOURWAY_HANDSHAKE_DONE = 2,
|
||||||
|
WIFI_EVENT_SCAN_RESULT_REPORT = 3,
|
||||||
|
WIFI_EVENT_SCAN_DONE = 4,
|
||||||
|
WIFI_EVENT_RECONNECTION_FAIL = 5,
|
||||||
|
WIFI_EVENT_SEND_ACTION_DONE = 6,
|
||||||
|
WIFI_EVENT_RX_MGNT = 7,
|
||||||
|
WIFI_EVENT_STA_ASSOC = 8,
|
||||||
|
WIFI_EVENT_STA_DISASSOC = 9,
|
||||||
|
WIFI_EVENT_WPS_FINISH = 10,
|
||||||
|
WIFI_EVENT_EAPOL_RECVD = 11,
|
||||||
|
WIFI_EVENT_NO_NETWORK = 12,
|
||||||
|
WIFI_EVENT_BEACON_AFTER_DHCP = 13,
|
||||||
|
WIFI_EVENT_DHCP_ASSIGNED = 14,
|
||||||
|
WIFI_EVENT_MAX,
|
||||||
|
}WIFI_EVENT_INDICATE;
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* _WIFI_CONSTANTS_H */
|
159
component/common/drivers/wlan/realtek/include/wifi_structures.h
Executable file
159
component/common/drivers/wlan/realtek/include/wifi_structures.h
Executable file
|
@ -0,0 +1,159 @@
|
||||||
|
#ifndef _WIFI_STRUCTURES_H
|
||||||
|
#define _WIFI_STRUCTURES_H
|
||||||
|
|
||||||
|
//#include <freertos/freertos_service.h>
|
||||||
|
#include "wifi_constants.h"
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack(1)
|
||||||
|
#endif
|
||||||
|
typedef struct rtw_ssid {
|
||||||
|
unsigned char len; /**< SSID length */
|
||||||
|
unsigned char val[33]; /**< SSID name (AP name) */
|
||||||
|
} rtw_ssid_t;
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack(1)
|
||||||
|
#endif
|
||||||
|
typedef struct rtw_mac {
|
||||||
|
unsigned char octet[6]; /**< Unique 6-byte MAC address */
|
||||||
|
} rtw_mac_t;
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct rtw_ap_info {
|
||||||
|
rtw_ssid_t ssid;
|
||||||
|
rtw_security_t security_type;
|
||||||
|
unsigned char *password;
|
||||||
|
int password_len;
|
||||||
|
int channel;
|
||||||
|
}rtw_ap_info_t;
|
||||||
|
|
||||||
|
typedef struct rtw_network_info {
|
||||||
|
rtw_ssid_t ssid;
|
||||||
|
rtw_mac_t bssid;
|
||||||
|
rtw_security_t security_type;
|
||||||
|
unsigned char *password;
|
||||||
|
int password_len;
|
||||||
|
int key_id;
|
||||||
|
}rtw_network_info_t;
|
||||||
|
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack(1)
|
||||||
|
#endif
|
||||||
|
typedef struct rtw_scan_result {
|
||||||
|
rtw_ssid_t SSID; /**< Service Set Identification (i.e. Name of Access Point) */
|
||||||
|
rtw_mac_t BSSID; /**< Basic Service Set Identification (i.e. MAC address of Access Point) */
|
||||||
|
signed short signal_strength; /**< Receive Signal Strength Indication in dBm. <-90=Very poor, >-30=Excellent */
|
||||||
|
rtw_bss_type_t bss_type; /**< Network type */
|
||||||
|
rtw_security_t security; /**< Security type */
|
||||||
|
rtw_wps_type_t wps_type; /**< WPS type */
|
||||||
|
unsigned int channel; /**< Radio channel that the AP beacon was received on */
|
||||||
|
rtw_802_11_band_t band; /**< Radio band */
|
||||||
|
} rtw_scan_result_t;
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct rtw_scan_handler_result {
|
||||||
|
rtw_scan_result_t ap_details;
|
||||||
|
rtw_bool_t scan_complete;
|
||||||
|
void* user_data;
|
||||||
|
|
||||||
|
} rtw_scan_handler_result_t;
|
||||||
|
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack(1)
|
||||||
|
#endif
|
||||||
|
typedef struct rtw_wifi_setting {
|
||||||
|
rtw_mode_t mode;
|
||||||
|
unsigned char ssid[33];
|
||||||
|
unsigned char channel;
|
||||||
|
rtw_security_t security_type;
|
||||||
|
unsigned char password[65];
|
||||||
|
unsigned char key_idx;
|
||||||
|
}rtw_wifi_setting_t;
|
||||||
|
#if defined(__IAR_SYSTEMS_ICC__)
|
||||||
|
#pragma pack()
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct rtw_wifi_config {
|
||||||
|
unsigned int boot_mode;
|
||||||
|
unsigned char ssid[32];
|
||||||
|
unsigned char ssid_len;
|
||||||
|
unsigned char security_type;
|
||||||
|
unsigned char password[65];
|
||||||
|
unsigned char password_len;
|
||||||
|
unsigned char channel;
|
||||||
|
} rtw_wifi_config_t;
|
||||||
|
|
||||||
|
typedef struct
|
||||||
|
{
|
||||||
|
unsigned int count; /**< Number of MAC addresses in the list */
|
||||||
|
rtw_mac_t mac_list[1]; /**< Variable length array of MAC addresses */
|
||||||
|
} rtw_maclist_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
unsigned int version; /* version field */
|
||||||
|
unsigned int length; /* byte length of data in this record, */
|
||||||
|
/* starting at version and including IEs */
|
||||||
|
rtw_mac_t BSSID;
|
||||||
|
unsigned short beacon_period; /* units are Kusec */
|
||||||
|
unsigned short capability; /* Capability information */
|
||||||
|
unsigned char SSID_len;
|
||||||
|
unsigned char SSID[32];
|
||||||
|
unsigned char channel;
|
||||||
|
// struct {
|
||||||
|
// uint32_t count; /* # rates in this set */
|
||||||
|
// uint8_t rates[16]; /* rates in 500kbps units w/hi bit set if basic */
|
||||||
|
// } rateset; /* supported rates */
|
||||||
|
// rtw_chanspec_t chanspec; /* chanspec for bss */
|
||||||
|
unsigned short atim_window; /* units are Kusec */
|
||||||
|
unsigned char dtim_period; /* DTIM period */
|
||||||
|
signed short RSSI; /* receive signal strength (in dBm) */
|
||||||
|
|
||||||
|
unsigned char n_cap; /* BSS is 802.11N Capable */
|
||||||
|
unsigned int nbss_cap; /* 802.11N BSS Capabilities (based on HT_CAP_*) */
|
||||||
|
unsigned char basic_mcs[MCSSET_LEN]; /* 802.11N BSS required MCS set */
|
||||||
|
|
||||||
|
unsigned short ie_offset; /* offset at which IEs start, from beginning */
|
||||||
|
unsigned int ie_length; /* byte length of Information Elements */
|
||||||
|
} rtw_bss_info_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
unsigned short offset; /**< Offset in bytes to start filtering (referenced to the start of the ethernet packet) */
|
||||||
|
unsigned short mask_size; /**< Size of the mask in bytes */
|
||||||
|
unsigned char* mask; /**< Pattern mask bytes to be ANDed with the pattern eg. "\xff00" (must be in network byte order) */
|
||||||
|
unsigned char* pattern; /**< Pattern bytes used to filter eg. "\x0800" (must be in network byte order) */
|
||||||
|
} rtw_packet_filter_pattern_t;
|
||||||
|
|
||||||
|
typedef struct ieee80211_frame_info{
|
||||||
|
unsigned short i_fc;
|
||||||
|
unsigned short i_dur;
|
||||||
|
unsigned char i_addr1[6];
|
||||||
|
unsigned char i_addr2[6];
|
||||||
|
unsigned char i_addr3[6];
|
||||||
|
unsigned short i_seq;
|
||||||
|
unsigned char bssid[6];
|
||||||
|
unsigned char encrypt;
|
||||||
|
signed char rssi;
|
||||||
|
}ieee80211_frame_info_t;
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
char filter_id;
|
||||||
|
rtw_packet_filter_pattern_t patt;
|
||||||
|
rtw_packet_filter_rule_e rule;
|
||||||
|
unsigned char enable;
|
||||||
|
}rtw_packet_filter_info_t;
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif /* _WIFI_STRUCTURES_H */
|
435
component/common/drivers/wlan/realtek/src/osdep/freertos/wrapper.h
Executable file
435
component/common/drivers/wlan/realtek/src/osdep/freertos/wrapper.h
Executable file
|
@ -0,0 +1,435 @@
|
||||||
|
#ifndef __WRAPPER_H__
|
||||||
|
#define __WRAPPER_H__
|
||||||
|
/**************************************************************************
|
||||||
|
* Wrapper provide a linux-like interface
|
||||||
|
*
|
||||||
|
* Copyright (c) 2013 Realtek Semiconductor Corp.
|
||||||
|
************************************************************************/
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Include Files
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "wireless.h"
|
||||||
|
#include <skbuff.h>
|
||||||
|
#include "freertos_service.h"
|
||||||
|
|
||||||
|
#ifndef __LIST_H
|
||||||
|
#warning "DLIST_NOT_DEFINE!!!!!!"
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Linled List
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
/*
|
||||||
|
* Simple doubly linked list implementation.
|
||||||
|
*
|
||||||
|
* Some of the internal functions ("__xxx") are useful when
|
||||||
|
* manipulating whole lists rather than single entries, as
|
||||||
|
* sometimes we already know the next/prev entries and we can
|
||||||
|
* generate better code by using them directly rather than
|
||||||
|
* using the generic single-entry routines.
|
||||||
|
*/
|
||||||
|
// struct list_head {
|
||||||
|
// struct list_head *next, *prev;
|
||||||
|
// };
|
||||||
|
|
||||||
|
#define LIST_HEAD_INIT(name) { &(name), &(name) }
|
||||||
|
|
||||||
|
#define INIT_LIST_HEAD(ptr) do { \
|
||||||
|
(ptr)->next = (ptr); (ptr)->prev = (ptr); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Insert a new entry between two known consecutive entries.
|
||||||
|
*
|
||||||
|
* This is only for internal list manipulation where we know
|
||||||
|
* the prev/next entries already!
|
||||||
|
*/
|
||||||
|
static __inline void __list_add(struct list_head * new,
|
||||||
|
struct list_head * prev,
|
||||||
|
struct list_head * next)
|
||||||
|
{
|
||||||
|
next->prev = new;
|
||||||
|
new->next = next;
|
||||||
|
new->prev = prev;
|
||||||
|
prev->next = new;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Delete a list entry by making the prev/next entries
|
||||||
|
* point to each other.
|
||||||
|
*
|
||||||
|
* This is only for internal list manipulation where we know
|
||||||
|
* the prev/next entries already!
|
||||||
|
*/
|
||||||
|
static __inline void __list_del(struct list_head * prev,
|
||||||
|
struct list_head * next)
|
||||||
|
{
|
||||||
|
next->prev = prev;
|
||||||
|
prev->next = next;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_del - deletes entry from list.
|
||||||
|
* @entry: the element to delete from the list.
|
||||||
|
* Note: list_empty on entry does not return true after this, the entry is in an undefined state.
|
||||||
|
*/
|
||||||
|
static __inline void list_del(struct list_head *entry)
|
||||||
|
{
|
||||||
|
__list_del(entry->prev, entry->next);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_del_init - deletes entry from list and reinitialize it.
|
||||||
|
* @entry: the element to delete from the list.
|
||||||
|
*/
|
||||||
|
static __inline void list_del_init(struct list_head *entry)
|
||||||
|
{
|
||||||
|
__list_del(entry->prev, entry->next);
|
||||||
|
INIT_LIST_HEAD(entry);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_empty - tests whether a list is empty
|
||||||
|
* @head: the list to test.
|
||||||
|
*/
|
||||||
|
static __inline int list_empty(struct list_head *head)
|
||||||
|
{
|
||||||
|
return head->next == head;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* list_splice - join two lists
|
||||||
|
* @list: the new list to add.
|
||||||
|
* @head: the place to add it in the first list.
|
||||||
|
*/
|
||||||
|
static __inline void list_splice(struct list_head *list, struct list_head *head)
|
||||||
|
{
|
||||||
|
struct list_head *first = list->next;
|
||||||
|
|
||||||
|
if (first != list) {
|
||||||
|
struct list_head *last = list->prev;
|
||||||
|
struct list_head *at = head->next;
|
||||||
|
|
||||||
|
first->prev = head;
|
||||||
|
head->next = first;
|
||||||
|
|
||||||
|
last->next = at;
|
||||||
|
at->prev = last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void list_add(struct list_head *new, struct list_head *head);
|
||||||
|
void list_add_tail(struct list_head *new, struct list_head *head);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
extern void save_and_cli(void);
|
||||||
|
extern void restore_flags(void);
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// SKB Operation
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
|
||||||
|
#define SMP_CACHE_BYTES 4
|
||||||
|
#define SKB_DATA_ALIGN(X) (((X) + (SMP_CACHE_BYTES - 1)) & ~(SMP_CACHE_BYTES - 1))
|
||||||
|
|
||||||
|
// Consideration for SKB size
|
||||||
|
// Tx: [INTF_CMD][TX_DESC][WLAN_HDR][QoS][IV][SNAP][Data][MIC][ICV][INTF_STATUS]
|
||||||
|
// Since SKB is used to accept ethernet packet from upper layer, SKB length of WLAN_MAX_ETHFRM_LEN
|
||||||
|
// (= 1514) is enough. But since SKB is also used to get spi receive packet, overall buffer space
|
||||||
|
// should be taken into consideration.
|
||||||
|
// RX: [INTF_CMD][RX_DESC][Drv_Info][WLAN_HDR][QoS][IV][SNAP][Data][MIC][ICV][CRC][INTF_STATUS]
|
||||||
|
//
|
||||||
|
// 32: Driver_Info that carry phy related information for each packets. Required only for receive case.
|
||||||
|
// WLAN_MAX_ETHFRM_LEN : May not be required because WLAN_HEADER +SNAP can totally
|
||||||
|
// cover ethernet header. Keep in only for safety.
|
||||||
|
//
|
||||||
|
// **Notes** SDIO requires 512 blocks r/w, so 512*4 = 2048 is required.
|
||||||
|
// 2003/12/26. The value is reduced from 2048 to 1658 for GSPI
|
||||||
|
// 2014/02/05. The value is 1650 for 8195A LX_BUS
|
||||||
|
#define SKB_RESERVED_FOR_SAFETY 0
|
||||||
|
#define SKB_WLAN_TX_EXTRA_LEN (TXDESC_SIZE + WLAN_HDR_A4_QOS_LEN + WLAN_MAX_IV_LEN + WLAN_SNAP_HEADER - WLAN_ETHHDR_LEN)
|
||||||
|
#define RX_DRIVER_INFO 32
|
||||||
|
|
||||||
|
#if (defined CONFIG_GSPI_HCI || defined CONFIG_SDIO_HCI)
|
||||||
|
#define HAL_INTERFACE_OVERHEAD_SKB_DATA 12 //HAL_INTERFACE_CMD (4) + HAL_INTERFACE_STATUS (8)
|
||||||
|
#elif defined(CONFIG_LX_HCI)
|
||||||
|
#define HAL_INTERFACE_OVERHEAD_SKB_DATA 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined CONFIG_GSPI_HCI || defined CONFIG_SDIO_HCI || defined(CONFIG_LX_HCI)
|
||||||
|
#if defined(CONFIG_RTL8195A) || defined(CONFIG_RTL8711B)
|
||||||
|
#if defined(CONFIG_MP_INCLUDED)
|
||||||
|
#ifdef CONFIG_DONT_CARE_TP
|
||||||
|
#define MAX_RX_PKT_LIMIT ((WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_RX_ETHFRM_LEN + 511) / 512) // 4, for lxbus
|
||||||
|
#else
|
||||||
|
#define MAX_RX_PKT_LIMIT ((WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_ETHFRM_LEN + 511) / 512) // 4, for lxbus
|
||||||
|
#endif
|
||||||
|
#define MAX_RX_PKT_SIZE MAX_RX_PKT_LIMIT*512 // MAX_SKB_BUF_SIZE = 0+32+40+512*4+0 = 2120
|
||||||
|
#else
|
||||||
|
#ifdef CONFIG_DONT_CARE_TP
|
||||||
|
#define MAX_RX_PKT_SIZE WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_RX_ETHFRM_LEN
|
||||||
|
#else
|
||||||
|
#define MAX_RX_PKT_SIZE WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_ETHFRM_LEN
|
||||||
|
#endif
|
||||||
|
#define MAX_RX_PKT_LIMIT ((MAX_RX_PKT_SIZE + 511) / 512) // MAX_RX_PKT_SIZE = 64+1514 = 1578
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#ifdef CONFIG_DONT_CARE_TP
|
||||||
|
#define MAX_RX_PKT_SIZE WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_RX_ETHFRM_LEN
|
||||||
|
#else
|
||||||
|
#define MAX_RX_PKT_SIZE WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_ETHFRM_LEN
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_DONT_CARE_TP
|
||||||
|
#define MAX_TX_SKB_BUF_SIZE (HAL_INTERFACE_OVERHEAD_SKB_DATA+RX_DRIVER_INFO+\
|
||||||
|
((TXDESC_SIZE>RXDESC_SIZE)? TXDESC_SIZE:RXDESC_SIZE) +\
|
||||||
|
WLAN_MAX_PROTOCOL_OVERHEAD + WLAN_MAX_TX_ETHFRM_LEN +\
|
||||||
|
SKB_RESERVED_FOR_SAFETY)
|
||||||
|
#define MAX_RX_SKB_BUF_SIZE (HAL_INTERFACE_OVERHEAD_SKB_DATA+RX_DRIVER_INFO+\
|
||||||
|
((TXDESC_SIZE>RXDESC_SIZE)? TXDESC_SIZE:RXDESC_SIZE) +\
|
||||||
|
MAX_RX_PKT_SIZE +\
|
||||||
|
SKB_RESERVED_FOR_SAFETY)
|
||||||
|
#else
|
||||||
|
#define MAX_SKB_BUF_SIZE (HAL_INTERFACE_OVERHEAD_SKB_DATA+RX_DRIVER_INFO+\
|
||||||
|
((TXDESC_SIZE>RXDESC_SIZE)? TXDESC_SIZE:RXDESC_SIZE) +\
|
||||||
|
MAX_RX_PKT_SIZE +\
|
||||||
|
SKB_RESERVED_FOR_SAFETY)
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#define MAX_SKB_BUF_SIZE 2048
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
struct sk_buff_head {
|
||||||
|
struct list_head *next, *prev;
|
||||||
|
u32 qlen;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct sk_buff {
|
||||||
|
/* These two members must be first. */
|
||||||
|
struct sk_buff *next; /* Next buffer in list */
|
||||||
|
struct sk_buff *prev; /* Previous buffer in list */
|
||||||
|
|
||||||
|
struct sk_buff_head *list; /* List we are on */
|
||||||
|
unsigned char *head; /* Head of buffer */
|
||||||
|
unsigned char *data; /* Data head pointer */
|
||||||
|
unsigned char *tail; /* Tail pointer */
|
||||||
|
unsigned char *end; /* End pointer */
|
||||||
|
struct net_device *dev; /* Device we arrived on/are leaving by */
|
||||||
|
unsigned int len; /* Length of actual data */
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* skb_put - add data to a buffer
|
||||||
|
* @skb: buffer to use
|
||||||
|
* @len: amount of data to add
|
||||||
|
*
|
||||||
|
* This function extends the used data area of the buffer. If this would
|
||||||
|
* exceed the total buffer size the kernel will panic. A pointer to the
|
||||||
|
* first byte of the extra data is returned.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static __inline__ unsigned char *skb_put(struct sk_buff *skb, unsigned int len)
|
||||||
|
{
|
||||||
|
unsigned char *tmp=skb->tail;
|
||||||
|
skb->tail+=len;
|
||||||
|
skb->len+=len;
|
||||||
|
if(skb->tail>skb->end) {
|
||||||
|
ASSERT(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
return tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ unsigned char *__skb_pull(struct sk_buff *skb, unsigned int len)
|
||||||
|
{
|
||||||
|
skb->len-=len;
|
||||||
|
skb->data = (unsigned char *)(((unsigned int)skb->data) + len);
|
||||||
|
|
||||||
|
return skb->data;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* skb_reserve - adjust headroom
|
||||||
|
* @skb: buffer to alter
|
||||||
|
* @len: bytes to move
|
||||||
|
*
|
||||||
|
* Increase the headroom of an empty &sk_buff by reducing the tail
|
||||||
|
* room. This is only allowed for an empty buffer.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static __inline__ void skb_reserve(struct sk_buff *skb, unsigned int len)
|
||||||
|
{
|
||||||
|
skb->data+=len;
|
||||||
|
skb->tail+=len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ void skb_queue_head_init(struct sk_buff_head *list)
|
||||||
|
{
|
||||||
|
list->prev = (struct list_head *)list;
|
||||||
|
list->next = (struct list_head *)list;
|
||||||
|
list->qlen = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* __skb_queue_tail - queue a buffer at the list tail
|
||||||
|
* @list: list to use
|
||||||
|
* @newsk: buffer to queue
|
||||||
|
*
|
||||||
|
* Queue a buffer at the end of a list. This function takes no locks
|
||||||
|
* and you must therefore hold required locks before calling it.
|
||||||
|
*
|
||||||
|
* A buffer cannot be placed on two lists at the same time.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static __inline__ void __skb_queue_tail(struct sk_buff_head *list, struct sk_buff *newsk)
|
||||||
|
{
|
||||||
|
struct sk_buff *prev, *next;
|
||||||
|
|
||||||
|
newsk->list = list;
|
||||||
|
list->qlen++;
|
||||||
|
next = (struct sk_buff *)list;
|
||||||
|
prev = next->prev;
|
||||||
|
newsk->next = next;
|
||||||
|
newsk->prev = prev;
|
||||||
|
next->prev = newsk;
|
||||||
|
prev->next = newsk;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* skb_queue_tail - queue a buffer at the list tail
|
||||||
|
* @list: list to use
|
||||||
|
* @newsk: buffer to queue
|
||||||
|
*
|
||||||
|
* Queue a buffer at the tail of the list. This function takes the
|
||||||
|
* list lock and can be used safely with other locking &sk_buff functions
|
||||||
|
* safely.
|
||||||
|
*
|
||||||
|
* A buffer cannot be placed on two lists at the same time.
|
||||||
|
*/
|
||||||
|
|
||||||
|
static __inline__ void skb_queue_tail(struct sk_buff_head *list, struct sk_buff *newsk)
|
||||||
|
{
|
||||||
|
save_and_cli();
|
||||||
|
__skb_queue_tail(list, newsk);
|
||||||
|
restore_flags();
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ void skb_assign_buf(struct sk_buff *skb, unsigned char *buf, unsigned int len)
|
||||||
|
{
|
||||||
|
skb->head = buf;
|
||||||
|
skb->data = buf;
|
||||||
|
skb->tail = buf;
|
||||||
|
skb->end = buf + len;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ unsigned char *skb_tail_pointer(const struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
return skb->tail;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ void skb_reset_tail_pointer(struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
skb->tail = skb->data;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ void skb_set_tail_pointer(struct sk_buff *skb, const int offset)
|
||||||
|
{
|
||||||
|
skb->tail = skb->data + offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
static __inline__ unsigned char *skb_end_pointer(const struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
return skb->end;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
/*
|
||||||
|
* External functions
|
||||||
|
*/
|
||||||
|
struct net_device;
|
||||||
|
extern void kfree_skb_chk_key(struct sk_buff *skb, struct net_device *root_dev);
|
||||||
|
#ifdef CONFIG_TRACE_SKB
|
||||||
|
extern void show_skb(void);
|
||||||
|
extern int _set_skb_list_flag(struct sk_buff *skb, unsigned int queueflag);
|
||||||
|
extern void dump_skb_list(void);
|
||||||
|
#define set_skb_list_flag(skb, queueflag) \
|
||||||
|
(\
|
||||||
|
_set_skb_list_flag((skb), queueflag), \
|
||||||
|
(skb) ? (skb)->funcname[(skb)->list_idx] = __FUNCTION__:NULL \
|
||||||
|
)
|
||||||
|
extern int _clear_skb_list_flag(struct sk_buff *skb, unsigned int queueflag);
|
||||||
|
#define clear_skb_list_flag(skb, queueflag) \
|
||||||
|
(\
|
||||||
|
_clear_skb_list_flag((skb), queueflag), \
|
||||||
|
(skb) ? (skb)->funcname[(skb)->list_idx] = __FUNCTION__ : NULL \
|
||||||
|
)
|
||||||
|
#define dev_kfree_skb_any(trx, holder, skb) \
|
||||||
|
do{\
|
||||||
|
clear_skb_list_flag(skb, SKBLIST_##trx##holder##_MASK);\
|
||||||
|
set_skb_list_flag(skb, SKBLIST_POOL);\
|
||||||
|
kfree_skb_chk_key(skb, skb->dev);\
|
||||||
|
}while (0)
|
||||||
|
#else
|
||||||
|
#define dev_kfree_skb_any(skb) kfree_skb_chk_key(skb, skb->dev)
|
||||||
|
#endif
|
||||||
|
extern struct sk_buff *dev_alloc_skb(unsigned int length, unsigned int reserve_len);
|
||||||
|
extern struct sk_buff *skb_clone(struct sk_buff *skb, int gfp_mask);
|
||||||
|
extern struct sk_buff *skb_copy(const struct sk_buff *skb, int gfp_mask, unsigned int reserve_len);
|
||||||
|
extern unsigned char *skb_pull(struct sk_buff *skb, unsigned int len);
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Device structure
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
struct net_device_stats {
|
||||||
|
unsigned long rx_packets; /* total packets received */
|
||||||
|
unsigned long tx_packets; /* total packets transmitted */
|
||||||
|
unsigned long rx_dropped; /* no space in linux buffers */
|
||||||
|
unsigned long tx_dropped; /* no space available in linux */
|
||||||
|
unsigned long rx_bytes; /* total bytes received */
|
||||||
|
unsigned long tx_bytes; /* total bytes transmitted */
|
||||||
|
unsigned long rx_overflow; /* rx fifo overflow count */
|
||||||
|
};
|
||||||
|
|
||||||
|
struct net_device {
|
||||||
|
char name[16];
|
||||||
|
void *priv; /* pointer to private data */
|
||||||
|
unsigned char dev_addr[6]; /* set during bootup */
|
||||||
|
int (*init)(void);
|
||||||
|
int (*open)(struct net_device *dev);
|
||||||
|
int (*stop)(struct net_device *dev);
|
||||||
|
int (*hard_start_xmit)(struct sk_buff *skb, struct net_device *dev);
|
||||||
|
int (*do_ioctl)(struct net_device *dev, struct iwreq *ifr, int cmd);
|
||||||
|
struct net_device_stats* (*get_stats)(struct net_device *dev);
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
struct net_device *dev; /* Binding wlan driver netdev */
|
||||||
|
void *skb; /* pending Rx packet */
|
||||||
|
unsigned int tx_busy;
|
||||||
|
unsigned int rx_busy;
|
||||||
|
unsigned char enable;
|
||||||
|
unsigned char mac[6];
|
||||||
|
} Rltk_wlan_t;
|
||||||
|
|
||||||
|
#define netdev_priv(dev) dev->priv
|
||||||
|
|
||||||
|
extern struct net_device *alloc_etherdev(int sizeof_priv);
|
||||||
|
void free_netdev(struct net_device *dev);
|
||||||
|
int dev_alloc_name(struct net_device *net_dev, const char *ifname);
|
||||||
|
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Timer Operation
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
void init_timer(struct timer_list *timer);
|
||||||
|
void mod_timer(struct timer_list *timer, u32 delay_time_ms);
|
||||||
|
void cancel_timer_ex(struct timer_list * timer);
|
||||||
|
void del_timer_sync(struct timer_list * timer);
|
||||||
|
void init_timer_wrapper(void);
|
||||||
|
void deinit_timer_wrapper(void);
|
||||||
|
|
||||||
|
#endif //__WRAPPER_H__
|
||||||
|
|
||||||
|
|
||||||
|
|
222
component/common/drivers/wlan/realtek/src/osdep/lwip_intf.c
Executable file
222
component/common/drivers/wlan/realtek/src/osdep/lwip_intf.c
Executable file
|
@ -0,0 +1,222 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2012 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of version 2 of the GNU General Public License as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
|
||||||
|
* more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with
|
||||||
|
* this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110, USA
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
//#define _LWIP_INTF_C_
|
||||||
|
|
||||||
|
#include <autoconf.h>
|
||||||
|
#include <lwip_intf.h>
|
||||||
|
#include <lwip/netif.h>
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <ethernetif.h>
|
||||||
|
#include <osdep_service.h>
|
||||||
|
#include <wifi/wifi_util.h>
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// External Reference
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
extern struct netif xnetif[]; //LWIP netif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rltk_wlan_set_netif_info - set netif hw address and register dev pointer to netif device
|
||||||
|
* @idx_wlan: netif index
|
||||||
|
* 0 for STA only or SoftAP only or STA in STA+SoftAP concurrent mode,
|
||||||
|
* 1 for SoftAP in STA+SoftAP concurrent mode
|
||||||
|
* @dev: register netdev pointer to LWIP. Reserved.
|
||||||
|
* @dev_addr: set netif hw address
|
||||||
|
*
|
||||||
|
* Return Value: None
|
||||||
|
*/
|
||||||
|
void rltk_wlan_set_netif_info(int idx_wlan, void * dev, unsigned char * dev_addr)
|
||||||
|
{
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
rtw_memcpy(xnetif[idx_wlan].hwaddr, dev_addr, 6);
|
||||||
|
xnetif[idx_wlan].state = dev;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rltk_wlan_send - send IP packets to WLAN. Called by low_level_output().
|
||||||
|
* @idx: netif index
|
||||||
|
* @sg_list: data buffer list
|
||||||
|
* @sg_len: size of each data buffer
|
||||||
|
* @total_len: total data len
|
||||||
|
*
|
||||||
|
* Return Value: None
|
||||||
|
*/
|
||||||
|
int rltk_wlan_send(int idx, struct eth_drv_sg *sg_list, int sg_len, int total_len)
|
||||||
|
{
|
||||||
|
struct eth_drv_sg *last_sg;
|
||||||
|
struct sk_buff *skb = NULL;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
if(idx == -1){
|
||||||
|
DBG_ERR("netif is DOWN");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
DBG_TRACE("%s is called", __FUNCTION__);
|
||||||
|
|
||||||
|
save_and_cli();
|
||||||
|
if(rltk_wlan_check_isup(idx))
|
||||||
|
rltk_wlan_tx_inc(idx);
|
||||||
|
else {
|
||||||
|
DBG_ERR("netif is DOWN");
|
||||||
|
restore_flags();
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
restore_flags();
|
||||||
|
|
||||||
|
skb = rltk_wlan_alloc_skb(total_len);
|
||||||
|
if (skb == NULL) {
|
||||||
|
//DBG_ERR("rltk_wlan_alloc_skb() for data len=%d failed!", total_len);
|
||||||
|
ret = -1;
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (last_sg = &sg_list[sg_len]; sg_list < last_sg; ++sg_list) {
|
||||||
|
rtw_memcpy(skb->tail, (void *)(sg_list->buf), sg_list->len);
|
||||||
|
skb_put(skb, sg_list->len);
|
||||||
|
}
|
||||||
|
|
||||||
|
rltk_wlan_send_skb(idx, skb);
|
||||||
|
|
||||||
|
exit:
|
||||||
|
save_and_cli();
|
||||||
|
rltk_wlan_tx_dec(idx);
|
||||||
|
restore_flags();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* rltk_wlan_recv - indicate packets to LWIP. Called by ethernetif_recv().
|
||||||
|
* @idx: netif index
|
||||||
|
* @sg_list: data buffer list
|
||||||
|
* @sg_len: size of each data buffer
|
||||||
|
*
|
||||||
|
* Return Value: None
|
||||||
|
*/
|
||||||
|
void rltk_wlan_recv(int idx, struct eth_drv_sg *sg_list, int sg_len)
|
||||||
|
{
|
||||||
|
struct eth_drv_sg *last_sg;
|
||||||
|
struct sk_buff *skb;
|
||||||
|
|
||||||
|
DBG_TRACE("%s is called", __FUNCTION__);
|
||||||
|
if(idx == -1){
|
||||||
|
DBG_ERR("skb is NULL");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
skb = rltk_wlan_get_recv_skb(idx);
|
||||||
|
DBG_ASSERT(skb, "No pending rx skb");
|
||||||
|
|
||||||
|
for (last_sg = &sg_list[sg_len]; sg_list < last_sg; ++sg_list) {
|
||||||
|
if (sg_list->buf != 0) {
|
||||||
|
rtw_memcpy((void *)(sg_list->buf), skb->data, sg_list->len);
|
||||||
|
skb_pull(skb, sg_list->len);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int netif_is_valid_IP(int idx, unsigned char *ip_dest)
|
||||||
|
{
|
||||||
|
#if CONFIG_LWIP_LAYER == 1
|
||||||
|
struct netif * pnetif = &xnetif[idx];
|
||||||
|
struct ip_addr addr = { 0 };
|
||||||
|
#ifdef CONFIG_MEMORY_ACCESS_ALIGNED
|
||||||
|
unsigned int temp;
|
||||||
|
memcpy(&temp, ip_dest, sizeof(unsigned int));
|
||||||
|
u32_t *ip_dest_addr = &temp;
|
||||||
|
#else
|
||||||
|
u32_t *ip_dest_addr = (u32_t*)ip_dest;
|
||||||
|
#endif
|
||||||
|
addr.addr = *ip_dest_addr;
|
||||||
|
|
||||||
|
if(pnetif->ip_addr.addr == 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
if(ip_addr_ismulticast(&addr) || ip_addr_isbroadcast(&addr,pnetif)){
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
//if(ip_addr_netcmp(&(pnetif->ip_addr), &addr, &(pnetif->netmask))) //addr&netmask
|
||||||
|
// return 1;
|
||||||
|
|
||||||
|
if(ip_addr_cmp(&(pnetif->ip_addr),&addr))
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
DBG_TRACE("invalid IP: %d.%d.%d.%d ",ip_dest[0],ip_dest[1],ip_dest[2],ip_dest[3]);
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_DONT_CARE_TP
|
||||||
|
if(pnetif->flags & NETIF_FLAG_IPSWITCH)
|
||||||
|
return 1;
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int netif_get_idx(struct netif* pnetif)
|
||||||
|
{
|
||||||
|
#if CONFIG_LWIP_LAYER == 1
|
||||||
|
int idx = pnetif - xnetif;
|
||||||
|
|
||||||
|
switch(idx) {
|
||||||
|
case 0:
|
||||||
|
return 0;
|
||||||
|
case 1:
|
||||||
|
return 1;
|
||||||
|
default:
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned char *netif_get_hwaddr(int idx_wlan)
|
||||||
|
{
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
return xnetif[idx_wlan].hwaddr;
|
||||||
|
#else
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void netif_rx(int idx, unsigned int len)
|
||||||
|
{
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
ethernetif_recv(&xnetif[idx], len);
|
||||||
|
#endif
|
||||||
|
#if (CONFIG_INIC_EN == 1)
|
||||||
|
inic_netif_rx(idx, len);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void netif_post_sleep_processing(void)
|
||||||
|
{
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
lwip_POST_SLEEP_PROCESSING(); //For FreeRTOS tickless to enable Lwip ARP timer when leaving IPS - Alex Fang
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
void netif_pre_sleep_processing(void)
|
||||||
|
{
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
lwip_PRE_SLEEP_PROCESSING();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
56
component/common/drivers/wlan/realtek/src/osdep/lwip_intf.h
Executable file
56
component/common/drivers/wlan/realtek/src/osdep/lwip_intf.h
Executable file
|
@ -0,0 +1,56 @@
|
||||||
|
#ifndef __LWIP_INTF_H__
|
||||||
|
#define __LWIP_INTF_H__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <wireless.h>
|
||||||
|
#include <skbuff.h>
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Ethernet Buffer
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
struct eth_drv_sg {
|
||||||
|
unsigned int buf;
|
||||||
|
unsigned int len;
|
||||||
|
};
|
||||||
|
|
||||||
|
#define MAX_ETH_DRV_SG 32
|
||||||
|
#define MAX_ETH_MSG 1540
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Wlan Interface Provided
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
unsigned char rltk_wlan_check_isup(int idx);
|
||||||
|
void rltk_wlan_tx_inc(int idx);
|
||||||
|
void rltk_wlan_tx_dec(int idx);
|
||||||
|
struct sk_buff * rltk_wlan_get_recv_skb(int idx);
|
||||||
|
struct sk_buff * rltk_wlan_alloc_skb(unsigned int total_len);
|
||||||
|
void rltk_wlan_set_netif_info(int idx_wlan, void * dev, unsigned char * dev_addr);
|
||||||
|
void rltk_wlan_send_skb(int idx, struct sk_buff *skb); //struct sk_buff as defined above comment line
|
||||||
|
int rltk_wlan_send(int idx, struct eth_drv_sg *sg_list, int sg_len, int total_len);
|
||||||
|
void rltk_wlan_recv(int idx, struct eth_drv_sg *sg_list, int sg_len);
|
||||||
|
unsigned char rltk_wlan_running(unsigned char idx); // interface is up. 0: interface is down
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Network Interface provided
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
struct netif;
|
||||||
|
int netif_is_valid_IP(int idx,unsigned char * ip_dest);
|
||||||
|
int netif_get_idx(struct netif *pnetif);
|
||||||
|
unsigned char *netif_get_hwaddr(int idx_wlan);
|
||||||
|
void netif_rx(int idx, unsigned int len);
|
||||||
|
void netif_post_sleep_processing(void);
|
||||||
|
void netif_pre_sleep_processing(void);
|
||||||
|
#if (CONFIG_LWIP_LAYER == 1)
|
||||||
|
extern void ethernetif_recv(struct netif *netif, int total_len);
|
||||||
|
extern void lwip_PRE_SLEEP_PROCESSING(void);
|
||||||
|
extern void lwip_POST_SLEEP_PROCESSING(void);
|
||||||
|
#endif //CONFIG_LWIP_LAYER == 1
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif //#ifndef __LWIP_INTF_H__
|
54
component/common/drivers/wlan/realtek/src/osdep/skbuff.h
Executable file
54
component/common/drivers/wlan/realtek/src/osdep/skbuff.h
Executable file
|
@ -0,0 +1,54 @@
|
||||||
|
#ifndef __SKBUFF_H__
|
||||||
|
#define __SKBUFF_H__
|
||||||
|
|
||||||
|
struct sk_buff_head {
|
||||||
|
struct list_head *next, *prev;
|
||||||
|
unsigned int qlen;
|
||||||
|
};
|
||||||
|
|
||||||
|
#ifdef CONFIG_TRACE_SKB
|
||||||
|
#define TRACE_SKB_DEPTH 8
|
||||||
|
#endif
|
||||||
|
|
||||||
|
struct sk_buff {
|
||||||
|
/* These two members must be first. */
|
||||||
|
struct sk_buff *next; /* Next buffer in list */
|
||||||
|
struct sk_buff *prev; /* Previous buffer in list */
|
||||||
|
|
||||||
|
struct sk_buff_head *list; /* List we are on */
|
||||||
|
unsigned char *head; /* Head of buffer */
|
||||||
|
unsigned char *data; /* Data head pointer */
|
||||||
|
unsigned char *tail; /* Tail pointer */
|
||||||
|
unsigned char *end; /* End pointer */
|
||||||
|
void *dev; /* Device we arrived on/are leaving by */
|
||||||
|
unsigned int len; /* Length of actual data */
|
||||||
|
#ifdef CONFIG_TRACE_SKB
|
||||||
|
unsigned int liston[TRACE_SKB_DEPTH]; /* Trace the Lists we went through */
|
||||||
|
const char *funcname[TRACE_SKB_DEPTH];
|
||||||
|
unsigned int list_idx; /* Trace the List we are on */
|
||||||
|
#endif
|
||||||
|
};
|
||||||
|
|
||||||
|
unsigned char *skb_put(struct sk_buff *skb, unsigned int len);
|
||||||
|
unsigned char *skb_pull(struct sk_buff *skb, unsigned int len);
|
||||||
|
void skb_reserve(struct sk_buff *skb, unsigned int len);
|
||||||
|
void skb_assign_buf(struct sk_buff *skb, unsigned char *buf, unsigned int len);
|
||||||
|
unsigned char *skb_tail_pointer(const struct sk_buff *skb);
|
||||||
|
void skb_set_tail_pointer(struct sk_buff *skb, const int offset);
|
||||||
|
unsigned char *skb_end_pointer(const struct sk_buff *skb);
|
||||||
|
|
||||||
|
void init_skb_pool(void);
|
||||||
|
void init_skb_data_pool(void);
|
||||||
|
|
||||||
|
#ifndef CONFIG_DONT_CARE_TP
|
||||||
|
struct sk_buff *dev_alloc_skb(unsigned int length, unsigned int reserve_len);
|
||||||
|
#else
|
||||||
|
struct sk_buff *dev_alloc_tx_skb(unsigned int length, unsigned int reserve_len);
|
||||||
|
struct sk_buff *dev_alloc_rx_skb(unsigned int length, unsigned int reserve_len);
|
||||||
|
#define dev_alloc_skb dev_alloc_tx_skb
|
||||||
|
#endif
|
||||||
|
void kfree_skb(struct sk_buff *skb);
|
||||||
|
|
||||||
|
|
||||||
|
#endif //__SKBUFF_H__
|
||||||
|
|
1207
component/common/drivers/wlan/realtek/src/osdep/wireless.h
Executable file
1207
component/common/drivers/wlan/realtek/src/osdep/wireless.h
Executable file
File diff suppressed because it is too large
Load diff
65
component/common/drivers/wlan/realtek/src/osdep/wlan_intf.h
Executable file
65
component/common/drivers/wlan/realtek/src/osdep/wlan_intf.h
Executable file
|
@ -0,0 +1,65 @@
|
||||||
|
#ifndef __WLAN_INTF_H__
|
||||||
|
#define __WLAN_INTF_H__
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
#include <autoconf.h>
|
||||||
|
|
||||||
|
#include <wireless.h>
|
||||||
|
#include "wifi_constants.h"
|
||||||
|
|
||||||
|
#ifndef WLAN0_IDX
|
||||||
|
#define WLAN0_IDX 0
|
||||||
|
#endif
|
||||||
|
#ifndef WLAN1_IDX
|
||||||
|
#define WLAN1_IDX 1
|
||||||
|
#endif
|
||||||
|
#ifndef WLAN_UNDEF
|
||||||
|
#define WLAN_UNDEF -1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/***********************************************************/
|
||||||
|
/*
|
||||||
|
struct sk_buff {
|
||||||
|
// These two members must be first.
|
||||||
|
struct sk_buff *next; // Next buffer in list
|
||||||
|
struct sk_buff *prev; // Previous buffer in list
|
||||||
|
|
||||||
|
struct sk_buff_head *list; // List we are on
|
||||||
|
unsigned char *head; // Head of buffer
|
||||||
|
unsigned char *data; // Data head pointer
|
||||||
|
unsigned char *tail; // Tail pointer
|
||||||
|
unsigned char *end; //End pointer
|
||||||
|
struct net_device *dev; //Device we arrived on/are leaving by
|
||||||
|
unsigned int len; // Length of actual data
|
||||||
|
};
|
||||||
|
*/
|
||||||
|
/************************************************************/
|
||||||
|
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
// Wlan Interface opened for upper layer
|
||||||
|
//----- ------------------------------------------------------------------
|
||||||
|
int rltk_wlan_init(int idx_wlan, rtw_mode_t mode); //return 0: success. -1:fail
|
||||||
|
void rltk_wlan_deinit(void);
|
||||||
|
void rltk_wlan_start(int idx_wlan);
|
||||||
|
void rltk_wlan_statistic(unsigned char idx);
|
||||||
|
unsigned char rltk_wlan_running(unsigned char idx); // interface is up. 0: interface is down
|
||||||
|
int rltk_wlan_control(unsigned long cmd, void *data);
|
||||||
|
int rltk_wlan_handshake_done(void);
|
||||||
|
int rltk_wlan_rf_on(void);
|
||||||
|
int rltk_wlan_rf_off(void);
|
||||||
|
int rltk_wlan_check_bus(void);
|
||||||
|
int rltk_wlan_wireless_mode(unsigned char mode);
|
||||||
|
int rltk_wlan_set_wps_phase(unsigned char is_trigger_wps);
|
||||||
|
int rtw_ps_enable(int enable);
|
||||||
|
int rltk_wlan_is_connected_to_ap(void);
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#endif //#ifndef __WLAN_INTF_H__
|
14
component/common/drivers/wlan/realtek/src/wifi_skbuf.c
Executable file
14
component/common/drivers/wlan/realtek/src/wifi_skbuf.c
Executable file
|
@ -0,0 +1,14 @@
|
||||||
|
#include <section_config.h>
|
||||||
|
#include <freertos/wrapper.h>
|
||||||
|
#undef MAX_SKB_BUF_NUM
|
||||||
|
#define MAX_SKB_BUF_NUM 16
|
||||||
|
|
||||||
|
// DO NOT modify this structure
|
||||||
|
struct skb_data {
|
||||||
|
struct list_head list;
|
||||||
|
unsigned char buf[MAX_SKB_BUF_SIZE];
|
||||||
|
atomic_t ref;
|
||||||
|
};
|
||||||
|
|
||||||
|
SRAM_BD_DATA_SECTION
|
||||||
|
struct skb_data skb_data_pool[MAX_SKB_BUF_NUM];
|
84
component/common/example/cJSON/cJSON_example.c
Executable file
84
component/common/example/cJSON/cJSON_example.c
Executable file
|
@ -0,0 +1,84 @@
|
||||||
|
#include "cmsis_os.h"
|
||||||
|
#include <cJSON.h>
|
||||||
|
|
||||||
|
#define malloc pvPortMalloc
|
||||||
|
#define free vPortFree
|
||||||
|
|
||||||
|
/* The data structure for this example
|
||||||
|
|
||||||
|
{
|
||||||
|
"Motion_Sensor" : "i",
|
||||||
|
"Light" : {
|
||||||
|
"Red" : "0",
|
||||||
|
"Green" : "0",
|
||||||
|
"Blue" : "0",
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
*/
|
||||||
|
static void gen_json_data(int i, int r, int g, int b)
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
cJSON_Hooks memoryHook;
|
||||||
|
|
||||||
|
memoryHook.malloc_fn = malloc;
|
||||||
|
memoryHook.free_fn = free;
|
||||||
|
cJSON_InitHooks(&memoryHook);
|
||||||
|
|
||||||
|
|
||||||
|
cJSON *IOTJSObject = NULL, *colorJSObject = NULL;
|
||||||
|
char *iot_json = NULL;
|
||||||
|
|
||||||
|
if((IOTJSObject = cJSON_CreateObject()) != NULL) {
|
||||||
|
|
||||||
|
cJSON_AddItemToObject(IOTJSObject, "Motion_Sensor", cJSON_CreateNumber(i));
|
||||||
|
cJSON_AddItemToObject(IOTJSObject, "Light", colorJSObject = cJSON_CreateObject());
|
||||||
|
|
||||||
|
cJSON_AddItemToObject(colorJSObject, "Red", cJSON_CreateNumber(r));
|
||||||
|
cJSON_AddItemToObject(colorJSObject, "Green", cJSON_CreateNumber(g));
|
||||||
|
cJSON_AddItemToObject(colorJSObject, "Blue", cJSON_CreateNumber(b));
|
||||||
|
|
||||||
|
iot_json = cJSON_Print(IOTJSObject);
|
||||||
|
cJSON_Delete(IOTJSObject);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static void handle_json_data(char *iot_json)
|
||||||
|
{
|
||||||
|
cJSON_Hooks memoryHook;
|
||||||
|
|
||||||
|
memoryHook.malloc_fn = malloc;
|
||||||
|
memoryHook.free_fn = free;
|
||||||
|
cJSON_InitHooks(&memoryHook);
|
||||||
|
|
||||||
|
|
||||||
|
cJSON *IOTJSObject, *sensorJSObject, *lightJSObject, *redJSObject, *greenJSObject, *blueJSObject;
|
||||||
|
int sensor_data, red, green, blue;
|
||||||
|
|
||||||
|
if((IOTJSObject = cJSON_Parse(iot_json)) != NULL) {
|
||||||
|
sensorJSObject = cJSON_GetObjectItem(IOTJSObject, "Motion_Sensor");
|
||||||
|
if(sensorJSObject)
|
||||||
|
sensor_data = sensorJSObject->valueint;
|
||||||
|
|
||||||
|
lightJSObject = cJSON_GetObjectItem(IOTJSObject, "Light");
|
||||||
|
|
||||||
|
if(lightJSObject){
|
||||||
|
redJSObject = cJSON_GetObjectItem(lightJSObject, "Red");
|
||||||
|
greenJSObject = cJSON_GetObjectItem(lightJSObject, "Green");
|
||||||
|
blueJSObject = cJSON_GetObjectItem(lightJSObject, "Blue");
|
||||||
|
|
||||||
|
if(redJSObject)
|
||||||
|
red = redJSObject->valueint;
|
||||||
|
if(greenJSObject)
|
||||||
|
green = greenJSObject->valueint;
|
||||||
|
if(blueJSObject)
|
||||||
|
blue = blueJSObject->valueint;
|
||||||
|
}
|
||||||
|
|
||||||
|
cJSON_Delete(IOTJSObject);
|
||||||
|
}
|
||||||
|
}
|
112
component/common/example/example_entry.c
Executable file
112
component/common/example/example_entry.c
Executable file
|
@ -0,0 +1,112 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2015 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#include <platform_opts.h>
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_MDNS
|
||||||
|
#include <mdns/example_mdns.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_MCAST
|
||||||
|
#include <mcast/example_mcast.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_XML
|
||||||
|
#include <xml/example_xml.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_SOCKET_SELECT
|
||||||
|
#include <socket_select/example_socket_select.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_SSL_DOWNLOAD
|
||||||
|
#include <ssl_download/example_ssl_download.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_GOOGLE_NEST
|
||||||
|
#include <googlenest/example_google.h>
|
||||||
|
#define FromDevice 1
|
||||||
|
#define ToDevice 2
|
||||||
|
#define TYPE "ToDevice"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_UVC
|
||||||
|
#include <uvc/example_uvc.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_WLAN_FAST_CONNECT
|
||||||
|
#include <wlan_fast_connect/example_wlan_fast_connect.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_WIGADGET
|
||||||
|
#include <wigadget/wigadget.h>
|
||||||
|
#endif
|
||||||
|
/*
|
||||||
|
Preprocessor of example
|
||||||
|
*/
|
||||||
|
void pre_example_entry(void)
|
||||||
|
{
|
||||||
|
#if CONFIG_EXAMPLE_WLAN_FAST_CONNECT
|
||||||
|
example_wlan_fast_connect();
|
||||||
|
#endif
|
||||||
|
#if CONFIG_JD_SMART
|
||||||
|
example_jdsmart_init();
|
||||||
|
#endif
|
||||||
|
#if CONFIG_EXAMPLE_UART_ADAPTER
|
||||||
|
example_uart_adapter_init();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
All of the examples are disabled by default for code size consideration
|
||||||
|
The configuration is enabled in platform_opts.h
|
||||||
|
*/
|
||||||
|
void example_entry(void)
|
||||||
|
{
|
||||||
|
#if (CONFIG_EXAMPLE_MDNS && !CONFIG_EXAMPLE_UART_ADAPTER)
|
||||||
|
example_mdns();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_MCAST
|
||||||
|
example_mcast();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_XML
|
||||||
|
example_xml();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_SOCKET_SELECT
|
||||||
|
example_socket_select();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_SSL_DOWNLOAD
|
||||||
|
example_ssl_download();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_GOOGLE_NEST
|
||||||
|
example_google(TYPE);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_UVC
|
||||||
|
example_uvc();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_UART_UPDATE
|
||||||
|
example_uart_update();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_WIFI_MANAGER
|
||||||
|
example_wifi_manager();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if CONFIG_EXAMPLE_WIGADGET
|
||||||
|
if(configTOTAL_HEAP_SIZE < ( ( size_t ) ( 115 * 1024 ) ))
|
||||||
|
printf("\r\n\r\n\r\n\r\nERROR!!!!\r\n\r\n Please goto FreeRTOSConfig.h to change configTOTAL_HEAP_SIZE more than 115*1024!!!\r\n\r\n\r\n\r\n\r\n\r\n");
|
||||||
|
else
|
||||||
|
example_wigadget();
|
||||||
|
|
||||||
|
#endif
|
||||||
|
}
|
8
component/common/example/example_entry.h
Executable file
8
component/common/example/example_entry.h
Executable file
|
@ -0,0 +1,8 @@
|
||||||
|
#ifndef __EXAMPLE_ENTRY_H__
|
||||||
|
#define __EXAMPLE_ENTRY_H__
|
||||||
|
|
||||||
|
|
||||||
|
void example_entry(void);
|
||||||
|
void pre_example_entry(void);
|
||||||
|
|
||||||
|
#endif //#ifndef __EXAMPLE_ENTRY_H__
|
38
component/common/example/googlenest/example.html
Executable file
38
component/common/example/googlenest/example.html
Executable file
|
@ -0,0 +1,38 @@
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<script src="https://cdn.firebase.com/js/client/2.1.1/firebase.js"></script>
|
||||||
|
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
|
||||||
|
</head>
|
||||||
|
|
||||||
|
<body>
|
||||||
|
<h1>Realtek Google Nest API example</h1>
|
||||||
|
<hr />
|
||||||
|
|
||||||
|
|
||||||
|
<h3 style="text-align:center;margin-left:auto;margin-right:auto;">Data To Device</h3>
|
||||||
|
|
||||||
|
<h4>Input the value of RGB to change the state of light:</h4>
|
||||||
|
<p>Red <input type="text" id="redInput" placeholder="Red" />
|
||||||
|
Green <input type="text" id="greenInput" placeholder="Green" />
|
||||||
|
Blue <input type="text" id="blueInput" placeholder="Blue" />
|
||||||
|
<input type="button" value="submit" name="submit" onClick="submit()" />
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
var myDataRef = new Firebase('https://your_firebase_address.firebaseio.com/light');
|
||||||
|
function submit()
|
||||||
|
{
|
||||||
|
var red = $('#redInput').val();
|
||||||
|
var green = $('#greenInput').val();
|
||||||
|
var blue = $('#blueInput').val();
|
||||||
|
myDataRef.set({
|
||||||
|
Red: red,
|
||||||
|
Green: green,
|
||||||
|
Blue: blue
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</body>
|
||||||
|
</html>
|
185
component/common/example/googlenest/example_google.c
Executable file
185
component/common/example/googlenest/example_google.c
Executable file
|
@ -0,0 +1,185 @@
|
||||||
|
#include "cmsis_os.h"
|
||||||
|
#include "diag.h"
|
||||||
|
#include "wifi_conf.h"
|
||||||
|
#include "wifi_ind.h"
|
||||||
|
#include "google/google_nest.h"
|
||||||
|
|
||||||
|
|
||||||
|
#include <googlenest/example_google.h>
|
||||||
|
#include "cJSON.h"
|
||||||
|
|
||||||
|
osThreadId google_thread_id;
|
||||||
|
#define malloc pvPortMalloc
|
||||||
|
#define free vPortFree
|
||||||
|
|
||||||
|
void google_data_retrieve(char *response_buf);
|
||||||
|
|
||||||
|
void google_data_retrieve(char *response_buf) {
|
||||||
|
//printf("\r\n\r\n\r\nResponse_buf:\r\n%s\r\n", response_buf);
|
||||||
|
char *event = NULL;
|
||||||
|
char *delims = "\n";
|
||||||
|
char *data = NULL, *backup = NULL;
|
||||||
|
char *info = NULL;
|
||||||
|
cJSON_Hooks memoryHook;
|
||||||
|
|
||||||
|
event = strtok_r(response_buf, delims, &backup);
|
||||||
|
data = strtok_r( NULL, delims, &backup );
|
||||||
|
|
||||||
|
if (!strncmp(data, "data: ", strlen("data: "))){
|
||||||
|
info = data + strlen("data: ");
|
||||||
|
if(info != NULL){
|
||||||
|
memoryHook.malloc_fn = malloc;
|
||||||
|
memoryHook.free_fn = free;
|
||||||
|
cJSON_InitHooks(&memoryHook);
|
||||||
|
|
||||||
|
cJSON *infoJSObject, *pathJSObject, *dataJSObject;
|
||||||
|
cJSON *redJSObject, *greenJSObject, *blueJSObject;
|
||||||
|
char *red, *green, *blue;
|
||||||
|
|
||||||
|
|
||||||
|
if((infoJSObject = cJSON_Parse(info)) != NULL) {
|
||||||
|
pathJSObject = cJSON_GetObjectItem(infoJSObject, "path");
|
||||||
|
dataJSObject = cJSON_GetObjectItem(infoJSObject, "data");
|
||||||
|
if(dataJSObject != NULL) {
|
||||||
|
|
||||||
|
redJSObject = cJSON_GetObjectItem(dataJSObject, "Red");
|
||||||
|
greenJSObject = cJSON_GetObjectItem(dataJSObject, "Green");
|
||||||
|
blueJSObject = cJSON_GetObjectItem(dataJSObject, "Blue");
|
||||||
|
|
||||||
|
if(redJSObject)
|
||||||
|
red = redJSObject->valuestring;
|
||||||
|
|
||||||
|
if(greenJSObject)
|
||||||
|
green = greenJSObject->valuestring;
|
||||||
|
|
||||||
|
if(blueJSObject)
|
||||||
|
blue = blueJSObject->valuestring;
|
||||||
|
|
||||||
|
printf("\n\rThe latest RGB information: RGB(%s, %s, %s)\n\r", red, green, blue);
|
||||||
|
|
||||||
|
cJSON_Delete(dataJSObject);
|
||||||
|
}
|
||||||
|
cJSON_Delete(infoJSObject);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\r\nCannot parse the message to JSON!\r\n");
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\r\n This is the keep alive message or cannot get the information!\r\n");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
printf("\r\nData structure may wrong!\r\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void gn_todevice_start(void) {
|
||||||
|
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_host = HOST_ADDR;
|
||||||
|
char *googlenest_uri = "light.json";
|
||||||
|
|
||||||
|
printf("\r\nStart connecting to Google Nest Server...\r\n");
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
|
||||||
|
reconnect:
|
||||||
|
if(gn_connect(&googlenest, googlenest_host, GN_PORT) == 0) {
|
||||||
|
printf("\r\n Connection is OK!\r\n");
|
||||||
|
|
||||||
|
google_retrieve_data_hook_callback(google_data_retrieve);
|
||||||
|
if(gn_stream(&googlenest, googlenest_uri) != 0){
|
||||||
|
printf("\r\n Connection is fail! \r\n Start Reconnecting...\r\n");
|
||||||
|
goto reconnect;
|
||||||
|
}
|
||||||
|
|
||||||
|
gn_close(&googlenest);
|
||||||
|
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
printf("\r\n Connection is fail! \r\n\r\n\r\n\r\nStart Reconnecting...\r\n");
|
||||||
|
goto reconnect;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void gn_fromdevice_start(void) {
|
||||||
|
googlenest_context googlenest;
|
||||||
|
char *googlenest_uri = "MotionSensor.json";
|
||||||
|
cJSON_Hooks memoryHook;
|
||||||
|
int j = 0;
|
||||||
|
|
||||||
|
memoryHook.malloc_fn = malloc;
|
||||||
|
memoryHook.free_fn = free;
|
||||||
|
cJSON_InitHooks(&memoryHook);
|
||||||
|
printf("\r\nStart connecting to Google Nest Server!\r\n");
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
memset(&googlenest, 0, sizeof(googlenest_context));
|
||||||
|
if(gn_connect(&googlenest, HOST_ADDR, GN_PORT) == 0) {
|
||||||
|
cJSON *MSJSObject;
|
||||||
|
char *data;
|
||||||
|
|
||||||
|
if((MSJSObject = cJSON_CreateObject()) != NULL) {
|
||||||
|
cJSON_AddItemToObject(MSJSObject, "MotionSenser", cJSON_CreateNumber(j++));
|
||||||
|
data = cJSON_Print(MSJSObject);
|
||||||
|
cJSON_Delete(MSJSObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(gn_put(&googlenest, googlenest_uri, data) == 0)
|
||||||
|
printf("\n\rUpdate the Motion Sensor's data to %d\n\r", (j-1));
|
||||||
|
free(data);
|
||||||
|
gn_close(&googlenest);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
printf("\n\rConnection failed!\n\r");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
vTaskDelay(5 * configTICK_RATE_HZ);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void gn_fromdevice_task(void *arg) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
printf("\n\r\n\r\n\r\n\r<<<<<<Waiting for 2 mins to connect Wi-Fi>>>>>>>\n\r\n\r\n\r\n\r");
|
||||||
|
for (i = 0; i<120; i++)
|
||||||
|
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||||
|
|
||||||
|
gn_fromdevice_start();
|
||||||
|
}
|
||||||
|
|
||||||
|
void gn_todevice_task(void *arg) {
|
||||||
|
int i;
|
||||||
|
|
||||||
|
printf("\n\r\n\r\n\r\n\r<<<<<<Waiting for 2 mins to connect Wi-Fi>>>>>>>\n\r\n\r\n\r\n\r");
|
||||||
|
for (i = 0; i<120; i++)
|
||||||
|
vTaskDelay(1000 / portTICK_PERIOD_MS);
|
||||||
|
|
||||||
|
gn_todevice_start();
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_google(char *type) {
|
||||||
|
|
||||||
|
|
||||||
|
if(strcmp(type, "FromDevice") == 0){
|
||||||
|
osThreadDef_t google_thread;
|
||||||
|
google_thread.instances = 1;
|
||||||
|
google_thread.name = "google thread";
|
||||||
|
google_thread.stacksize = 4096;
|
||||||
|
google_thread.pthread = (os_pthread)gn_fromdevice_task;
|
||||||
|
google_thread.tpriority = tskIDLE_PRIORITY+6;
|
||||||
|
google_thread_id = osThreadCreate(&google_thread, NULL);
|
||||||
|
}
|
||||||
|
else if(strcmp(type, "ToDevice") == 0){
|
||||||
|
osThreadDef_t google_thread;
|
||||||
|
google_thread.instances = 1;
|
||||||
|
google_thread.name = "google thread";
|
||||||
|
google_thread.stacksize = 4096;
|
||||||
|
google_thread.pthread = (os_pthread)gn_todevice_task;
|
||||||
|
google_thread.tpriority = tskIDLE_PRIORITY+6;
|
||||||
|
google_thread_id = osThreadCreate(&google_thread, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
10
component/common/example/googlenest/example_google.h
Executable file
10
component/common/example/googlenest/example_google.h
Executable file
|
@ -0,0 +1,10 @@
|
||||||
|
#ifndef GOOGLE_THREAD_H
|
||||||
|
#define GOOGLE_THREAD_H
|
||||||
|
|
||||||
|
#define HOST_ADDR "your_firebase_address.firebaseio.com"
|
||||||
|
#define GN_PORT 443
|
||||||
|
|
||||||
|
void example_google(char *type);
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
55
component/common/example/mdns/example_mdns.c
Executable file
55
component/common/example/mdns/example_mdns.c
Executable file
|
@ -0,0 +1,55 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
|
||||||
|
#include <mDNS/mDNS.h>
|
||||||
|
|
||||||
|
#include <lwip_netconf.h>
|
||||||
|
#include <lwip/netif.h>
|
||||||
|
extern struct netif xnetif[];
|
||||||
|
|
||||||
|
static void example_mdns_thread(void *param)
|
||||||
|
{
|
||||||
|
DNSServiceRef dnsServiceRef = NULL;
|
||||||
|
TXTRecordRef txtRecord;
|
||||||
|
unsigned char txt_buf[100]; // use fixed buffer for text record to prevent malloc/free
|
||||||
|
|
||||||
|
// Delay to wait for IP by DHCP
|
||||||
|
vTaskDelay(10000);
|
||||||
|
|
||||||
|
printf("\nmDNS Init\n");
|
||||||
|
if(mDNSResponderInit() == 0) {
|
||||||
|
printf("mDNS Register service\n");
|
||||||
|
TXTRecordCreate(&txtRecord, sizeof(txt_buf), txt_buf);
|
||||||
|
TXTRecordSetValue(&txtRecord, "text1", strlen("text1_content"), "text1_content");
|
||||||
|
TXTRecordSetValue(&txtRecord, "text2", strlen("text2_content"), "text2_content");
|
||||||
|
dnsServiceRef = mDNSRegisterService("ameba", "_service1._tcp", "local", 5000, &txtRecord);
|
||||||
|
TXTRecordDeallocate(&txtRecord);
|
||||||
|
printf("wait for 30s ... \n");
|
||||||
|
vTaskDelay(30*1000);
|
||||||
|
|
||||||
|
printf("mDNS Update service\n");
|
||||||
|
TXTRecordCreate(&txtRecord, sizeof(txt_buf), txt_buf);
|
||||||
|
TXTRecordSetValue(&txtRecord, "text1", strlen("text1_content_new"), "text1_content_new");
|
||||||
|
mDNSUpdateService(dnsServiceRef, &txtRecord, 0);
|
||||||
|
TXTRecordDeallocate(&txtRecord);
|
||||||
|
printf("wait for 30s ... \n");
|
||||||
|
vTaskDelay(30*1000);
|
||||||
|
|
||||||
|
if(dnsServiceRef)
|
||||||
|
mDNSDeregisterService(dnsServiceRef);
|
||||||
|
|
||||||
|
// deregister service before mdns deinit is not necessary
|
||||||
|
// mDNS deinit will also deregister all services
|
||||||
|
printf("mDNS Deinit\n");
|
||||||
|
mDNSResponderDeinit();
|
||||||
|
}
|
||||||
|
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_mdns(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(example_mdns_thread, ((const char*)"example_mdns_thread"), 1024, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate(init_thread) failed", __FUNCTION__);
|
||||||
|
}
|
6
component/common/example/mdns/example_mdns.h
Executable file
6
component/common/example/mdns/example_mdns.h
Executable file
|
@ -0,0 +1,6 @@
|
||||||
|
#ifndef EXAMPLE_MDNS_H
|
||||||
|
#define EXAMPLE_MDNS_H
|
||||||
|
|
||||||
|
void example_mdns(void);
|
||||||
|
|
||||||
|
#endif /* EXAMPLE_MDNS_H */
|
102
component/common/example/socket_select/example_socket_select.c
Executable file
102
component/common/example/socket_select/example_socket_select.c
Executable file
|
@ -0,0 +1,102 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
#include <lwip/sockets.h>
|
||||||
|
|
||||||
|
#define MAX_SOCKETS 10
|
||||||
|
#define SELECT_TIMEOUT 10
|
||||||
|
#define SERVER_PORT 5000
|
||||||
|
#define LISTEN_QLEN 2
|
||||||
|
|
||||||
|
static void example_socket_select_thread(void *param)
|
||||||
|
{
|
||||||
|
struct sockaddr_in server_addr;
|
||||||
|
int server_fd = -1;
|
||||||
|
int socket_used[10];
|
||||||
|
|
||||||
|
memset(socket_used, 0, sizeof(socket_used));
|
||||||
|
|
||||||
|
if((server_fd = socket(AF_INET, SOCK_STREAM, 0)) >= 0) {
|
||||||
|
socket_used[server_fd] = 1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("socket error\n");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
server_addr.sin_family = AF_INET;
|
||||||
|
server_addr.sin_port = htons(SERVER_PORT);
|
||||||
|
server_addr.sin_addr.s_addr = INADDR_ANY;
|
||||||
|
|
||||||
|
if(bind(server_fd, (struct sockaddr *) &server_addr, sizeof(server_addr)) != 0) {
|
||||||
|
printf("bind error\n");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(listen(server_fd, LISTEN_QLEN) != 0) {
|
||||||
|
printf("listen error\n");
|
||||||
|
goto exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
int socket_fd;
|
||||||
|
unsigned char buf[512];
|
||||||
|
fd_set read_fds;
|
||||||
|
struct timeval timeout;
|
||||||
|
|
||||||
|
FD_ZERO(&read_fds);
|
||||||
|
timeout.tv_sec = SELECT_TIMEOUT;
|
||||||
|
timeout.tv_usec = 0;
|
||||||
|
|
||||||
|
for(socket_fd = 0; socket_fd < MAX_SOCKETS; socket_fd ++)
|
||||||
|
if(socket_used[socket_fd])
|
||||||
|
FD_SET(socket_fd, &read_fds);
|
||||||
|
|
||||||
|
if(select(MAX_SOCKETS, &read_fds, NULL, NULL, &timeout)) {
|
||||||
|
for(socket_fd = 0; socket_fd < MAX_SOCKETS; socket_fd ++) {
|
||||||
|
if(socket_used[socket_fd] && FD_ISSET(socket_fd, &read_fds)) {
|
||||||
|
if(socket_fd == server_fd) {
|
||||||
|
struct sockaddr_in client_addr;
|
||||||
|
unsigned int client_addr_size = sizeof(client_addr);
|
||||||
|
int fd = accept(server_fd, (struct sockaddr *) &client_addr, &client_addr_size);
|
||||||
|
|
||||||
|
if(fd >= 0) {
|
||||||
|
printf("accept socket fd(%d)\n", fd);
|
||||||
|
socket_used[fd] = 1;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("accept error\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
int read_size = read(socket_fd, buf, sizeof(buf));
|
||||||
|
|
||||||
|
if(read_size > 0) {
|
||||||
|
write(socket_fd, buf, read_size);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("socket fd(%d) disconnected\n", socket_fd);
|
||||||
|
socket_used[socket_fd] = 0;
|
||||||
|
close(socket_fd);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("TCP server: no data in %d seconds\n", SELECT_TIMEOUT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
exit:
|
||||||
|
if(server_fd >= 0)
|
||||||
|
close(server_fd);
|
||||||
|
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_socket_select(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(example_socket_select_thread, ((const char*)"example_socket_select_thread"), 1024, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate(init_thread) failed", __FUNCTION__);
|
||||||
|
}
|
6
component/common/example/socket_select/example_socket_select.h
Executable file
6
component/common/example/socket_select/example_socket_select.h
Executable file
|
@ -0,0 +1,6 @@
|
||||||
|
#ifndef EXAMPLE_SOCKET_SELECT_H
|
||||||
|
#define EXAMPLE_SOCKET_SELECT_H
|
||||||
|
|
||||||
|
void example_socket_select(void);
|
||||||
|
|
||||||
|
#endif /* EXAMPLE_SOCKET_SELECT_H */
|
13
component/common/example/socket_select/readme.txt
Executable file
13
component/common/example/socket_select/readme.txt
Executable file
|
@ -0,0 +1,13 @@
|
||||||
|
LWIP SOCKET SELECT EXAMPLE
|
||||||
|
|
||||||
|
Description:
|
||||||
|
TCP server listens on port 5000 and handle socket by select().
|
||||||
|
|
||||||
|
Configuration:
|
||||||
|
[platform_opts.h]
|
||||||
|
#define CONFIG_EXAMPLE_SOCKET_SELECT 1
|
||||||
|
|
||||||
|
Execution:
|
||||||
|
Can make automatical Wi-Fi connection when booting by using wlan fast connect example.
|
||||||
|
A socket select example thread will be started automatically when booting.
|
||||||
|
|
129
component/common/example/wlan_fast_connect/example_wlan_fast_connect.c
Executable file
129
component/common/example/wlan_fast_connect/example_wlan_fast_connect.c
Executable file
|
@ -0,0 +1,129 @@
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2015 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
|
||||||
|
/** @file
|
||||||
|
|
||||||
|
This example demonstrate how to implement wifi fast reconnection
|
||||||
|
**/
|
||||||
|
#include <platform_opts.h>
|
||||||
|
#include <wlan_fast_connect/example_wlan_fast_connect.h>
|
||||||
|
|
||||||
|
|
||||||
|
#include "task.h"
|
||||||
|
#include <platform/platform_stdlib.h>
|
||||||
|
#include <wifi/wifi_conf.h>
|
||||||
|
#include "flash_api.h"
|
||||||
|
|
||||||
|
write_reconnect_ptr p_write_reconnect_ptr;
|
||||||
|
|
||||||
|
extern void fATW0(void *arg);
|
||||||
|
extern void fATW1(void *arg);
|
||||||
|
extern void fATW2(void *arg);
|
||||||
|
extern void fATWC(void *arg);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Usage:
|
||||||
|
* wifi connection indication trigger this function to save current
|
||||||
|
* wifi profile in flash
|
||||||
|
*
|
||||||
|
* Condition:
|
||||||
|
* CONFIG_EXAMPLE_WLAN_FAST_CONNECT flag is set
|
||||||
|
*/
|
||||||
|
|
||||||
|
int wlan_wrtie_reconnect_data_to_flash(u8 *data, uint32_t len)
|
||||||
|
{
|
||||||
|
flash_t flash;
|
||||||
|
struct wlan_fast_reconnect read_data = {0};
|
||||||
|
if(!data)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
flash_stream_read(&flash, FAST_RECONNECT_DATA, sizeof(struct wlan_fast_reconnect), (u8 *) &read_data);
|
||||||
|
|
||||||
|
//wirte it to flash if different content: SSID, Passphrase, Channel, Security type
|
||||||
|
if(memcmp(data, (u8 *) &read_data, sizeof(struct wlan_fast_reconnect)) != 0) {
|
||||||
|
printf("\r\n %s():not the same ssid/passphrase/channel, write new profile to flash", __func__);
|
||||||
|
flash_erase_sector(&flash, FAST_RECONNECT_DATA);
|
||||||
|
flash_stream_write(&flash, FAST_RECONNECT_DATA, len, (uint8_t *) data);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Usage:
|
||||||
|
* After wifi init done, waln driver call this function to check whether
|
||||||
|
* auto-connect is required.
|
||||||
|
*
|
||||||
|
* This function read previous saved wlan profile in flash and execute connection.
|
||||||
|
*
|
||||||
|
* Condition:
|
||||||
|
* CONFIG_EXAMPLE_WLAN_FAST_CONNECT flag is set
|
||||||
|
*/
|
||||||
|
int wlan_init_done_callback()
|
||||||
|
{
|
||||||
|
flash_t flash;
|
||||||
|
struct wlan_fast_reconnect *data;
|
||||||
|
uint32_t channel;
|
||||||
|
uint32_t security_type;
|
||||||
|
uint8_t pscan_config;
|
||||||
|
char key_id[2] = {0};
|
||||||
|
|
||||||
|
#if CONFIG_AUTO_RECONNECT
|
||||||
|
//setup reconnection flag
|
||||||
|
wifi_set_autoreconnect(1);
|
||||||
|
#endif
|
||||||
|
data = (struct wlan_fast_reconnect *)rtw_zmalloc(sizeof(struct wlan_fast_reconnect));
|
||||||
|
if(data){
|
||||||
|
flash_stream_read(&flash, FAST_RECONNECT_DATA, sizeof(struct wlan_fast_reconnect), (uint8_t *)data);
|
||||||
|
if(*((uint32_t *) data) != ~0x0){
|
||||||
|
memcpy(psk_essid, data->psk_essid, sizeof(data->psk_essid));
|
||||||
|
memcpy(psk_passphrase, data->psk_passphrase, sizeof(data->psk_passphrase));
|
||||||
|
memcpy(wpa_global_PSK, data->wpa_global_PSK, sizeof(data->wpa_global_PSK));
|
||||||
|
channel = data->channel;
|
||||||
|
sprintf(key_id,"%d",(char) (channel>>28));
|
||||||
|
channel &= 0xff;
|
||||||
|
security_type = data->security_type;
|
||||||
|
pscan_config = PSCAN_ENABLE | PSCAN_FAST_SURVEY;
|
||||||
|
//set partial scan for entering to listen beacon quickly
|
||||||
|
wifi_set_pscan_chan((uint8_t *)&channel, &pscan_config, 1);
|
||||||
|
|
||||||
|
//set wifi connect
|
||||||
|
switch(security_type){
|
||||||
|
case RTW_SECURITY_OPEN:
|
||||||
|
fATW0((char*)psk_essid);
|
||||||
|
break;
|
||||||
|
case RTW_SECURITY_WEP_PSK:
|
||||||
|
fATW0((char*)psk_essid);
|
||||||
|
fATW1((char*)psk_passphrase);
|
||||||
|
fATW2(key_id);
|
||||||
|
break;
|
||||||
|
case RTW_SECURITY_WPA_TKIP_PSK:
|
||||||
|
case RTW_SECURITY_WPA2_AES_PSK:
|
||||||
|
fATW0((char*)psk_essid);
|
||||||
|
fATW1((char*)psk_passphrase);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
fATWC(NULL);
|
||||||
|
}
|
||||||
|
rtw_mfree(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void example_wlan_fast_connect()
|
||||||
|
{
|
||||||
|
// Call back from wlan driver after wlan init done
|
||||||
|
p_wlan_init_done_callback = wlan_init_done_callback;
|
||||||
|
|
||||||
|
// Call back from application layer after wifi_connection success
|
||||||
|
p_write_reconnect_ptr = wlan_wrtie_reconnect_data_to_flash;
|
||||||
|
|
||||||
|
}
|
46
component/common/example/wlan_fast_connect/example_wlan_fast_connect.h
Executable file
46
component/common/example/wlan_fast_connect/example_wlan_fast_connect.h
Executable file
|
@ -0,0 +1,46 @@
|
||||||
|
#ifndef __EXAMPLE_FAST_RECONNECTION_H__
|
||||||
|
#define __EXAMPLE_FAST_RECONNECTION_H__
|
||||||
|
|
||||||
|
|
||||||
|
/******************************************************************************
|
||||||
|
*
|
||||||
|
* Copyright(c) 2007 - 2015 Realtek Corporation. All rights reserved.
|
||||||
|
*
|
||||||
|
*
|
||||||
|
******************************************************************************/
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include <autoconf.h>
|
||||||
|
|
||||||
|
#define IW_PASSPHRASE_MAX_SIZE 64
|
||||||
|
#define FAST_RECONNECT_DATA (0x80000 - 0x1000)
|
||||||
|
#define NDIS_802_11_LENGTH_SSID 32
|
||||||
|
#define A_SHA_DIGEST_LEN 20
|
||||||
|
|
||||||
|
|
||||||
|
struct wlan_fast_reconnect {
|
||||||
|
unsigned char psk_essid[NDIS_802_11_LENGTH_SSID + 4];
|
||||||
|
unsigned char psk_passphrase[IW_PASSPHRASE_MAX_SIZE + 1];
|
||||||
|
unsigned char wpa_global_PSK[A_SHA_DIGEST_LEN * 2];
|
||||||
|
uint32_t channel;
|
||||||
|
uint32_t security_type;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
typedef int (*wlan_init_done_ptr)(void);
|
||||||
|
typedef int (*write_reconnect_ptr)(uint8_t *data, uint32_t len);
|
||||||
|
|
||||||
|
|
||||||
|
//Variable
|
||||||
|
extern unsigned char psk_essid[NET_IF_NUM][NDIS_802_11_LENGTH_SSID+4];
|
||||||
|
extern unsigned char psk_passphrase[NET_IF_NUM][IW_PASSPHRASE_MAX_SIZE + 1];
|
||||||
|
extern unsigned char wpa_global_PSK[NET_IF_NUM][A_SHA_DIGEST_LEN * 2];
|
||||||
|
extern unsigned char psk_passphrase64[IW_PASSPHRASE_MAX_SIZE + 1];
|
||||||
|
|
||||||
|
//Function
|
||||||
|
extern wlan_init_done_ptr p_wlan_init_done_callback;
|
||||||
|
extern write_reconnect_ptr p_write_reconnect_ptr;
|
||||||
|
|
||||||
|
void example_wlan_fast_connect(void);
|
||||||
|
|
||||||
|
#endif //#ifndef __EXAMPLE_FAST_RECONNECTION_H__
|
111
component/common/example/xml/example_xml.c
Executable file
111
component/common/example/xml/example_xml.c
Executable file
|
@ -0,0 +1,111 @@
|
||||||
|
#include "FreeRTOS.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include <platform_stdlib.h>
|
||||||
|
#include "xml.h"
|
||||||
|
|
||||||
|
static void example_xml_thread(void *param)
|
||||||
|
{
|
||||||
|
/* Create XML document
|
||||||
|
* <Home:Light xmlns:Home="http://www.home.com" xmlns="http://www.device.com" fw_ver="1.0.0">
|
||||||
|
* <Power>on</Power>
|
||||||
|
* <Color>
|
||||||
|
* <Red>255</Red>
|
||||||
|
* <Green>255</Green>
|
||||||
|
* <Blud>255</Blue>
|
||||||
|
* </Color>
|
||||||
|
* </Home:Light>
|
||||||
|
*/
|
||||||
|
struct xml_node *light_node, *power_node, *color_node, *red_node, *green_node, *blue_node;
|
||||||
|
|
||||||
|
// Creates element with (prefix, tag name, namespace uri), add element and text node as child
|
||||||
|
light_node = xml_new_element("Home", "Light", "http://www.home.com");
|
||||||
|
power_node = xml_new_element(NULL, "Power", NULL);
|
||||||
|
xml_add_child(power_node, xml_new_text("on"));
|
||||||
|
color_node = xml_new_element(NULL, "Color", NULL);
|
||||||
|
red_node = xml_new_element(NULL, "Red", NULL);
|
||||||
|
xml_add_child(red_node, xml_new_text("255"));
|
||||||
|
green_node = xml_new_element(NULL, "Green", NULL);
|
||||||
|
xml_add_child(green_node, xml_new_text("255"));
|
||||||
|
blue_node = xml_new_element(NULL, "Blue", NULL);
|
||||||
|
xml_add_child(blue_node, xml_new_text("255"));
|
||||||
|
xml_add_child(light_node, power_node);
|
||||||
|
xml_add_child(light_node, color_node);
|
||||||
|
xml_add_child(color_node, red_node);
|
||||||
|
xml_add_child(color_node, green_node);
|
||||||
|
xml_add_child(color_node, blue_node);
|
||||||
|
|
||||||
|
// Add or modify attributes
|
||||||
|
xml_set_attribute(light_node, "xmlns", "http://www.device.com");
|
||||||
|
xml_set_attribute(light_node, "fw_ver", "1.0.0");
|
||||||
|
|
||||||
|
// Dump XML document to memory buffer, equal to xml_dump_tree_ex(node, NULL, 0, 0);
|
||||||
|
char *dump_buf = xml_dump_tree(light_node);
|
||||||
|
printf("\n%s\n", dump_buf);
|
||||||
|
// Free dump buffer
|
||||||
|
xml_free(dump_buf);
|
||||||
|
// Dump XML document to memory buffer with prolog, new line, aligment
|
||||||
|
dump_buf = xml_dump_tree_ex(light_node, "<?xml version=\"1.0\"?>", 1, 4);
|
||||||
|
printf("\n%s\n", dump_buf);
|
||||||
|
xml_free(dump_buf);
|
||||||
|
|
||||||
|
// Delete XML tree to free memory
|
||||||
|
xml_delete_tree(light_node);
|
||||||
|
|
||||||
|
/* Parse XML document */
|
||||||
|
char *doc = "\
|
||||||
|
<?xml version=\"1.0\"?>\
|
||||||
|
<!--sensor example-->\
|
||||||
|
<Home:Sensor>\
|
||||||
|
<Thermostat>\
|
||||||
|
<Mode>auto</Mode>\
|
||||||
|
<Temperature unit=\"celsius\">25.5</Temperature>\
|
||||||
|
</Thermostat>\
|
||||||
|
</Home:Sensor>";
|
||||||
|
|
||||||
|
// Parse document buffer to XML tree. Prolog will be dropped
|
||||||
|
struct xml_node *root = xml_parse(doc, strlen(doc));
|
||||||
|
|
||||||
|
if(root) {
|
||||||
|
dump_buf = xml_dump_tree_ex(root, NULL, 1, 4);
|
||||||
|
printf("\n%s\n", dump_buf);
|
||||||
|
xml_free(dump_buf);
|
||||||
|
|
||||||
|
// Search by XPath, prefix and name in path should be matched
|
||||||
|
struct xml_node_set *set = xml_find_path(root, "/Home:Sensor/Thermostat/Temperature");
|
||||||
|
|
||||||
|
if(set->count) {
|
||||||
|
printf("\nFind %d element by %s\n", set->count, "/Home:Sensor/Thermostat/Temperature");
|
||||||
|
|
||||||
|
// Get XML tree search result 0
|
||||||
|
struct xml_node *temperature_node = set->node[0];
|
||||||
|
|
||||||
|
if(xml_is_text(temperature_node->child)) {
|
||||||
|
// Get text
|
||||||
|
printf("Temperature[0] is %s\n", temperature_node->child->text);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get attribute
|
||||||
|
char *unit = xml_get_attribute(temperature_node, "unit");
|
||||||
|
printf("Unit is \"%s\"\n", unit);
|
||||||
|
// Free attribute search result
|
||||||
|
xml_free(unit);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Delete XML tree search result to free memory
|
||||||
|
xml_delete_set(set);
|
||||||
|
|
||||||
|
xml_delete_tree(root);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
printf("Xml parse failed\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
vTaskDelete(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void example_xml(void)
|
||||||
|
{
|
||||||
|
if(xTaskCreate(example_xml_thread, ((const char*)"example_xml_thread"), 1024, NULL, tskIDLE_PRIORITY + 1, NULL) != pdPASS)
|
||||||
|
printf("\n\r%s xTaskCreate(init_thread) failed", __FUNCTION__);
|
||||||
|
}
|
||||||
|
|
6
component/common/example/xml/example_xml.h
Executable file
6
component/common/example/xml/example_xml.h
Executable file
|
@ -0,0 +1,6 @@
|
||||||
|
#ifndef EXAMPLE_XML_H
|
||||||
|
#define EXAMPLE_XML_H
|
||||||
|
|
||||||
|
void example_xml(void);
|
||||||
|
|
||||||
|
#endif /* EXAMPLE_XML_H */
|
13
component/common/example/xml/readme.txt
Executable file
13
component/common/example/xml/readme.txt
Executable file
|
@ -0,0 +1,13 @@
|
||||||
|
XML EXAMPLE
|
||||||
|
|
||||||
|
Description:
|
||||||
|
The creation of a light XML document is used as the example of XML document generation.
|
||||||
|
The processing of a sensor XML document is used as the example of XML document parsing.
|
||||||
|
|
||||||
|
Configuration:
|
||||||
|
[platform_opts.h]
|
||||||
|
#define CONFIG_EXAMPLE_XML 1
|
||||||
|
|
||||||
|
Execution:
|
||||||
|
An XML example thread will be started automatically when booting.
|
||||||
|
|
66
component/common/mbed/api/error.h
Executable file
66
component/common/mbed/api/error.h
Executable file
|
@ -0,0 +1,66 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_ERROR_H
|
||||||
|
#define MBED_ERROR_H
|
||||||
|
|
||||||
|
/** To generate a fatal compile-time error, you can use the pre-processor #error directive.
|
||||||
|
*
|
||||||
|
* @code
|
||||||
|
* #error "That shouldn't have happened!"
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* If the compiler evaluates this line, it will report the error and stop the compile.
|
||||||
|
*
|
||||||
|
* For example, you could use this to check some user-defined compile-time variables:
|
||||||
|
*
|
||||||
|
* @code
|
||||||
|
* #define NUM_PORTS 7
|
||||||
|
* #if (NUM_PORTS > 4)
|
||||||
|
* #error "NUM_PORTS must be less than 4"
|
||||||
|
* #endif
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* Reporting Run-Time Errors:
|
||||||
|
* To generate a fatal run-time error, you can use the mbed error() function.
|
||||||
|
*
|
||||||
|
* @code
|
||||||
|
* error("That shouldn't have happened!");
|
||||||
|
* @endcode
|
||||||
|
*
|
||||||
|
* If the mbed running the program executes this function, it will print the
|
||||||
|
* message via the USB serial port, and then die with the blue lights of death!
|
||||||
|
*
|
||||||
|
* The message can use printf-style formatting, so you can report variables in the
|
||||||
|
* message too. For example, you could use this to check a run-time condition:
|
||||||
|
*
|
||||||
|
* @code
|
||||||
|
* if(x >= 5) {
|
||||||
|
* error("expected x to be less than 5, but got %d", x);
|
||||||
|
* }
|
||||||
|
* #endcode
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void error(const char* format, ...);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
50
component/common/mbed/api/mbed_assert.h
Executable file
50
component/common/mbed/api/mbed_assert.h
Executable file
|
@ -0,0 +1,50 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_ASSERT_H
|
||||||
|
#define MBED_ASSERT_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Internal mbed assert function which is invoked when MBED_ASSERT macro failes.
|
||||||
|
* This function is active only if NDEBUG is not defined prior to including this
|
||||||
|
* assert header file.
|
||||||
|
* In case of MBED_ASSERT failing condition, the assertation message is printed
|
||||||
|
* to stderr and mbed_die() is called.
|
||||||
|
* @param expr Expresion to be checked.
|
||||||
|
* @param file File where assertation failed.
|
||||||
|
* @param line Failing assertation line number.
|
||||||
|
*/
|
||||||
|
void mbed_assert_internal(const char *expr, const char *file, int line);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef NDEBUG
|
||||||
|
#define MBED_ASSERT(expr) ((void)0)
|
||||||
|
|
||||||
|
#else
|
||||||
|
#define MBED_ASSERT(expr) \
|
||||||
|
do { \
|
||||||
|
if (!(expr)) { \
|
||||||
|
mbed_assert_internal(#expr, __FILE__, __LINE__); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
74
component/common/mbed/api/rtc_time.h
Executable file
74
component/common/mbed/api/rtc_time.h
Executable file
|
@ -0,0 +1,74 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Implementation of the C time.h functions
|
||||||
|
*
|
||||||
|
* Provides mechanisms to set and read the current time, based
|
||||||
|
* on the microcontroller Real-Time Clock (RTC), plus some
|
||||||
|
* standard C manipulation and formating functions.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* #include "mbed.h"
|
||||||
|
*
|
||||||
|
* int main() {
|
||||||
|
* set_time(1256729737); // Set RTC time to Wed, 28 Oct 2009 11:35:37
|
||||||
|
*
|
||||||
|
* while(1) {
|
||||||
|
* time_t seconds = time(NULL);
|
||||||
|
*
|
||||||
|
* printf("Time as seconds since January 1, 1970 = %d\n", seconds);
|
||||||
|
*
|
||||||
|
* printf("Time as a basic string = %s", ctime(&seconds));
|
||||||
|
*
|
||||||
|
* char buffer[32];
|
||||||
|
* strftime(buffer, 32, "%I:%M %p\n", localtime(&seconds));
|
||||||
|
* printf("Time as a custom formatted string = %s", buffer);
|
||||||
|
*
|
||||||
|
* wait(1);
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** Set the current time
|
||||||
|
*
|
||||||
|
* Initialises and sets the time of the microcontroller Real-Time Clock (RTC)
|
||||||
|
* to the time represented by the number of seconds since January 1, 1970
|
||||||
|
* (the UNIX timestamp).
|
||||||
|
*
|
||||||
|
* @param t Number of seconds since January 1, 1970 (the UNIX timestamp)
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* #include "mbed.h"
|
||||||
|
*
|
||||||
|
* int main() {
|
||||||
|
* set_time(1256729737); // Set time to Wed, 28 Oct 2009 11:35:37
|
||||||
|
* }
|
||||||
|
* @endcode
|
||||||
|
*/
|
||||||
|
void set_time(time_t t);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
66
component/common/mbed/api/wait_api.h
Executable file
66
component/common/mbed/api/wait_api.h
Executable file
|
@ -0,0 +1,66 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_WAIT_API_H
|
||||||
|
#define MBED_WAIT_API_H
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/** Generic wait functions.
|
||||||
|
*
|
||||||
|
* These provide simple NOP type wait capabilities.
|
||||||
|
*
|
||||||
|
* Example:
|
||||||
|
* @code
|
||||||
|
* #include "mbed.h"
|
||||||
|
*
|
||||||
|
* DigitalOut heartbeat(LED1);
|
||||||
|
*
|
||||||
|
* int main() {
|
||||||
|
* while (1) {
|
||||||
|
* heartbeat = 1;
|
||||||
|
* wait(0.5);
|
||||||
|
* heartbeat = 0;
|
||||||
|
* wait(0.5);
|
||||||
|
* }
|
||||||
|
* }
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** Waits for a number of seconds, with microsecond resolution (within
|
||||||
|
* the accuracy of single precision floating point).
|
||||||
|
*
|
||||||
|
* @param s number of seconds to wait
|
||||||
|
*/
|
||||||
|
void wait(float s);
|
||||||
|
|
||||||
|
/** Waits a number of milliseconds.
|
||||||
|
*
|
||||||
|
* @param ms the whole number of milliseconds to wait
|
||||||
|
*/
|
||||||
|
void wait_ms(int ms);
|
||||||
|
|
||||||
|
/** Waits a number of microseconds.
|
||||||
|
*
|
||||||
|
* @param us the whole number of microseconds to wait
|
||||||
|
*/
|
||||||
|
void wait_us(int us);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
0
component/common/mbed/common/.gitkeep
Executable file
0
component/common/mbed/common/.gitkeep
Executable file
69
component/common/mbed/common/Makefile
Executable file
69
component/common/mbed/common/Makefile
Executable file
|
@ -0,0 +1,69 @@
|
||||||
|
|
||||||
|
include $(MAKE_INCLUDE_GEN)
|
||||||
|
|
||||||
|
.PHONY: all clean
|
||||||
|
|
||||||
|
MODULE_IFLAGS = -I../
|
||||||
|
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_TOOLCHAIN_ARM_GCC), y)
|
||||||
|
GCC_PROJ_BASE = ../../../../../
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/lib/sw_lib/mbed/hal/
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/lib/sw_lib/mbed/api/
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/lib/sw_lib/mbed/common/
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/os
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/os/os_dep/include
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/os/freertos/include
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/sw/os/freertos/portable/GCC/ARM_CM3
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/targets/cmsis/
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/targets/cmsis/TARGET_RTK/TARGET_8195A
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/targets/hal/TARGET_RTK/TARGET_8195A
|
||||||
|
MODULE_IFLAGS += -I$(GCC_PROJ_BASE)/targets/hal/TARGET_RTK/TARGET_8195A/rtl8195a
|
||||||
|
endif
|
||||||
|
|
||||||
|
#*****************************************************************************#
|
||||||
|
# Object FILE LIST #
|
||||||
|
#*****************************************************************************#
|
||||||
|
OBJS =
|
||||||
|
OBJS_ROM =
|
||||||
|
OBJS_RAM =
|
||||||
|
ifeq ($(CONFIG_TIMER_MODULE),y)
|
||||||
|
OBJS += us_ticker_api.o wait_api.o
|
||||||
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_LIB_BUILD_RAM),y)
|
||||||
|
OBJS = $(OBJS_RAM)
|
||||||
|
else ifeq ($(CONFIG_RELEASE_BUILD_RAM_ALL),y)
|
||||||
|
OBJS += $(OBJS_RAM)
|
||||||
|
else ifeq ($(CONFIG_RELEASE_BUILD_LIBRARIES),y)
|
||||||
|
OBJS = $(CSRC_ROM)
|
||||||
|
else ifeq ($(CONFIG_NORMAL_BUILD),y)
|
||||||
|
OBJS += $(CSRC_ROM)
|
||||||
|
OBJS += $(CSRC_RAM)
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
#*****************************************************************************#
|
||||||
|
# RULES TO GENERATE TARGETS #
|
||||||
|
#*****************************************************************************#
|
||||||
|
|
||||||
|
# Define the Rules to build the core targets
|
||||||
|
all: CORE_TARGETS COPY_RAM_OBJS
|
||||||
|
|
||||||
|
#*****************************************************************************#
|
||||||
|
# GENERATE OBJECT FILE
|
||||||
|
#*****************************************************************************#
|
||||||
|
CORE_TARGETS: $(OBJS)
|
||||||
|
|
||||||
|
|
||||||
|
#*****************************************************************************#
|
||||||
|
# RULES TO CLEAN TARGETS #
|
||||||
|
#*****************************************************************************#
|
||||||
|
clean:
|
||||||
|
$(REMOVE) *.o
|
||||||
|
$(REMOVE) *.i
|
||||||
|
$(REMOVE) *.s
|
||||||
|
$(REMOVE) *.d
|
||||||
|
|
||||||
|
-include $(DEPS)
|
118
component/common/mbed/common/us_ticker_api.c
Executable file
118
component/common/mbed/common/us_ticker_api.c
Executable file
|
@ -0,0 +1,118 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#include <stddef.h>
|
||||||
|
#include "us_ticker_api.h"
|
||||||
|
#include "cmsis.h"
|
||||||
|
|
||||||
|
static ticker_event_handler event_handler;
|
||||||
|
static ticker_event_t *head = NULL;
|
||||||
|
|
||||||
|
void us_ticker_set_handler(ticker_event_handler handler) {
|
||||||
|
us_ticker_init();
|
||||||
|
|
||||||
|
event_handler = handler;
|
||||||
|
}
|
||||||
|
|
||||||
|
void us_ticker_irq_handler(void) {
|
||||||
|
us_ticker_clear_interrupt();
|
||||||
|
|
||||||
|
/* Go through all the pending TimerEvents */
|
||||||
|
while (1) {
|
||||||
|
if (head == NULL) {
|
||||||
|
// There are no more TimerEvents left, so disable matches.
|
||||||
|
us_ticker_disable_interrupt();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((int)(head->timestamp - us_ticker_read()) <= 0) {
|
||||||
|
// This event was in the past:
|
||||||
|
// point to the following one and execute its handler
|
||||||
|
ticker_event_t *p = head;
|
||||||
|
head = head->next;
|
||||||
|
if (event_handler != NULL) {
|
||||||
|
event_handler(p->id); // NOTE: the handler can set new events
|
||||||
|
}
|
||||||
|
/* Note: We continue back to examining the head because calling the
|
||||||
|
* event handler may have altered the chain of pending events. */
|
||||||
|
} else {
|
||||||
|
// This event and the following ones in the list are in the future:
|
||||||
|
// set it as next interrupt and return
|
||||||
|
us_ticker_set_interrupt(head->timestamp);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void us_ticker_insert_event(ticker_event_t *obj, timestamp_t timestamp, uint32_t id) {
|
||||||
|
/* disable interrupts for the duration of the function */
|
||||||
|
__disable_irq();
|
||||||
|
|
||||||
|
// initialise our data
|
||||||
|
obj->timestamp = timestamp;
|
||||||
|
obj->id = id;
|
||||||
|
|
||||||
|
/* Go through the list until we either reach the end, or find
|
||||||
|
an element this should come before (which is possibly the
|
||||||
|
head). */
|
||||||
|
ticker_event_t *prev = NULL, *p = head;
|
||||||
|
while (p != NULL) {
|
||||||
|
/* check if we come before p */
|
||||||
|
if ((int)(timestamp - p->timestamp) <= 0) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
/* go to the next element */
|
||||||
|
prev = p;
|
||||||
|
p = p->next;
|
||||||
|
}
|
||||||
|
/* if prev is NULL we're at the head */
|
||||||
|
if (prev == NULL) {
|
||||||
|
head = obj;
|
||||||
|
us_ticker_set_interrupt(timestamp);
|
||||||
|
} else {
|
||||||
|
prev->next = obj;
|
||||||
|
}
|
||||||
|
/* if we're at the end p will be NULL, which is correct */
|
||||||
|
obj->next = p;
|
||||||
|
|
||||||
|
__enable_irq();
|
||||||
|
}
|
||||||
|
|
||||||
|
void us_ticker_remove_event(ticker_event_t *obj) {
|
||||||
|
__disable_irq();
|
||||||
|
|
||||||
|
// remove this object from the list
|
||||||
|
if (head == obj) {
|
||||||
|
// first in the list, so just drop me
|
||||||
|
head = obj->next;
|
||||||
|
if (head == NULL) {
|
||||||
|
us_ticker_disable_interrupt();
|
||||||
|
} else {
|
||||||
|
us_ticker_set_interrupt(head->timestamp);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// find the object before me, then drop me
|
||||||
|
ticker_event_t* p = head;
|
||||||
|
while (p != NULL) {
|
||||||
|
if (p->next == obj) {
|
||||||
|
p->next = obj->next;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
p = p->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
__enable_irq();
|
||||||
|
}
|
30
component/common/mbed/common/wait_api.c
Executable file
30
component/common/mbed/common/wait_api.c
Executable file
|
@ -0,0 +1,30 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#include "wait_api.h"
|
||||||
|
#include "us_ticker_api.h"
|
||||||
|
|
||||||
|
void wait(float s) {
|
||||||
|
wait_us((int)(s * 1000000.0f));
|
||||||
|
}
|
||||||
|
|
||||||
|
void wait_ms(int ms) {
|
||||||
|
wait_us(ms * 1000);
|
||||||
|
}
|
||||||
|
|
||||||
|
void wait_us(int us) {
|
||||||
|
uint32_t start = us_ticker_read();
|
||||||
|
while ((us_ticker_read() - start) < (uint32_t)us);
|
||||||
|
}
|
39
component/common/mbed/hal/analogin_api.h
Executable file
39
component/common/mbed/hal/analogin_api.h
Executable file
|
@ -0,0 +1,39 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_ANALOGIN_API_H
|
||||||
|
#define MBED_ANALOGIN_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_ANALOGIN
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct analogin_s analogin_t;
|
||||||
|
|
||||||
|
void analogin_init (analogin_t *obj, PinName pin);
|
||||||
|
float analogin_read (analogin_t *obj);
|
||||||
|
uint16_t analogin_read_u16(analogin_t *obj);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
42
component/common/mbed/hal/analogout_api.h
Executable file
42
component/common/mbed/hal/analogout_api.h
Executable file
|
@ -0,0 +1,42 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_ANALOGOUT_API_H
|
||||||
|
#define MBED_ANALOGOUT_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_ANALOGOUT
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct dac_s dac_t;
|
||||||
|
|
||||||
|
void analogout_init (dac_t *obj, PinName pin);
|
||||||
|
void analogout_free (dac_t *obj);
|
||||||
|
void analogout_write (dac_t *obj, float value);
|
||||||
|
void analogout_write_u16(dac_t *obj, uint16_t value);
|
||||||
|
float analogout_read (dac_t *obj);
|
||||||
|
uint16_t analogout_read_u16 (dac_t *obj);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
80
component/common/mbed/hal/can_api.h
Executable file
80
component/common/mbed/hal/can_api.h
Executable file
|
@ -0,0 +1,80 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_CAN_API_H
|
||||||
|
#define MBED_CAN_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_CAN
|
||||||
|
|
||||||
|
#include "PinNames.h"
|
||||||
|
#include "PeripheralNames.h"
|
||||||
|
#include "can_helper.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
IRQ_RX,
|
||||||
|
IRQ_TX,
|
||||||
|
IRQ_ERROR,
|
||||||
|
IRQ_OVERRUN,
|
||||||
|
IRQ_WAKEUP,
|
||||||
|
IRQ_PASSIVE,
|
||||||
|
IRQ_ARB,
|
||||||
|
IRQ_BUS,
|
||||||
|
IRQ_READY
|
||||||
|
} CanIrqType;
|
||||||
|
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
MODE_RESET,
|
||||||
|
MODE_NORMAL,
|
||||||
|
MODE_SILENT,
|
||||||
|
MODE_TEST_GLOBAL,
|
||||||
|
MODE_TEST_LOCAL,
|
||||||
|
MODE_TEST_SILENT
|
||||||
|
} CanMode;
|
||||||
|
|
||||||
|
typedef void (*can_irq_handler)(uint32_t id, CanIrqType type);
|
||||||
|
|
||||||
|
typedef struct can_s can_t;
|
||||||
|
|
||||||
|
void can_init (can_t *obj, PinName rd, PinName td);
|
||||||
|
void can_free (can_t *obj);
|
||||||
|
int can_frequency(can_t *obj, int hz);
|
||||||
|
|
||||||
|
void can_irq_init (can_t *obj, can_irq_handler handler, uint32_t id);
|
||||||
|
void can_irq_free (can_t *obj);
|
||||||
|
void can_irq_set (can_t *obj, CanIrqType irq, uint32_t enable);
|
||||||
|
|
||||||
|
int can_write (can_t *obj, CAN_Message, int cc);
|
||||||
|
int can_read (can_t *obj, CAN_Message *msg, int handle);
|
||||||
|
int can_mode (can_t *obj, CanMode mode);
|
||||||
|
int can_filter(can_t *obj, uint32_t id, uint32_t mask, CANFormat format, int32_t handle);
|
||||||
|
void can_reset (can_t *obj);
|
||||||
|
unsigned char can_rderror (can_t *obj);
|
||||||
|
unsigned char can_tderror (can_t *obj);
|
||||||
|
void can_monitor (can_t *obj, int silent);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif // MBED_CAN_API_H
|
||||||
|
|
||||||
|
#endif
|
63
component/common/mbed/hal/ethernet_api.h
Executable file
63
component/common/mbed/hal/ethernet_api.h
Executable file
|
@ -0,0 +1,63 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_ETHERNET_API_H
|
||||||
|
#define MBED_ETHERNET_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_ETHERNET
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// Connection constants
|
||||||
|
|
||||||
|
int ethernet_init(void);
|
||||||
|
void ethernet_free(void);
|
||||||
|
|
||||||
|
// write size bytes from data to ethernet buffer
|
||||||
|
// return num bytes written
|
||||||
|
// or -1 if size is too big
|
||||||
|
int ethernet_write(const char *data, int size);
|
||||||
|
|
||||||
|
// send ethernet write buffer, returning the packet size sent
|
||||||
|
int ethernet_send(void);
|
||||||
|
|
||||||
|
// recieve from ethernet buffer, returning packet size, or 0 if no packet
|
||||||
|
int ethernet_receive(void);
|
||||||
|
|
||||||
|
// read size bytes in to data, return actual num bytes read (0..size)
|
||||||
|
// if data == NULL, throw the bytes away
|
||||||
|
int ethernet_read(char *data, int size);
|
||||||
|
|
||||||
|
// get the ethernet address
|
||||||
|
void ethernet_address(char *mac);
|
||||||
|
|
||||||
|
// see if the link is up
|
||||||
|
int ethernet_link(void);
|
||||||
|
|
||||||
|
// force link settings
|
||||||
|
void ethernet_set_link(int speed, int duplex);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
51
component/common/mbed/hal/gpio_api.h
Executable file
51
component/common/mbed/hal/gpio_api.h
Executable file
|
@ -0,0 +1,51 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_GPIO_API_H
|
||||||
|
#define MBED_GPIO_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Set the given pin as GPIO
|
||||||
|
* @param pin The pin to be set as GPIO
|
||||||
|
* @return The GPIO port mask for this pin
|
||||||
|
**/
|
||||||
|
uint32_t gpio_set(PinName pin);
|
||||||
|
|
||||||
|
/* GPIO object */
|
||||||
|
void gpio_init(gpio_t *obj, PinName pin);
|
||||||
|
|
||||||
|
void gpio_mode (gpio_t *obj, PinMode mode);
|
||||||
|
void gpio_dir (gpio_t *obj, PinDirection direction);
|
||||||
|
|
||||||
|
void gpio_write(gpio_t *obj, int value);
|
||||||
|
int gpio_read (gpio_t *obj);
|
||||||
|
|
||||||
|
// the following set of functions are generic and are implemented in the common gpio.c file
|
||||||
|
void gpio_init_in(gpio_t* gpio, PinName pin);
|
||||||
|
void gpio_init_in_ex(gpio_t* gpio, PinName pin, PinMode mode);
|
||||||
|
void gpio_init_out(gpio_t* gpio, PinName pin);
|
||||||
|
void gpio_init_out_ex(gpio_t* gpio, PinName pin, int value);
|
||||||
|
void gpio_init_inout(gpio_t* gpio, PinName pin, PinDirection direction, PinMode mode, int value);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
47
component/common/mbed/hal/gpio_irq_api.h
Executable file
47
component/common/mbed/hal/gpio_irq_api.h
Executable file
|
@ -0,0 +1,47 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_GPIO_IRQ_API_H
|
||||||
|
#define MBED_GPIO_IRQ_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_INTERRUPTIN
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
IRQ_NONE,
|
||||||
|
IRQ_RISE,
|
||||||
|
IRQ_FALL
|
||||||
|
} gpio_irq_event;
|
||||||
|
|
||||||
|
typedef void (*gpio_irq_handler)(uint32_t id, gpio_irq_event event);
|
||||||
|
|
||||||
|
int gpio_irq_init(gpio_irq_t *obj, PinName pin, gpio_irq_handler handler, uint32_t id);
|
||||||
|
void gpio_irq_free(gpio_irq_t *obj);
|
||||||
|
void gpio_irq_set (gpio_irq_t *obj, gpio_irq_event event, uint32_t enable);
|
||||||
|
void gpio_irq_enable(gpio_irq_t *obj);
|
||||||
|
void gpio_irq_disable(gpio_irq_t *obj);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
58
component/common/mbed/hal/i2c_api.h
Executable file
58
component/common/mbed/hal/i2c_api.h
Executable file
|
@ -0,0 +1,58 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_I2C_API_H
|
||||||
|
#define MBED_I2C_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_I2C
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct i2c_s i2c_t;
|
||||||
|
|
||||||
|
enum {
|
||||||
|
I2C_ERROR_NO_SLAVE = -1,
|
||||||
|
I2C_ERROR_BUS_BUSY = -2
|
||||||
|
};
|
||||||
|
|
||||||
|
void i2c_init (i2c_t *obj, PinName sda, PinName scl);
|
||||||
|
void i2c_frequency (i2c_t *obj, int hz);
|
||||||
|
int i2c_start (i2c_t *obj);
|
||||||
|
int i2c_stop (i2c_t *obj);
|
||||||
|
int i2c_read (i2c_t *obj, int address, char *data, int length, int stop);
|
||||||
|
int i2c_write (i2c_t *obj, int address, const char *data, int length, int stop);
|
||||||
|
void i2c_reset (i2c_t *obj);
|
||||||
|
int i2c_byte_read (i2c_t *obj, int last);
|
||||||
|
int i2c_byte_write (i2c_t *obj, int data);
|
||||||
|
|
||||||
|
#if DEVICE_I2CSLAVE
|
||||||
|
void i2c_slave_mode (i2c_t *obj, int enable_slave);
|
||||||
|
int i2c_slave_receive(i2c_t *obj);
|
||||||
|
int i2c_slave_read (i2c_t *obj, char *data, int length);
|
||||||
|
int i2c_slave_write (i2c_t *obj, const char *data, int length);
|
||||||
|
void i2c_slave_address(i2c_t *obj, int idx, uint32_t address, uint32_t mask);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
43
component/common/mbed/hal/pinmap.h
Executable file
43
component/common/mbed/hal/pinmap.h
Executable file
|
@ -0,0 +1,43 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_PINMAP_H
|
||||||
|
#define MBED_PINMAP_H
|
||||||
|
|
||||||
|
#include "PinNames.h"
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct {
|
||||||
|
PinName pin;
|
||||||
|
int peripheral;
|
||||||
|
int function;
|
||||||
|
} PinMap;
|
||||||
|
|
||||||
|
void pin_function(PinName pin, int function);
|
||||||
|
void pin_mode (PinName pin, PinMode mode);
|
||||||
|
|
||||||
|
uint32_t pinmap_peripheral(PinName pin, const PinMap* map);
|
||||||
|
uint32_t pinmap_merge (uint32_t a, uint32_t b);
|
||||||
|
void pinmap_pinout (PinName pin, const PinMap *map);
|
||||||
|
uint32_t pinmap_find_peripheral(PinName pin, const PinMap* map);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
42
component/common/mbed/hal/port_api.h
Executable file
42
component/common/mbed/hal/port_api.h
Executable file
|
@ -0,0 +1,42 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_PORTMAP_H
|
||||||
|
#define MBED_PORTMAP_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_PORTIN || DEVICE_PORTOUT
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct port_s port_t;
|
||||||
|
|
||||||
|
PinName port_pin(PortName port, int pin_n);
|
||||||
|
|
||||||
|
void port_init (port_t *obj, PortName port, int mask, PinDirection dir);
|
||||||
|
void port_mode (port_t *obj, PinMode mode);
|
||||||
|
void port_dir (port_t *obj, PinDirection dir);
|
||||||
|
void port_write(port_t *obj, int value);
|
||||||
|
int port_read (port_t *obj);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
49
component/common/mbed/hal/pwmout_api.h
Executable file
49
component/common/mbed/hal/pwmout_api.h
Executable file
|
@ -0,0 +1,49 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_PWMOUT_API_H
|
||||||
|
#define MBED_PWMOUT_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_PWMOUT
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef struct pwmout_s pwmout_t;
|
||||||
|
|
||||||
|
void pwmout_init (pwmout_t* obj, PinName pin);
|
||||||
|
void pwmout_free (pwmout_t* obj);
|
||||||
|
|
||||||
|
void pwmout_write (pwmout_t* obj, float percent);
|
||||||
|
float pwmout_read (pwmout_t* obj);
|
||||||
|
|
||||||
|
void pwmout_period (pwmout_t* obj, float seconds);
|
||||||
|
void pwmout_period_ms (pwmout_t* obj, int ms);
|
||||||
|
void pwmout_period_us (pwmout_t* obj, int us);
|
||||||
|
|
||||||
|
void pwmout_pulsewidth (pwmout_t* obj, float seconds);
|
||||||
|
void pwmout_pulsewidth_ms(pwmout_t* obj, int ms);
|
||||||
|
void pwmout_pulsewidth_us(pwmout_t* obj, int us);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
42
component/common/mbed/hal/rtc_api.h
Executable file
42
component/common/mbed/hal/rtc_api.h
Executable file
|
@ -0,0 +1,42 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_RTC_API_H
|
||||||
|
#define MBED_RTC_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_RTC
|
||||||
|
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
void rtc_init(void);
|
||||||
|
void rtc_free(void);
|
||||||
|
int rtc_isenabled(void);
|
||||||
|
|
||||||
|
time_t rtc_read(void);
|
||||||
|
void rtc_write(time_t t);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
78
component/common/mbed/hal/serial_api.h
Executable file
78
component/common/mbed/hal/serial_api.h
Executable file
|
@ -0,0 +1,78 @@
|
||||||
|
/* mbed Microcontroller Library
|
||||||
|
* Copyright (c) 2006-2013 ARM Limited
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
#ifndef MBED_SERIAL_API_H
|
||||||
|
#define MBED_SERIAL_API_H
|
||||||
|
|
||||||
|
#include "device.h"
|
||||||
|
|
||||||
|
#if DEVICE_SERIAL
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
ParityNone = 0,
|
||||||
|
ParityOdd = 1,
|
||||||
|
ParityEven = 2,
|
||||||
|
ParityForced1 = 3,
|
||||||
|
ParityForced0 = 4
|
||||||
|
} SerialParity;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
RxIrq,
|
||||||
|
TxIrq
|
||||||
|
} SerialIrq;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
FlowControlNone,
|
||||||
|
FlowControlRTS,
|
||||||
|
FlowControlCTS,
|
||||||
|
FlowControlRTSCTS
|
||||||
|
} FlowControl;
|
||||||
|
|
||||||
|
typedef void (*uart_irq_handler)(uint32_t id, SerialIrq event);
|
||||||
|
|
||||||
|
typedef struct serial_s serial_t;
|
||||||
|
|
||||||
|
void serial_init (serial_t *obj, PinName tx, PinName rx);
|
||||||
|
void serial_free (serial_t *obj);
|
||||||
|
void serial_baud (serial_t *obj, int baudrate);
|
||||||
|
void serial_format (serial_t *obj, int data_bits, SerialParity parity, int stop_bits);
|
||||||
|
|
||||||
|
void serial_irq_handler(serial_t *obj, uart_irq_handler handler, uint32_t id);
|
||||||
|
void serial_irq_set (serial_t *obj, SerialIrq irq, uint32_t enable);
|
||||||
|
|
||||||
|
int serial_getc (serial_t *obj);
|
||||||
|
void serial_putc (serial_t *obj, int c);
|
||||||
|
int serial_readable (serial_t *obj);
|
||||||
|
int serial_writable (serial_t *obj);
|
||||||
|
void serial_clear (serial_t *obj);
|
||||||
|
|
||||||
|
void serial_break_set (serial_t *obj);
|
||||||
|
void serial_break_clear(serial_t *obj);
|
||||||
|
|
||||||
|
void serial_pinout_tx(PinName tx);
|
||||||
|
|
||||||
|
void serial_set_flow_control(serial_t *obj, FlowControl type, PinName rxflow, PinName txflow);
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue