optimize the codes with lwip and opcua

This commit is contained in:
wlyu 2022-03-21 16:47:32 +08:00
parent a52854efb6
commit f74d1dafd7
25 changed files with 452 additions and 2257 deletions

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2020 AIIT XUOS Lab * Copyright (c) 2022 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2. * XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2. * You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at: * You may obtain a copy of Mulan PSL v2 at:
@ -11,16 +11,14 @@
*/ */
/** /**
* @file tcp_echo_socket_demo.c * @file lwip_tcp_socket_demo.c
* @brief One UDP demo based on LwIP * @brief TCP socket demo based on LwIP
* @version 1.0 * @version 1.0
* @author AIIT XUOS Lab * @author AIIT XUOS Lab
* @date 2021-05-29 * @date 2022-03-21
*/ */
#include <transform.h> #include <transform.h>
#include <xizi.h>
#include "board.h"
#include "sys_arch.h" #include "sys_arch.h"
#include <lwip/sockets.h> #include <lwip/sockets.h>
#include "lwip/sys.h" #include "lwip/sys.h"
@ -28,6 +26,7 @@
#define TCP_DEMO_BUF_SIZE 65535 #define TCP_DEMO_BUF_SIZE 65535
char tcp_socket_ip[] = {192, 168, 250, 252}; char tcp_socket_ip[] = {192, 168, 250, 252};
u16_t tcp_socket_port = LWIP_TARGET_PORT;
/******************************************************************************/ /******************************************************************************/
@ -44,36 +43,41 @@ static void TCPSocketRecvTask(void *arg)
recv_buf = (char *)malloc(TCP_DEMO_BUF_SIZE); recv_buf = (char *)malloc(TCP_DEMO_BUF_SIZE);
if (recv_buf == NULL) if (recv_buf == NULL)
{ {
lw_print("No memory\n"); lw_error("No memory\n");
goto __exit; continue;
} }
fd = socket(AF_INET, SOCK_STREAM, 0); fd = socket(AF_INET, SOCK_STREAM, 0);
if (fd < 0) if (fd < 0)
{ {
lw_print("Socket error\n"); lw_error("Socket error\n");
goto __exit; free(recv_buf);
continue;
} }
tcp_addr.sin_family = AF_INET; tcp_addr.sin_family = AF_INET;
tcp_addr.sin_addr.s_addr = INADDR_ANY; tcp_addr.sin_addr.s_addr = INADDR_ANY;
tcp_addr.sin_port = htons(LWIP_LOCAL_PORT); tcp_addr.sin_port = htons(tcp_socket_port);
memset(&(tcp_addr.sin_zero), 0, sizeof(tcp_addr.sin_zero)); memset(&(tcp_addr.sin_zero), 0, sizeof(tcp_addr.sin_zero));
if (bind(fd, (struct sockaddr *)&tcp_addr, sizeof(struct sockaddr)) == -1) if (bind(fd, (struct sockaddr *)&tcp_addr, sizeof(struct sockaddr)) == -1)
{ {
lw_print("Unable to bind\n"); lw_error("Unable to bind\n");
goto __exit; closesocket(fd);
free(recv_buf);
continue;
} }
lw_print("tcp bind success, start to receive.\n"); lw_print("tcp bind success, start to receive.\n");
lw_notice("\n\nLocal Port:%d\n\n", LWIP_LOCAL_PORT); lw_notice("\n\nLocal Port:%d\n\n", tcp_socket_port);
// setup socket fd as listening mode // setup socket fd as listening mode
if (listen(fd, 5) != 0 ) if (listen(fd, 5) != 0 )
{ {
lw_print("Unable to listen\n"); lw_error("Unable to listen\n");
goto __exit; closesocket(fd);
free(recv_buf);
continue;
} }
// accept client connection // accept client connection
@ -91,27 +95,24 @@ static void TCPSocketRecvTask(void *arg)
} }
sendto(clientfd, recv_buf, recv_len, 0, (struct sockaddr*)&tcp_addr, addr_len); sendto(clientfd, recv_buf, recv_len, 0, (struct sockaddr*)&tcp_addr, addr_len);
} }
__exit:
if (fd >= 0)
closesocket(fd);
if (recv_buf)
free(recv_buf);
} }
closesocket(fd);
free(recv_buf);
} }
void TCPSocketRecvTest(int argc, char *argv[]) void TCPSocketRecvTest(int argc, char *argv[])
{ {
int result = 0; int result = 0;
pthread_t th_id;
pthread_attr_t attr;
if(argc == 2) if(argc >= 2)
{
lw_print("lw: [%s] target ip %s\n", __func__, argv[1]);
if(sscanf(argv[1], "%d.%d.%d.%d:%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3], &tcp_socket_port) == EOK)
{ {
lw_print("lw: [%s] gw %s\n", __func__, argv[1]);
sscanf(argv[1], "%d.%d.%d.%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3]); sscanf(argv[1], "%d.%d.%d.%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3]);
} }
}
lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_socket_ip); lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_socket_ip);
sys_thread_new("TCPSocketRecvTask", TCPSocketRecvTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("TCPSocketRecvTask", TCPSocketRecvTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
@ -138,7 +139,7 @@ static void TCPSocketSendTask(void *arg)
struct sockaddr_in tcp_sock; struct sockaddr_in tcp_sock;
tcp_sock.sin_family = AF_INET; tcp_sock.sin_family = AF_INET;
tcp_sock.sin_port = htons(LWIP_TARGET_PORT); tcp_sock.sin_port = htons(tcp_socket_port);
tcp_sock.sin_addr.s_addr = PP_HTONL(LWIP_MAKEU32(tcp_socket_ip[0], tcp_socket_ip[1], tcp_socket_ip[2], tcp_socket_ip[3])); tcp_sock.sin_addr.s_addr = PP_HTONL(LWIP_MAKEU32(tcp_socket_ip[0], tcp_socket_ip[1], tcp_socket_ip[2], tcp_socket_ip[3]));
memset(&(tcp_sock.sin_zero), 0, sizeof(tcp_sock.sin_zero)); memset(&(tcp_sock.sin_zero), 0, sizeof(tcp_sock.sin_zero));
@ -149,8 +150,7 @@ static void TCPSocketSendTask(void *arg)
return; return;
} }
lw_print("tcp connect success, start to send.\n"); lw_notice("\n\nTarget Port:%d\n\n", tcp_socket_port);
lw_notice("\n\nTarget Port:%d\n\n", LWIP_TARGET_PORT);
while (cnt --) while (cnt --)
{ {
@ -168,14 +168,17 @@ static void TCPSocketSendTask(void *arg)
void TCPSocketSendTest(int argc, char *argv[]) void TCPSocketSendTest(int argc, char *argv[])
{ {
if(argc == 2) if(argc >= 2)
{
lw_print("lw: [%s] target ip %s\n", __func__, argv[1]);
if(sscanf(argv[1], "%d.%d.%d.%d:%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3], &tcp_socket_port) == EOK)
{ {
lw_print("lw: [%s] gw %s\n", __func__, argv[1]);
sscanf(argv[1], "%d.%d.%d.%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3]); sscanf(argv[1], "%d.%d.%d.%d", &tcp_socket_ip[0], &tcp_socket_ip[1], &tcp_socket_ip[2], &tcp_socket_ip[3]);
} }
}
lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_socket_ip); lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_socket_ip);
sys_thread_new("tcp socket", TCPSocketSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("TCP Socket Send", TCPSocketSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0),

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2020 AIIT XUOS Lab * Copyright (c) 2022 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2. * XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2. * You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at: * You may obtain a copy of Mulan PSL v2 at:
@ -12,33 +12,25 @@
/** /**
* @file lwip_udp_socket_demo.c * @file lwip_udp_socket_demo.c
* @brief One UDP demo based on LwIP * @brief UDP demo based on LwIP
* @version 1.0 * @version 1.0
* @author AIIT XUOS Lab * @author AIIT XUOS Lab
* @date 2021-05-29 * @date 2022-03-21
*/ */
#include <transform.h> #include <transform.h>
#include <xizi.h>
#include "board.h"
#include "sys_arch.h" #include "sys_arch.h"
#include "lwip/udp.h" #include "lwip/sockets.h"
#include "lwip/opt.h"
#include <lwip/sockets.h>
#include "lwip/sys.h"
#define UDP_BUF_SIZE 65536 #define UDP_BUF_SIZE 65536
extern char udp_target[];
static struct udp_pcb *udpecho_raw_pcb;
char udp_socket_ip[] = {192, 168, 250, 252}; char udp_socket_ip[] = {192, 168, 250, 252};
u16_t udp_socket_port = LWIP_LOCAL_PORT;
/******************************************************************************/ /*****************************************************************************/
static void UdpSocketRecvTask(void *arg) static void UdpSocketRecvTask(void *arg)
{ {
lw_print("UdpSocketRecvTask start.\n"); int fd = -1;
int socket_fd = -1;
char *recv_buf; char *recv_buf;
struct sockaddr_in udp_addr, server_addr; struct sockaddr_in udp_addr, server_addr;
int recv_len; int recv_len;
@ -49,134 +41,124 @@ static void UdpSocketRecvTask(void *arg)
recv_buf = (char *)malloc(UDP_BUF_SIZE); recv_buf = (char *)malloc(UDP_BUF_SIZE);
if(recv_buf == NULL) if(recv_buf == NULL)
{ {
lw_print("No memory\n"); lw_error("No memory\n");
goto __exit; continue;
} }
socket_fd = socket(AF_INET, SOCK_DGRAM, 0); fd = socket(AF_INET, SOCK_DGRAM, 0);
if(socket_fd < 0) if(fd < 0)
{ {
lw_print("Socket error\n"); lw_error("Socket error\n");
goto __exit; free(recv_buf);
continue;
} }
udp_addr.sin_family = AF_INET; udp_addr.sin_family = AF_INET;
udp_addr.sin_addr.s_addr = INADDR_ANY; udp_addr.sin_addr.s_addr = INADDR_ANY;
udp_addr.sin_port = htons(LWIP_LOCAL_PORT); udp_addr.sin_port = htons(udp_socket_port);
memset(&(udp_addr.sin_zero), 0, sizeof(udp_addr.sin_zero)); memset(&(udp_addr.sin_zero), 0, sizeof(udp_addr.sin_zero));
if(bind(socket_fd, (struct sockaddr *)&udp_addr, sizeof(struct sockaddr)) == -1) if(bind(fd, (struct sockaddr *)&udp_addr, sizeof(struct sockaddr)) == -1)
{ {
lw_print("Unable to bind\n"); lw_error("Unable to bind\n");
goto __exit; closesocket(fd);
free(recv_buf);
continue;
} }
lw_print("UDP bind sucess, start to receive.\n"); lw_notice("UDP bind sucess, start to receive.\n");
lw_print("\n\nLocal Port:%d\n\n", LWIP_LOCAL_PORT); lw_notice("\n\nLocal Port:%d\n\n", udp_socket_port);
while(1) while(1)
{ {
memset(recv_buf, 0, UDP_BUF_SIZE); memset(recv_buf, 0, UDP_BUF_SIZE);
recv_len = recvfrom(socket_fd, recv_buf, UDP_BUF_SIZE, 0, (struct sockaddr *)&server_addr, &addr_len); recv_len = recvfrom(fd, recv_buf, UDP_BUF_SIZE, 0, (struct sockaddr *)&server_addr, &addr_len);
if(recv_len > 0)
{
lw_notice("Receive from : %s\n", inet_ntoa(server_addr.sin_addr)); lw_notice("Receive from : %s\n", inet_ntoa(server_addr.sin_addr));
lw_notice("Receive data : %s\n\n", recv_buf); lw_notice("Receive data : %s\n\n", recv_buf);
sendto(socket_fd, recv_buf, recv_len, 0, (struct sockaddr*)&server_addr, addr_len); }
sendto(fd, recv_buf, recv_len, 0, (struct sockaddr*)&server_addr, addr_len);
} }
__exit: closesocket(fd);
if(socket_fd >= 0)
{
closesocket(socket_fd);
}
if(recv_buf)
{
free(recv_buf); free(recv_buf);
} }
} }
}
void UdpSocketRecvTask(int argc, char *argv[]) void UdpSocketRecvTest(int argc, char *argv[])
{ {
int result = 0; if(argc >= 2)
pthread_t th_id; {
pthread_attr_t attr; lw_notice("lw: [%s] target ip %s\n", __func__, argv[1]);
if(sscanf(argv[1], "%d.%d.%d.%d:%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3], &udp_socket_port) == EOK)
if(argc == 2)
{ {
lw_print("lw: [%s] gw %s\n", __func__, argv[1]);
sscanf(argv[1], "%d.%d.%d.%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3]); sscanf(argv[1], "%d.%d.%d.%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3]);
} }
}
lwip_config_tcp(lwip_ipaddr, lwip_netmask, lwip_gwaddr); lwip_config_tcp(lwip_ipaddr, lwip_netmask, udp_socket_ip);
sys_thread_new("UdpSocketRecvTask", UdpSocketRecvTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("UdpSocketRecvTask", UdpSocketRecvTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3),
UDPSocketRecv, UdpSocketRecvTask, UDP recv echo); UDPSocketRecv, UdpSocketRecvTest, UDP Receive DEMO);
static void UdpSocketSendTask(void *arg) static void UdpSocketSendTask(void *arg)
{ {
int cnt = LWIP_DEMO_TIMES; int cnt = LWIP_DEMO_TIMES;
char send_str[128]; char send_str[128];
int fd = -1;
lw_print("UdpSocketSendTask start.\n");
int socket_fd = -1;
memset(send_str, 0, sizeof(send_str)); memset(send_str, 0, sizeof(send_str));
socket_fd = socket(AF_INET, SOCK_DGRAM, 0); fd = socket(AF_INET, SOCK_DGRAM, 0);
if(socket_fd < 0) if(fd < 0)
{ {
lw_print("Socket error\n"); lw_error("Socket error\n");
goto __exit; return;
} }
struct sockaddr_in udp_sock; struct sockaddr_in udp_sock;
udp_sock.sin_family = AF_INET; udp_sock.sin_family = AF_INET;
udp_sock.sin_port = htons(LWIP_TARGET_PORT); udp_sock.sin_port = htons(udp_socket_port);
udp_sock.sin_addr.s_addr = PP_HTONL(LWIP_MAKEU32(udp_target[0], udp_target[1], udp_target[2], udp_target[3])); udp_sock.sin_addr.s_addr = PP_HTONL(LWIP_MAKEU32(udp_socket_ip[0], udp_socket_ip[1], udp_socket_ip[2], udp_socket_ip[3]));
memset(&(udp_sock.sin_zero), 0, sizeof(udp_sock.sin_zero)); memset(&(udp_sock.sin_zero), 0, sizeof(udp_sock.sin_zero));
if(connect(socket_fd, (struct sockaddr *)&udp_sock, sizeof(struct sockaddr))) if(connect(fd, (struct sockaddr *)&udp_sock, sizeof(struct sockaddr)))
{ {
lw_print("Unable to connect\n"); lw_error("Unable to connect\n");
goto __exit; closesocket(fd);
return;
} }
lw_print("UDP connect success, start to send.\n"); lw_print("UDP connect success, start to send.\n");
lw_print("\n\nTarget Port:%d\n\n", udp_sock.sin_port); lw_notice("\n\nTarget Port:%d\n\n", udp_sock.sin_port);
while (cnt --) while (cnt --)
{ {
snprintf(send_str, sizeof(send_str), "UDP test package times %d\r\n", cnt); snprintf(send_str, sizeof(send_str), "UDP test package times %d\r\n", cnt);
sendto(socket_fd, send_str, strlen(send_str), 0, (struct sockaddr*)&udp_sock, sizeof(struct sockaddr)); sendto(fd, send_str, strlen(send_str), 0, (struct sockaddr*)&udp_sock, sizeof(struct sockaddr));
lw_notice("Send UDP msg: %s ", send_str); lw_notice("Send UDP msg: %s ", send_str);
MdelayKTask(1000); MdelayKTask(1000);
} }
__exit: closesocket(fd);
if(socket_fd >= 0)
{
closesocket(socket_fd);
}
return; return;
} }
void UdpSocketSendTest(int argc, char *argv[]) void UdpSocketSendTest(int argc, char *argv[])
{ {
int result = 0; if(argc >= 2)
pthread_t th_id; {
pthread_attr_t attr; lw_notice("lw: [%s] target ip %s\n", __func__, argv[1]);
if(sscanf(argv[1], "%d.%d.%d.%d:%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3], &udp_socket_port) == EOK)
if(argc == 2)
{ {
lw_print("lw: [%s] gw %s\n", __func__, argv[1]);
sscanf(argv[1], "%d.%d.%d.%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3]); sscanf(argv[1], "%d.%d.%d.%d", &udp_socket_ip[0], &udp_socket_ip[1], &udp_socket_ip[2], &udp_socket_ip[3]);
} }
}
lwip_config_tcp(lwip_ipaddr, lwip_netmask, lwip_gwaddr); lwip_config_tcp(lwip_ipaddr, lwip_netmask, udp_socket_ip);
sys_thread_new("UdpSocketSendTask", UdpSocketSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("UdpSocketSendTask", UdpSocketSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
} }

View File

@ -0,0 +1,16 @@
# OPCUA DEMO README
## 文件说明
用于OPCUA 相关测试命令演示需要开启LWIP和OPCUA协议.
### 命令行
UaConnect [IP]
用于测试与OPCUA服务器连接连接成功应显示OK
UaObject [IP]
用于显示对应的OPCUA设备的节点信息

View File

@ -0,0 +1,48 @@
# PLC DEMO README
## 文件说明
用于PLC设备相关测试命令演示目前支持OPCUA协议对PLC进行远程控制该命令基于LWIP和OPCUA需要开启相关开关。
多个PLC设备可以组成一个channel用于一条相关业务线控制。
### 命令行
ShowChannel
显示注册到channel上的PLC设备范例如下
ch_type ch_name drv_name dev_name cnt
-----------------------------------------------------------------
PLC_Channel PLC OPCUA PLC Demo 4 1
PLC Demo 3 2
PLC Demo 2 3
PLC Demo 1 4
PLC Demo 0 5
ShowPLC
用于显示PLC范例如下
device vendor model product id
-----------------------------------------------------------------
PLC Demo 4 B&R X20 X20 CP1381 5
PLC Demo 3 B&R X20 X20 CP1586 4
PLC Demo 2 SIEMSNS S7-200 CPU SR60 3
PLC Demo 1 SIEMENS S7-1200 CPU 1215C 2
PLC Demo 0 SIEMENS S7-1500 CPU 1512SP-1PN 1
PlcRead [NodeID]
用于读取PLC节点信息
- [NodeID]: 如n4,1, 其中4代表namespace1代表节点号
PlcWrite
用于写入PLC节点数值
- [NodeID]: 如n4,1, 其中4代表namespace1代表节点号
- [value]: 为写入数值目前支持bool类型和int类型。bool型应为0b(代表false), 1b(代表true)

View File

@ -101,8 +101,6 @@ void PlcReadUATask(void* arg)
if(EOK != ret) if(EOK != ret)
{ {
plc_print("plc: [%s] open failed %#x\n", __func__, ret); plc_print("plc: [%s] open failed %#x\n", __func__, ret);
// free(plc_demo_dev.priv_data);
// plc_demo_dev.priv_data = NULL;
return; return;
} }
@ -163,8 +161,6 @@ void PlcWriteUATask(void* arg)
if(EOK != ret) if(EOK != ret)
{ {
plc_print("plc: [%s] open failed %#x\n", __func__, ret); plc_print("plc: [%s] open failed %#x\n", __func__, ret);
// free(plc_demo_dev.priv_data);
// plc_demo_dev.priv_data = NULL;
return; return;
} }

View File

@ -0,0 +1,18 @@
# PLC SOCKET README
## 文件说明
用于测试PLC socket通信. 通过建立与制定IP的PLC设备的socket连接, 发送命令给PLC设备, 实现相关功能. 实现该功能需要开启LWIP, 同时需要扩大shell的栈大小和内存空间。
### 命令行
PLCSocket ip=[PLC IP] port=[PLC port] tcp=[1: TCP; 0: UDP] cmd=[相关命令] file=[制定配置文件]
配置文件支持json格式, 默认文件名为socket_param.json, 放置于plc目录下, 文件内容如下:
{
"ip": "192.168.250.6",
"port": 102,
"tcp": 1,
"cmd": [x, x, x]
}

View File

@ -24,56 +24,18 @@
#include "lwip/sockets.h" #include "lwip/sockets.h"
#include "control_file.h" #include "control_file.h"
#define PLC_SOCK_CMD_NUM 10 // max support plc socket test commands number
#define PLC_SOCK_CMD_NUM CTL_CMD_NUM
#define PLC_SOCK_TIMEOUT 50000
// for saving PLC command // for saving PLC command index
int plc_cmd_index = 0; int plc_cmd_index = 0;
// only for test
#define SUPPORT_PLC_SIEMENS
//siemens test //siemens test
PlcBinCmdType TestPlcCmd[PLC_SOCK_CMD_NUM] = PlcBinCmdType TestPlcCmd[PLC_SOCK_CMD_NUM] = {0};
{
#ifdef SUPPORT_PLC_SIEMENS
// handshake1 repeat 1
{
0, 3000, 22,
{
0x03, 0x00, 0x00, 0x16, 0x11, 0xE0, 0x00, 0x00,
0x02, 0xC8, 0x00, 0xC1, 0x02, 0x02, 0x01, 0xC2,
0x02, 0x02, 0x01, 0xC0, 0x01, 0x0A
}
},
// handshake2
{
1, 500, 25,
{
0x03, 0x00, 0x00, 0x19, 0x02, 0xF0, 0x80, 0x32,
0x01, 0x00, 0x00, 0x00, 0x0D, 0x00, 0x08, 0x00,
0x00, 0xF0, 0x00, 0x00, 0x01, 0x00, 0x01, 0x00,
0xF0
}
},
// read command
{
2, 1000, 31,
{
0x03, 0x00, 0x00, 0x1F, 0x02, 0xF0, 0x80, 0x32,
0x01, 0x00, 0x00, 0x33, 0x01, 0x00, 0x0E, 0x00,
0x00, 0x04, 0x01, 0x12, 0x0A, 0x10, 0x02, 0x00,
0xD2, 0x00, 0x34, 0x84, 0x00, 0x00, 0x00
}
}
// oml plc
#else// SUPPORT_PLC_OML
{
0, 1000, 18,
{
0x80, 0x00, 0x02, 0x00, 0x03, 0x00, 0x00, 0x7E,
0x00, 0x00, 0x01, 0x01, 0x82, 0x0F, 0xA0, 0x00,
0x00, 0x20
}
}
#endif
};
//Test information //Test information
//SIEMENS ip: 192.168.250.9 port: 102 //SIEMENS ip: 192.168.250.9 port: 102
@ -82,14 +44,21 @@ PlcBinCmdType TestPlcCmd[PLC_SOCK_CMD_NUM] =
//OML ip: 192.168.250.3 port: 9600 //OML ip: 192.168.250.3 port: 9600
PlcSocketParamType plc_socket_demo_data = { PlcSocketParamType plc_socket_demo_data = {
#ifdef SUPPORT_PLC_SIEMENS
.ip = {192, 168, 250, 6},
.port = 102,
.device_type = PLC_DEV_TYPE_SIEMENS,
.socket_type = SOCK_STREAM,
.cmd_num = 3,
#else
.ip = {192, 168, 250, 3}, .ip = {192, 168, 250, 3},
.port = 9600, .port = 9600,
.device_type = PLC_DEV_TYPE_OML, .device_type = PLC_DEV_TYPE_OML,
.socket_type = SOCK_STREAM, //SOCK_DGRAM, //udp .socket_type = SOCK_DGRAM,
.step = 0, .cmd_num = 1,
.cmd_num = 3, #endif
.buf_size = PLC_TEST_SIZE, .recv_len = PLC_RECV_BUF_LEN,
.buf = NULL, .recv_buf = NULL,
}; };
#define OML_HEADER_LEN 78 #define OML_HEADER_LEN 78
@ -97,12 +66,20 @@ PlcSocketParamType plc_socket_demo_data = {
/******************************************************************************/ /******************************************************************************/
static void plc_print_array(char *title, int size, uint8_t *cmd)
{
lw_notice("%s : %d - ", title, size);
for(int i = 0; i < size; i++)
{
lw_notice(" %#x", cmd[i]);
}
lw_notice("\n");
}
static void *PlcSocketStart(void *arg) static void *PlcSocketStart(void *arg)
{ {
int fd = -1; int fd = -1;
int recv_len; int timeout, recv_len;
int step = 0;
char *recv_buf;
struct sockaddr_in sock_addr; struct sockaddr_in sock_addr;
socklen_t addr_len = sizeof(struct sockaddr_in); socklen_t addr_len = sizeof(struct sockaddr_in);
PlcSocketParamType *param = (PlcSocketParamType *)&plc_socket_demo_data; PlcSocketParamType *param = (PlcSocketParamType *)&plc_socket_demo_data;
@ -116,9 +93,11 @@ static void *PlcSocketStart(void *arg)
param->device_type, param->device_type,
param->socket_type); param->socket_type);
param->recv_len = PLC_RECV_BUF_LEN;
//malloc memory //malloc memory
recv_buf = (char *)malloc(param->buf_size); param->recv_buf = (char *)malloc(param->recv_len);
if (recv_buf == NULL) if (param->recv_buf == NULL)
{ {
plc_error("No memory\n"); plc_error("No memory\n");
return NULL; return NULL;
@ -128,7 +107,7 @@ static void *PlcSocketStart(void *arg)
if (fd < 0) if (fd < 0)
{ {
plc_error("Socket error %d\n", param->socket_type); plc_error("Socket error %d\n", param->socket_type);
free(recv_buf); free(param->recv_buf);
return NULL; return NULL;
} }
@ -143,51 +122,42 @@ static void *PlcSocketStart(void *arg)
{ {
plc_error("Unable to connect\n"); plc_error("Unable to connect\n");
closesocket(fd); closesocket(fd);
free(recv_buf); free(param->recv_buf);
return NULL; return NULL;
} }
lw_notice("client %s connected\n", inet_ntoa(sock_addr.sin_addr)); lw_notice("client %s connected\n", inet_ntoa(sock_addr.sin_addr));
while(step < param->cmd_num) for(int i = 0; i < param->cmd_num; i ++)
{ {
sendto(fd, TestPlcCmd[step].cmd, TestPlcCmd[step].cmd_len, 0, (struct sockaddr*)&sock_addr, addr_len); PlcBinCmdType *cmd = &TestPlcCmd[i];
lw_notice("Send Cmd: %d - ", TestPlcCmd[step].cmd_len); sendto(fd, cmd->cmd, cmd->cmd_len, 0, (struct sockaddr*)&sock_addr, addr_len);
for(int i = 0; i < TestPlcCmd[step].cmd_len; i++) plc_print_array("Send cmd", cmd->cmd_len, cmd->cmd);
{
lw_notice(" %#x", TestPlcCmd[step].cmd[i]);
}
lw_notice("\n");
MdelayKTask(TestPlcCmd[step].delay_ms);
memset(recv_buf, 0, param->buf_size); MdelayKTask(cmd->delay_ms);
while(1) timeout = PLC_SOCK_TIMEOUT;
memset(param->recv_buf, 0, param->recv_len);
while(timeout --)
{ {
recv_len = recvfrom(fd, recv_buf, param->buf_size, 0, (struct sockaddr *)&sock_addr, &addr_len); recv_len = recvfrom(fd, param->recv_buf, param->recv_len, 0, (struct sockaddr *)&sock_addr, &addr_len);
if(recv_len > 0) if(recv_len > 0)
{ {
if(param->device_type == PLC_DEV_TYPE_OML) if(param->device_type == PLC_DEV_TYPE_OML)
{ {
if((recv_len == OML_HEADER_LEN) && (CHECK_OML_HEADER(recv_buf))) if((recv_len == OML_HEADER_LEN) && (CHECK_OML_HEADER(param->recv_buf)))
{ {
lw_notice("This is Oml package!!!\n"); lw_notice("This is Oml package!!!\n");
} }
} }
lw_notice("Receive from : %s\n", inet_ntoa(sock_addr.sin_addr)); lw_notice("Receive from : %s\n", inet_ntoa(sock_addr.sin_addr));
lw_notice("Receive data : %d -", recv_len); plc_print_array("Receive data", recv_len, param->recv_buf);
for(int i = 0; i < recv_len; i++)
{
lw_notice(" %#x", recv_buf[i]);
}
lw_notice("\n");
break; break;
} }
} }
step ++;
} }
closesocket(fd); closesocket(fd);
free(recv_buf); free(param->recv_buf);
return NULL; return NULL;
} }
@ -221,29 +191,46 @@ void PlcShowUsage(void)
plc_notice("tcp=[] 0: udp 1:tcp\n"); plc_notice("tcp=[] 0: udp 1:tcp\n");
plc_notice("ip=[ip.ip.ip.ip]\n"); plc_notice("ip=[ip.ip.ip.ip]\n");
plc_notice("port=port\n"); plc_notice("port=port\n");
plc_notice("file: use %s\n", PLC_SOCK_FILE_NAME);
plc_notice("------------------------------------\n"); plc_notice("------------------------------------\n");
} }
void PlcGetParamFromFile(void) #if defined(MOUNT_SDCARD) && defined(LIB_USING_CJSON)
void PlcGetParamFromFile(char *file_name)
{ {
PlcSocketParamType *param = &plc_socket_demo_data; PlcSocketParamType *param = &plc_socket_demo_data;
//for PLC socket parameter file char *file_buf = malloc(CTL_FILE_LEN);
char file_buf[CTL_FILE_SIZE] = {0}; if(file_buf == NULL)
FILE *fd = CtlFileInit(PLC_SOCK_FILE_NAME); {
plc_error("No enough buffer %d\n", CTL_FILE_LEN);
if(fd == NULL)
return; return;
}
memset(file_buf, 0, CTL_FILE_LEN);
memset(file_buf, 0, CTL_FILE_SIZE); if(CtlFileReadWithFilename(file_name, CTL_FILE_LEN, file_buf) != EOK)
{
CtlFileRead(fd, CTL_FILE_SIZE, file_buf); plc_error("Can't open file %s\n", file_name);
CtlFileClose(fd); //try again default file
if(strcmp(file_name, PLC_SOCK_FILE_NAME) != 0)
{
if(CtlFileReadWithFilename(PLC_SOCK_FILE_NAME, CTL_FILE_LEN, file_buf) != EOK)
{
plc_error("Can't open file %s\n", file_name);
return;
}
}
else
{
return;
}
}
CtlParseJsonData(file_buf); CtlParseJsonData(file_buf);
memcpy(param->ip, ctl_file_param.ip, 4); memcpy(param->ip, ctl_file_param.ip, 4);
param->port = ctl_file_param.port; param->port = ctl_file_param.port;
param->cmd_num = ctl_file_param.cmd_num; param->cmd_num = ctl_file_param.cmd_num;
param->socket_type = ctl_file_param.tcp ? SOCK_STREAM : SOCK_DGRAM;
for(int i = 0; i < param->cmd_num; i++) for(int i = 0; i < param->cmd_num; i++)
{ {
@ -253,17 +240,18 @@ void PlcGetParamFromFile(void)
plc_print("ip: %d.%d.%d.%d\n", param->ip[0], param->ip[1], param->ip[2], param->ip[3]); plc_print("ip: %d.%d.%d.%d\n", param->ip[0], param->ip[1], param->ip[2], param->ip[3]);
plc_print("port: %d", param->port); plc_print("port: %d", param->port);
plc_print("tcp: %d", param->socket_type);
plc_print("cmd number: %d\n", param->cmd_num); plc_print("cmd number: %d\n", param->cmd_num);
for(int i = 0; i < param->cmd_num; i++) for(int i = 0; i < param->cmd_num; i++)
{ {
plc_print("cmd %d len %d: ", i, TestPlcCmd[i].cmd_len); plc_print_array("cmd", TestPlcCmd[i].cmd_len, TestPlcCmd[i].cmd);
for(int j = 0; j < TestPlcCmd[i].cmd_len; j++)
plc_print("%x ", TestPlcCmd[i].cmd[j]);
plc_print("\n");
} }
free(file_buf);
} }
#endif
void PlcCheckParam(int argc, char *argv[]) void PlcCheckParam(int argc, char *argv[])
{ {
int i; int i;
@ -278,13 +266,19 @@ void PlcCheckParam(int argc, char *argv[])
plc_print("check %d %s\n", i, str); plc_print("check %d %s\n", i, str);
if(strcmp(str, "file") == 0) #if defined(MOUNT_SDCARD) && defined(LIB_USING_CJSON)
if(strncmp(str, "file", 4) == 0)
{ {
plc_notice("get parameter file %s\n", PLC_SOCK_FILE_NAME); char file_name[CTL_FILE_NAME_LEN] = {0};
PlcGetParamFromFile(); if(sscanf(str, "file=%s", file_name) == EOF)
{
strcpy(file_name, PLC_SOCK_FILE_NAME);
}
plc_notice("get %s parameter file %s\n", str, file_name);
PlcGetParamFromFile(file_name);
return; return;
} }
#endif
if(sscanf(str, "ip=%d.%d.%d.%d", if(sscanf(str, "ip=%d.%d.%d.%d",
&param->ip[0], &param->ip[0],
&param->ip[1], &param->ip[1],

View File

@ -23,9 +23,9 @@
#define PLC_BIN_CMD_LEN 512 #define PLC_BIN_CMD_LEN 512
// for plc socket test bin commands
typedef struct typedef struct
{ {
uint8_t step;
uint16_t delay_ms; uint16_t delay_ms;
uint8_t cmd_len; uint8_t cmd_len;
uint8_t cmd[PLC_BIN_CMD_LEN]; uint8_t cmd[PLC_BIN_CMD_LEN];
@ -43,28 +43,23 @@ enum PlcDeviceType {
PLC_DEV_TYPE_END, PLC_DEV_TYPE_END,
}; };
#define PLC_IP_SIZE 16 #define PLC_IP_LEN 16
#define PLC_DEV_SIZE 32 #define PLC_DEV_NAME_LEN 32
#define PLC_TEST_SIZE 65536 #define PLC_RECV_BUF_LEN CTL_FILE_LEN
typedef struct PlcSocketParamStruct{ typedef struct PlcSocketParamStruct{
char ip[PLC_IP_SIZE]; char ip[PLC_IP_LEN];
uint32_t port; uint32_t port;
uint32_t device_type; //PlcDeviceType uint32_t device_type; //PlcDeviceType
uint32_t socket_type; //UDP or TCP uint32_t socket_type; //UDP or TCP
char device[PLC_DEV_SIZE]; char device[PLC_DEV_NAME_LEN];
uint32_t step; // communication step
uint32_t cmd_num; // command number uint32_t cmd_num; // command number
uint32_t buf_size; uint32_t recv_len; // receive length
uint8_t *buf; uint8_t *recv_buf; // receive buffer
}PlcSocketParamType; }PlcSocketParamType;
//debug command //debug command
<<<<<<< HEAD
#define plc_print KPrintf
=======
#define plc_print //KPrintf #define plc_print //KPrintf
>>>>>>> e5d124231c72798f7f77b842cc8c631b79043914
#define plc_error KPrintf #define plc_error KPrintf
#define plc_notice KPrintf #define plc_notice KPrintf

View File

@ -36,6 +36,7 @@
"{ \r\n"\ "{ \r\n"\
" \"ip\": \"192.168.250.6\", \r\n"\ " \"ip\": \"192.168.250.6\", \r\n"\
" \"port\": 102, \r\n"\ " \"port\": 102, \r\n"\
" \"tcp\": 1, \r\n"\
" \"cmd\": [3, 0, 0, 22, 17, 224, 0, 0, 2, 200, 0, 193, 2, 2, 1, 194, 2, 2, 1, 192, 1, 10], \r\n"\ " \"cmd\": [3, 0, 0, 22, 17, 224, 0, 0, 2, 200, 0, 193, 2, 2, 1, 194, 2, 2, 1, 192, 1, 10], \r\n"\
" \"cmd1\": [3, 0, 0, 25, 2, 240, 128, 50, 1, 0, 0, 0, 13, 0, 8, 0, 0, 240, 0, 0, 1, 0, 1, 0, 240], \r\n" \ " \"cmd1\": [3, 0, 0, 25, 2, 240, 128, 50, 1, 0, 0, 0, 13, 0, 8, 0, 0, 240, 0, 0, 1, 0, 1, 0, 240], \r\n" \
" \"cmd2\": [3, 0, 0, 31, 2, 240, 128, 50, 1, 0, 0, 51, 1, 0, 14, 0, 0, 4, 1, 18, 10, 16, 2, 0, 210, 0, 52, 132, 0, 0, 0]\r\n" \ " \"cmd2\": [3, 0, 0, 31, 2, 240, 128, 50, 1, 0, 0, 51, 1, 0, 14, 0, 0, 4, 1, 18, 10, 16, 2, 0, 210, 0, 52, 132, 0, 0, 0]\r\n" \
@ -48,12 +49,21 @@ FILE *CtlFileInit(char *file)
{ {
FILE *fd = NULL; FILE *fd = NULL;
#ifdef MOUNT_SDCARD
// SD card mount flag 1: OK
if(sd_mount_flag == 0)
{
ctl_error("SD card mount failed\n");
return NULL;
}
fd = fopen(file, "a+"); fd = fopen(file, "a+");
if(fd == NULL) if(fd == NULL)
{ {
ctl_error("open file %s failed\n", file); ctl_error("open file %s failed\n", file);
} }
#endif
return fd; return fd;
} }
@ -76,6 +86,22 @@ void CtlFileWrite(FILE *fd, int size, char *buf)
ctl_print("write size %d: %s\n", size, buf); ctl_print("write size %d: %s\n", size, buf);
} }
int CtlFileReadWithFilename(char *file, int size, char *buf)
{
FILE *fd;
fd = fopen(file, "r");
if(fd == NULL)
{
ctl_error("open file %s failed\n", file);
return EEMPTY;
}
fseek(fd, 0, SEEK_SET);
fread(buf, size, 1, fd);
ctl_print("read file %d: %.100s\n", size, buf);
return EOK;
}
void CtlCreateFileTest(void) void CtlCreateFileTest(void)
{ {
FILE *fd = CtlFileInit(PLC_SOCK_FILE_NAME); FILE *fd = CtlFileInit(PLC_SOCK_FILE_NAME);
@ -117,10 +143,9 @@ void CtlParseJsonData(char *buf)
cJSON *file_dat = NULL; cJSON *file_dat = NULL;
cJSON *ip_dat = NULL; cJSON *ip_dat = NULL;
cJSON *port_dat = NULL; cJSON *port_dat = NULL;
cJSON *tcp_dat = NULL;
cJSON *cmd_dat = NULL; cJSON *cmd_dat = NULL;
int cmd_num = 0; char cmd_title[10] = {"cmd"};
int cmd_index = 1;
char cmd_str[10] = {0};
CtlPlcSockParamType *file_param = &ctl_file_param; CtlPlcSockParamType *file_param = &ctl_file_param;
file_dat = cJSON_Parse(buf); file_dat = cJSON_Parse(buf);
@ -132,6 +157,7 @@ void CtlParseJsonData(char *buf)
ip_dat = cJSON_GetObjectItem(file_dat, "ip"); ip_dat = cJSON_GetObjectItem(file_dat, "ip");
port_dat = cJSON_GetObjectItem(file_dat, "port"); port_dat = cJSON_GetObjectItem(file_dat, "port");
tcp_dat = cJSON_GetObjectItem(file_dat, "tcp");
ctl_print(" ip : %s\n", ip_dat->valuestring); ctl_print(" ip : %s\n", ip_dat->valuestring);
sscanf(ip_dat->valuestring, "%d.%d.%d.%d", &file_param->ip[0], sscanf(ip_dat->valuestring, "%d.%d.%d.%d", &file_param->ip[0],
@ -141,14 +167,17 @@ void CtlParseJsonData(char *buf)
ctl_print(" port: %s %d\n", ip_dat->string, port_dat->valueint); ctl_print(" port: %s %d\n", ip_dat->string, port_dat->valueint);
file_param->port = port_dat->valueint; file_param->port = port_dat->valueint;
file_param->tcp = tcp_dat->valueint;
file_param->cmd_num = 0;
strcpy(cmd_str, "cmd"); for(int i = 0; i < CTL_CMD_NUM; i++)
while(cmd_dat = cJSON_GetObjectItem(file_dat, cmd_str))
{ {
CtlParseJsonArray(cmd_dat, &file_param->cmd_len[cmd_index - 1], file_param->cmd[cmd_index - 1]); cmd_dat = cJSON_GetObjectItem(file_dat, cmd_title);
snprintf(cmd_str, sizeof(cmd_str), "cmd%d", cmd_index++); if(!cmd_dat)
break;
CtlParseJsonArray(cmd_dat, &file_param->cmd_len[i], file_param->cmd[i]);
snprintf(cmd_title, sizeof(cmd_title), "cmd%d", ++file_param->cmd_num);
} }
file_param->cmd_num = cmd_index - 1;
cJSON_Delete(file_dat); cJSON_Delete(file_dat);
} }
@ -156,14 +185,25 @@ void CtlParseJsonData(char *buf)
void CtlParseFileTest(void) void CtlParseFileTest(void)
{ {
//for PLC socket parameter file //for PLC socket parameter file
char file_buf[CTL_FILE_SIZE] = {0};
FILE *fd = CtlFileInit(PLC_SOCK_FILE_NAME); FILE *fd = CtlFileInit(PLC_SOCK_FILE_NAME);
if(fd == NULL) if(fd == NULL)
{
ctl_error("ctl get file %s failed\n", PLC_SOCK_FILE_NAME);
return; return;
memset(file_buf, 0, CTL_FILE_SIZE); }
CtlFileRead(fd, CTL_FILE_SIZE, file_buf);
char *file_buf = malloc(CTL_FILE_LEN);
if(file_buf == NULL)
{
ctl_error("ctl malloc failed\n");
return;
}
memset(file_buf, 0, CTL_FILE_LEN);
CtlFileRead(fd, CTL_FILE_LEN, file_buf);
CtlFileClose(fd); CtlFileClose(fd);
CtlParseJsonData(file_buf); CtlParseJsonData(file_buf);
free(file_buf);
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0),

View File

@ -21,31 +21,36 @@
#ifndef __CONTROL_FILE_H_ #ifndef __CONTROL_FILE_H_
#define __CONTROL_FILE_H_ #define __CONTROL_FILE_H_
#define CTL_FILE_SIZE 1000 #define CTL_FILE_LEN 1000 // control file size
#define CTL_CMD_NUM 10 // max command number #define CTL_CMD_NUM 10 // support command number
#define CTL_CMD_LEN 100 #define CTL_CMD_LEN 100 // control command length
#define CTL_IP_LEN 32 #define CTL_IP_LEN 32 // IP address length
#define CTL_FILE_NAME_LEN 100 // file name length
#define PLC_SOCK_FILE_NAME "/plc/socket_param.json" #define PLC_SOCK_FILE_NAME "/plc/socket_param.json"
#define ctl_print KPrintf #define ctl_print //KPrintf
#define ctl_error KPrintf #define ctl_error KPrintf
// for running plc socket
typedef struct CtlPlcSockParamStruct typedef struct CtlPlcSockParamStruct
{ {
char ip[CTL_IP_LEN]; char ip[CTL_IP_LEN];
int port; int port;
int tcp; // 1: TCP 0: UDP
int cmd_num; //command number int cmd_num; //command number
int cmd_len[CTL_CMD_NUM]; // command length int cmd_len[CTL_CMD_NUM]; // command length
char cmd[CTL_CMD_NUM][CTL_CMD_LEN]; char cmd[CTL_CMD_NUM][CTL_CMD_LEN];
}CtlPlcSockParamType; }CtlPlcSockParamType;
extern CtlPlcSockParamType ctl_file_param; extern CtlPlcSockParamType ctl_file_param;
extern int sd_mount_flag;
FILE *CtlFileInit(char *file); FILE *CtlFileInit(char *file);
void CtlFileClose(FILE *fd); void CtlFileClose(FILE *fd);
void CtlFileRead(FILE *fd, int size, char *buf); void CtlFileRead(FILE *fd, int size, char *buf);
void CtlFileWrite(FILE *fd, int size, char *buf); void CtlFileWrite(FILE *fd, int size, char *buf);
int CtlFileReadWithFilename(char *file_name, int size, char *buf);
#ifdef LIB_USING_CJSON #ifdef LIB_USING_CJSON
void CtlParseJsonData(char *buf); void CtlParseJsonData(char *buf);

View File

@ -84,6 +84,10 @@ int MountSDCard(void)
#include <connect_adc.h> #include <connect_adc.h>
#endif #endif
#ifdef BSP_USING_I2C
#include <connect_i2c.h>
#endif
#ifdef BSP_USING_SPI #ifdef BSP_USING_SPI
#include <connect_spi.h> #include <connect_spi.h>
#endif #endif
@ -688,6 +692,10 @@ void InitBoardHardware()
Imrt1052HwAdcInit(); Imrt1052HwAdcInit();
#endif #endif
#ifdef BSP_USING_I2C
Imrt1052HwI2cInit();
#endif
#ifdef BSP_USING_SPI #ifdef BSP_USING_SPI
Imrt1052HwSpiInit(); Imrt1052HwSpiInit();
#endif #endif

View File

@ -143,7 +143,7 @@ static int BoardI2cDevBend(void)
} }
/*BOARD I2C INIT*/ /*BOARD I2C INIT*/
int Stm32HwI2cInit(void) int Imrt1052HwI2cInit(void)
{ {
static int init_flag = 0; static int init_flag = 0;
x_err_t ret = EOK; x_err_t ret = EOK;

View File

@ -65,7 +65,6 @@ void I2cEEpromTestWrite(void)
int I2cEEpromTest(void) int I2cEEpromTest(void)
{ {
Stm32HwI2cInit();
BOARD_InitI2C1Pins(); BOARD_InitI2C1Pins();
I2cHardwareInit(); I2cHardwareInit();
I2cEEpromTestWrite(); I2cEEpromTestWrite();

View File

@ -37,7 +37,7 @@ typedef struct Stm32I2c
#define i2c_print KPrintf #define i2c_print KPrintf
int Stm32HwI2cInit(void); int Imrt1052HwI2cInit(void);
#ifdef __cplusplus #ifdef __cplusplus
} }

View File

@ -245,7 +245,6 @@ netconn_delete(struct netconn *conn)
err = ERR_OK; err = ERR_OK;
} else } else
#endif /* LWIP_NETCONN_FULLDUPLEX */ #endif /* LWIP_NETCONN_FULLDUPLEX */
//tst by wly
{ {
err = netconn_prepare_delete(conn); err = netconn_prepare_delete(conn);
} }

View File

@ -497,18 +497,6 @@ get_socket(int fd)
return sock; return sock;
} }
void pr_socket_buf(void)
{
int i;
lw_debug("socket:\n");
for (i = 0; i < NUM_SOCKETS; ++i) {
// if (!sockets[i].conn)
lw_debug("%d: conn %p rcv %d send %d wait %d\n", i, sockets[i].conn, sockets[i].rcvevent, sockets[i].sendevent,
sockets[i].select_waiting);
}
}
/** /**
* Allocate a new socket for a given netconn. * Allocate a new socket for a given netconn.
* *
@ -600,7 +588,6 @@ free_socket_free_elements(int is_tcp, struct netconn *conn, union lwip_sock_last
} }
if (conn != NULL) { if (conn != NULL) {
/* netconn_prepare_delete() has already been called, here we only free the conn */ /* netconn_prepare_delete() has already been called, here we only free the conn */
lw_debug("lw: [%s] tcp %d socket %d accept %d recv %d\n", __func__, is_tcp, conn->socket, conn->acceptmbox, conn->recvmbox);
netconn_delete(conn); netconn_delete(conn);
} }
} }
@ -673,8 +660,6 @@ lwip_accept(int s, struct sockaddr *addr, socklen_t *addrlen)
newsock = alloc_socket(newconn, 1); newsock = alloc_socket(newconn, 1);
if (newsock == -1) { if (newsock == -1) {
lw_debug("lw: [%s] recv %d\n", __func__, newconn->recvmbox);
pr_socket_buf();
netconn_delete(newconn); netconn_delete(newconn);
sock_set_errno(sock, ENFILE); sock_set_errno(sock, ENFILE);
done_socket(sock); done_socket(sock);
@ -711,8 +696,6 @@ lwip_accept(int s, struct sockaddr *addr, socklen_t *addrlen)
err = netconn_peer(newconn, &naddr, &port); err = netconn_peer(newconn, &naddr, &port);
if (err != ERR_OK) { if (err != ERR_OK) {
LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d): netconn_peer failed, err=%d\n", s, err)); LWIP_DEBUGF(SOCKETS_DEBUG, ("lwip_accept(%d): netconn_peer failed, err=%d\n", s, err));
lw_debug("lw: [%s] recv %x\n", __func__, newconn->recvmbox);
netconn_delete(newconn); netconn_delete(newconn);
free_socket(nsock, 1); free_socket(nsock, 1);
sock_set_errno(sock, err_to_errno(err)); sock_set_errno(sock, err_to_errno(err));
@ -1756,8 +1739,6 @@ lwip_socket(int domain, int type, int protocol)
i = alloc_socket(conn, 0); i = alloc_socket(conn, 0);
if (i == -1) { if (i == -1) {
lw_debug("lw: [%s] recv %d delete no socket\n", __func__, conn->recvmbox);
pr_socket_buf();
netconn_delete(conn); netconn_delete(conn);
set_errno(ENFILE); set_errno(ENFILE);
return -1; return -1;
@ -1766,7 +1747,6 @@ lwip_socket(int domain, int type, int protocol)
done_socket(&sockets[i - LWIP_SOCKET_OFFSET]); done_socket(&sockets[i - LWIP_SOCKET_OFFSET]);
LWIP_DEBUGF(SOCKETS_DEBUG, ("%d\n", i)); LWIP_DEBUGF(SOCKETS_DEBUG, ("%d\n", i));
set_errno(0); set_errno(0);
lw_debug("lw: [%s] new socket %d %p\n", __func__, i, conn);
return i; return i;
} }

View File

@ -250,10 +250,9 @@ typedef unsigned int nfds_t;
#define MEMP_MEM_MALLOC 1 #define MEMP_MEM_MALLOC 1
#define lw_print //KPrintf #define lw_print //KPrintf
#define lw_trace() //KPrintf("lw: [%s][%d] passed!\n", __func__, __LINE__) #define lw_error KPrintf
#define lw_error() //KPrintf("lw: [%s][%d] failed!\n", __func__, __LINE__)
#define lw_debug KPrintf
#define lw_notice KPrintf #define lw_notice KPrintf
#endif /* __LWIPOPTS_H__ */ #endif /* __LWIPOPTS_H__ */
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/

View File

@ -1386,17 +1386,13 @@ tcp_output(struct tcp_pcb *pcb)
/* In the case of fast retransmit, the packet should not go to the tail /* In the case of fast retransmit, the packet should not go to the tail
* of the unacked queue, but rather somewhere before it. We need to check for * of the unacked queue, but rather somewhere before it. We need to check for
* this case. -STJ Jul 27, 2004 */ * this case. -STJ Jul 27, 2004 */
lw_debug("check %s seg %p useg %p\n", __func__, seg, useg);
if (TCP_SEQ_LT(lwip_ntohl(seg->tcphdr->seqno), lwip_ntohl(useg->tcphdr->seqno))) { if (TCP_SEQ_LT(lwip_ntohl(seg->tcphdr->seqno), lwip_ntohl(useg->tcphdr->seqno))) {
/* add segment to before tail of unacked list, keeping the list sorted */ /* add segment to before tail of unacked list, keeping the list sorted */
struct tcp_seg **cur_seg = &(pcb->unacked); struct tcp_seg **cur_seg = &(pcb->unacked);
lw_debug("check %s ", __func__);
while (*cur_seg && while (*cur_seg &&
TCP_SEQ_LT(lwip_ntohl((*cur_seg)->tcphdr->seqno), lwip_ntohl(seg->tcphdr->seqno))) { TCP_SEQ_LT(lwip_ntohl((*cur_seg)->tcphdr->seqno), lwip_ntohl(seg->tcphdr->seqno))) {
lw_debug("%p -> ", *cur_seg);
cur_seg = &((*cur_seg)->next ); cur_seg = &((*cur_seg)->next );
} }
lw_debug("\n");
seg->next = (*cur_seg); seg->next = (*cur_seg);
(*cur_seg) = seg; (*cur_seg) = seg;
} else { } else {

View File

@ -18,40 +18,18 @@
* @date 2021.12.15 * @date 2021.12.15
*/ */
#include "lwip/opt.h"
#if LWIP_IPV4 && LWIP_RAW
#include "ping.h"
#include "lwip/timeouts.h"
#include "lwip/init.h"
#include "netif/ethernet.h"
#include "board.h" #include "board.h"
#include "pin_mux.h" #include "sys_arch.h"
#include "clock_config.h"
#include <transform.h>
#include <sys_arch.h>
#include "connect_ethernet.h"
/******************************************************************************/ /******************************************************************************/
static void *LwipSetIPTask(void *param) static void LwipSetIPTask(void *param)
{ {
lwip_config_net(lwip_ipaddr, lwip_netmask, lwip_gwaddr); lwip_config_net(lwip_ipaddr, lwip_netmask, lwip_gwaddr);
} }
void LwipSetIPTest(int argc, char *argv[]) void LwipSetIPTest(int argc, char *argv[])
{ {
int result = 0;
pthread_t th_id;
pthread_attr_t attr;
attr.schedparam.sched_priority = LWIP_DEMO_TASK_PRIO;
attr.stacksize = LWIP_TASK_STACK_SIZE;
if(argc >= 4) if(argc >= 4)
{ {
lw_print("lw: [%s] ip %s mask %s gw %s\n", __func__, argv[1], argv[2], argv[3]); lw_print("lw: [%s] ip %s mask %s gw %s\n", __func__, argv[1], argv[2], argv[3]);
@ -65,12 +43,7 @@ void LwipSetIPTest(int argc, char *argv[])
sscanf(argv[1], "%d.%d.%d.%d", &lwip_ipaddr[0], &lwip_ipaddr[1], &lwip_ipaddr[2], &lwip_ipaddr[3]); sscanf(argv[1], "%d.%d.%d.%d", &lwip_ipaddr[0], &lwip_ipaddr[1], &lwip_ipaddr[2], &lwip_ipaddr[3]);
} }
result = pthread_create(&th_id, &attr, LwipSetIPTask, NULL); sys_thread_new("SET ip address", LwipSetIPTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
if (0 == result) {
lw_print("lw: [%s] thread %d successfully!\n", __func__, th_id);
} else {
lw_print("lw: [%s] failed! error code is %d\n", __func__, result);
}
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3),
@ -98,4 +71,3 @@ void LwipShowIPTask(int argc, char *argv[])
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0),
showip, LwipShowIPTask, GetIp [IP] [Netmask] [Gateway]); showip, LwipShowIPTask, GetIp [IP] [Netmask] [Gateway]);
#endif

View File

@ -1,7 +1,37 @@
/*
* Copyright (c) 2022 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
* http://license.coscl.org.cn/MulanPSL2
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
/**
* @file lwip_demo.h
* @brief lwip demo relative struct and definition
* @version 1.0
* @author AIIT XUOS Lab
* @date 2022-03-21
*/
#ifndef __LWIP_DEMO_H__ #ifndef __LWIP_DEMO_H__
#define __LWIP_DEMO_H__ #define __LWIP_DEMO_H__
typedef struct LwipTcpSocketStruct
{
char ip[6];
uint16_t port;
char *buf;
}LwipTcpSocketParamType;
#define LWIP_TEST_MSG_SIZE 128
#define LWIP_TEST_STACK_SIZE 4096 #define LWIP_TEST_STACK_SIZE 4096
#define LWIP_TEST_TASK_PRIO 20 #define LWIP_TEST_TASK_PRIO 20
#endif /* __LWIP_DEMO_H__ */ #endif /* __LWIP_DEMO_H__ */

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2020 AIIT XUOS Lab * Copyright (c) 2022 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2. * XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2. * You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at: * You may obtain a copy of Mulan PSL v2 at:
@ -11,45 +11,32 @@
*/ */
/** /**
* @file tcp_echo_socket_demo.c * @file lwip_tcp_demo.c
* @brief One UDP demo based on LwIP * @brief TCP demo based on LwIP
* @version 1.0 * @version 1.0
* @author AIIT XUOS Lab * @author AIIT XUOS Lab
* @date 2021-05-29 * @date 2022-03-21
*/ */
#include <transform.h>
#include <xizi.h>
#include "board.h" #include "board.h"
#include "lwip_demo.h"
#include "sys_arch.h" #include "sys_arch.h"
#include <lwip/sockets.h> #include "lwip/sockets.h"
#include "lwip/sys.h"
#include "tcpecho_raw.h" #include "tcpecho_raw.h"
#define MSG_SIZE 128 char tcp_demo_msg[LWIP_TEST_MSG_SIZE] = {0};
char tcp_demo_ip[] = {192, 168, 250, 252};
typedef struct LwipTcpSocketStruct u16_t tcp_demo_port = LWIP_TARGET_PORT;
{
char ip[6];
uint16_t port;
char *buf; // test buffer
}LwipTcpSocketParamType;
// this is for test in shell, in fact, shell restrict the length of input string, which is less then 128
char tcp_send_msg[MSG_SIZE] = {0};
char tcp_target[] = {192, 168, 250, 252};
uint16_t tcp_port = LWIP_TARGET_PORT;
/******************************************************************************/ /******************************************************************************/
static void LwipTcpSendTask(void *arg) static void LwipTcpSendTask(void *arg)
{ {
lw_notice("LwipTcpSendTask start.\n");
int fd = -1; int fd = -1;
fd = socket(AF_INET, SOCK_STREAM, 0); fd = socket(AF_INET, SOCK_STREAM, 0);
if (fd < 0) if (fd < 0)
{ {
lw_notice("Socket error\n"); lw_error("Socket error\n");
return; return;
} }
@ -63,7 +50,7 @@ static void LwipTcpSendTask(void *arg)
if (connect(fd, (struct sockaddr *)&tcp_sock, sizeof(struct sockaddr))) if (connect(fd, (struct sockaddr *)&tcp_sock, sizeof(struct sockaddr)))
{ {
lw_notice("Unable to connect\n"); lw_error("Unable to connect\n");
closesocket(fd); closesocket(fd);
return; return;
} }
@ -71,9 +58,9 @@ static void LwipTcpSendTask(void *arg)
lw_notice("tcp connect success, start to send.\n"); lw_notice("tcp connect success, start to send.\n");
lw_notice("\n\nTarget Port:%d\n\n", tcp_sock.sin_port); lw_notice("\n\nTarget Port:%d\n\n", tcp_sock.sin_port);
sendto(fd, tcp_send_msg, strlen(tcp_send_msg), 0, (struct sockaddr*)&tcp_sock, sizeof(struct sockaddr)); sendto(fd, tcp_demo_msg, strlen(tcp_demo_msg), 0, (struct sockaddr*)&tcp_sock, sizeof(struct sockaddr));
lw_notice("Send tcp msg: %s ", tcp_send_msg); lw_notice("Send tcp msg: %s ", tcp_demo_msg);
closesocket(fd); closesocket(fd);
return; return;
@ -82,31 +69,31 @@ static void LwipTcpSendTask(void *arg)
void LwipTcpSendTest(int argc, char *argv[]) void LwipTcpSendTest(int argc, char *argv[])
{ {
LwipTcpSocketParamType param; LwipTcpSocketParamType param;
memset(tcp_send_msg, 0, MSG_SIZE); memset(tcp_demo_msg, 0, LWIP_TEST_MSG_SIZE);
if(argc >= 2) if(argc >= 2)
{ {
strncpy(tcp_send_msg, argv[1], strlen(argv[1])); strncpy(tcp_demo_msg, argv[1], strlen(argv[1]));
} }
else else
{ {
strncpy(tcp_send_msg, "hello world", strlen("hello world")); strncpy(tcp_demo_msg, "hello world", strlen("hello world"));
} }
strcat(tcp_send_msg, "\r\n"); strcat(tcp_demo_msg, "\r\n");
if(argc >= 3) if(argc >= 3)
{ {
if(sscanf(argv[2], "%d.%d.%d.%d:%d", &tcp_target[0], &tcp_target[1], &tcp_target[2], &tcp_target[3], &tcp_port) == EOK) if(sscanf(argv[2], "%d.%d.%d.%d:%d", &tcp_demo_ip[0], &tcp_demo_ip[1], &tcp_demo_ip[2], &tcp_demo_ip[3], &tcp_demo_port) == EOK)
{ {
sscanf(argv[2], "%d.%d.%d.%d", &tcp_target[0], &tcp_target[1], &tcp_target[2], &tcp_target[3]); sscanf(argv[2], "%d.%d.%d.%d", &tcp_demo_ip[0], &tcp_demo_ip[1], &tcp_demo_ip[2], &tcp_demo_ip[3]);
} }
} }
lw_notice("get ipaddr %d.%d.%d.%d:%d\n", tcp_target[0], tcp_target[1], tcp_target[2], tcp_target[3], tcp_port); lw_notice("get ipaddr %d.%d.%d.%d:%d\n", tcp_demo_ip[0], tcp_demo_ip[1], tcp_demo_ip[2], tcp_demo_ip[3], tcp_demo_port);
lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_target); lwip_config_tcp(lwip_ipaddr, lwip_netmask, tcp_demo_ip);
memcpy(param.ip, tcp_target, 4); memcpy(param.ip, tcp_demo_ip, 4);
param.port = tcp_port; param.port = tcp_demo_port;
param.buf = malloc(MSG_SIZE); param.buf = malloc(LWIP_TEST_MSG_SIZE);
memcpy(param.buf, tcp_send_msg, MSG_SIZE); memcpy(param.buf, tcp_demo_msg, LWIP_TEST_MSG_SIZE);
sys_thread_new("tcp send", LwipTcpSendTask, &param, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("tcp send", LwipTcpSendTask, &param, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2021 AIIT XUOS Lab * Copyright (c) 2022 AIIT XUOS Lab
* XiUOS is licensed under Mulan PSL v2. * XiUOS is licensed under Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2. * You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at: * You may obtain a copy of Mulan PSL v2 at:
@ -15,25 +15,23 @@
* @brief One UDP demo based on LwIP * @brief One UDP demo based on LwIP
* @version 1.0 * @version 1.0
* @author AIIT XUOS Lab * @author AIIT XUOS Lab
* @date 2021-05-29 * @date 2022-03-21
*/ */
#include <transform.h>
#include <xizi.h>
#include "board.h" #include "board.h"
#include "sys_arch.h" #include "sys_arch.h"
#include "lwip/udp.h" #include "lwip/udp.h"
#include <lwip/sockets.h> #include "lwip/sockets.h"
#include "lwip/sys.h"
#define UDP_TASK_STACK_SIZE 4096
#define UDP_TASK_PRIO 15
#define PBUF_SIZE 27 #define PBUF_SIZE 27
static struct udp_pcb *udpecho_raw_pcb; static struct udp_pcb *udpecho_raw_pcb;
char udp_demo_ip[] = {192, 168, 250, 252}; char udp_demo_ip[] = {192, 168, 250, 252};
uint16_t udp_demo_port = LWIP_TARGET_PORT; u16_t udp_demo_port = LWIP_TARGET_PORT;
char hello_str[] = {"hello world\r\n"}; char hello_str[] = {"hello world\r\n"};
char udp_send_msg[] = "\n\nThis one is UDP pkg. Congratulations on you.\n\n"; char udp_demo_msg[] = "\nThis one is UDP package!!!\n";
/******************************************************************************/ /******************************************************************************/
@ -47,7 +45,7 @@ static void LwipUDPSendTask(void *arg)
socket_fd = socket(AF_INET, SOCK_DGRAM, 0); socket_fd = socket(AF_INET, SOCK_DGRAM, 0);
if (socket_fd < 0) if (socket_fd < 0)
{ {
lw_print("Socket error\n"); lw_error("Socket error\n");
return; return;
} }
@ -59,45 +57,43 @@ static void LwipUDPSendTask(void *arg)
if (connect(socket_fd, (struct sockaddr *)&udp_sock, sizeof(struct sockaddr))) if (connect(socket_fd, (struct sockaddr *)&udp_sock, sizeof(struct sockaddr)))
{ {
lw_print("Unable to connect\n"); lw_error("Unable to connect\n");
closesocket(socket_fd); closesocket(socket_fd);
return; return;
} }
lw_print("UDP connect success, start to send.\n"); lw_notice("UDP connect success, start to send.\n");
lw_print("\n\nTarget Port:%d\n\n", udp_sock.sin_port); lw_notice("\n\nTarget Port:%d\n\n", udp_sock.sin_port);
sendto(socket_fd, udp_send_msg, strlen(udp_send_msg), 0, (struct sockaddr*)&udp_sock, sizeof(struct sockaddr)); sendto(socket_fd, udp_demo_msg, strlen(udp_demo_msg), 0, (struct sockaddr*)&udp_sock, sizeof(struct sockaddr));
lw_notice("Send UDP msg: %s ", udp_send_msg); lw_notice("Send UDP msg: %s ", udp_demo_msg);
closesocket(socket_fd); closesocket(socket_fd);
return; return;
} }
void *LwipUdpSendTest(int argc, char *argv[]) void *LwipUdpSendTest(int argc, char *argv[])
{ {
int result = 0; memset(udp_demo_msg, 0, sizeof(udp_demo_msg));
sys_thread_t th_id;
memset(udp_send_msg, 0, sizeof(udp_send_msg));
if(argc == 1) if(argc == 1)
{ {
lw_print("lw: [%s] gw %d.%d.%d.%d\n", __func__, udp_demo_ip[0], udp_demo_ip[1], udp_demo_ip[2], udp_demo_ip[3]); lw_print("lw: [%s] gw %d.%d.%d.%d\n", __func__, udp_demo_ip[0], udp_demo_ip[1], udp_demo_ip[2], udp_demo_ip[3]);
strncpy(udp_send_msg, hello_str, strlen(hello_str)); strncpy(udp_demo_msg, hello_str, strlen(hello_str));
} }
else else
{ {
strncpy(udp_send_msg, argv[1], strlen(argv[1])); strncpy(udp_demo_msg, argv[1], strlen(argv[1]));
strncat(udp_send_msg, "\r\n", 2); strncat(udp_demo_msg, "\r\n", 2);
if(argc == 3) if(argc == 3)
{ {
sscanf(argv[2], "%d.%d.%d.%d", &udp_demo_ip[0], &udp_demo_ip[1], &udp_demo_ip[2], &udp_demo_ip[3]); sscanf(argv[2], "%d.%d.%d.%d", &udp_demo_ip[0], &udp_demo_ip[1], &udp_demo_ip[2], &udp_demo_ip[3]);
} }
} }
lw_print("lw: [%s] gw %d.%d.%d.%d\n", __func__, udp_demo_ip[0], udp_demo_ip[1], udp_demo_ip[2], udp_demo_ip[3]); lw_print("lw: [%s] gw %d.%d.%d.%d\n", __func__, udp_demo_ip[0], udp_demo_ip[1], udp_demo_ip[2], udp_demo_ip[3]);
lwip_config_net(lwip_ipaddr, lwip_netmask, lwip_gwaddr); lwip_config_net(lwip_ipaddr, lwip_netmask, udp_demo_ip);
sys_thread_new("udp socket send", LwipUDPSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO); sys_thread_new("udp send", LwipUDPSendTask, NULL, LWIP_TASK_STACK_SIZE, LWIP_DEMO_TASK_PRIO);
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(3),
@ -116,6 +112,7 @@ static void LwipUdpRecvTask(void *arg, struct udp_pcb *upcb, struct pbuf *p,
{ {
return; return;
} }
udp_len = p->tot_len; udp_len = p->tot_len;
lw_notice("Receive data :%dB\r\n", udp_len); lw_notice("Receive data :%dB\r\n", udp_len);
@ -158,5 +155,5 @@ void LwipUdpRecvTest(void)
} }
SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0), SHELL_EXPORT_CMD(SHELL_CMD_PERMISSION(0) | SHELL_CMD_TYPE(SHELL_TYPE_CMD_MAIN) | SHELL_CMD_PARAM_NUM(0),
UDPRecv, LwipUdpRecvTest, UDP server echo); UDPRecv, LwipUdpRecvTest, UDP Receive echo);

View File

@ -21,9 +21,7 @@
#ifndef FLASH_SPI_H #ifndef FLASH_SPI_H
#define FLASH_SPI_H #define FLASH_SPI_H
#ifdef RESOURCES_SPI_SFUD
#include <sfud_port.h> #include <sfud_port.h>
#endif
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {

View File

@ -115,7 +115,7 @@ int userShellInit(void)
serial_dev_param->serial_stream_mode = SIGN_OPER_STREAM; serial_dev_param->serial_stream_mode = SIGN_OPER_STREAM;
BusDevOpen(console); BusDevOpen(console);
shellInit(&shell, shellBuffer, 4096); shellInit(&shell, shellBuffer, 512);
int32 tid; int32 tid;
tid = KTaskCreate("letter-shell", tid = KTaskCreate("letter-shell",
shellTask, &shell, shellTask, &shell,