Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
rt-thread
提交
ea608778
R
rt-thread
项目概览
BaiXuePrincess
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
未验证
提交
ea608778
编写于
12月 27, 2017
作者:
B
Bernard Xiong
提交者:
GitHub
12月 27, 2017
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #1144 from aozima/lwip_dev
update dhcpd
上级
e3dd653e
b0081d35
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
113 addition
and
14 deletion
+113
-14
components/net/lwip_dhcpd/dhcp_server.c
components/net/lwip_dhcpd/dhcp_server.c
+111
-13
components/net/lwip_dhcpd/dhcp_server.h
components/net/lwip_dhcpd/dhcp_server.h
+2
-1
未找到文件。
components/net/lwip_dhcpd/dhcp_server.c
浏览文件 @
ea608778
...
...
@@ -25,6 +25,7 @@
* 2013-01-30 aozima the first version
* 2013-08-08 aozima support different network segments.
* 2015-01-30 bernard release to RT-Thread RTOS.
* 2017-12-27 aozima add [mac-ip] table support.
*/
#include <stdio.h>
...
...
@@ -77,7 +78,25 @@
/* buffer size for receive DHCP packet */
#define BUFSZ 1024
static
uint8_t
next_client_ip
=
DHCPD_CLIENT_IP_MIN
;
#ifndef MAC_ADDR_LEN
#define MAC_ADDR_LEN 6
#endif
#ifndef MAC_TABLE_LEN
#define MAC_TABLE_LEN 4
#endif
struct
mac_addr_t
{
uint8_t
add
[
MAC_ADDR_LEN
];
};
struct
mac_ip_item_t
{
struct
mac_addr_t
mac_addr
;
uint8_t
ip_addr_3
;
};
static
rt_err_t
_low_level_dhcp_send
(
struct
netif
*
netif
,
const
void
*
buffer
,
rt_size_t
size
)
...
...
@@ -124,10 +143,67 @@ static rt_err_t _low_level_dhcp_send(struct netif *netif,
netif
->
linkoutput
(
netif
,
p
);
pbuf_free
(
p
);
return
RT_EOK
;
}
static
uint8_t
get_ip
(
struct
mac_addr_t
*
p_mac_addr
)
{
static
uint8_t
next_client_ip
=
DHCPD_CLIENT_IP_MIN
;
static
struct
mac_ip_item_t
mac_table
[
MAC_TABLE_LEN
];
static
int
offset
=
0
;
struct
mac_addr_t
bad_mac
;
int
i
;
uint8_t
ip_addr_3
;
rt_memset
(
&
bad_mac
,
0
,
sizeof
(
bad_mac
));
if
(
!
rt_memcmp
(
&
bad_mac
,
p_mac_addr
,
sizeof
(
bad_mac
)))
{
DEBUG_PRINTF
(
"mac address all zero"
);
ip_addr_3
=
DHCPD_CLIENT_IP_MAX
;
goto
_return
;
}
rt_memset
(
&
bad_mac
,
0xFF
,
sizeof
(
bad_mac
));
if
(
!
rt_memcmp
(
&
bad_mac
,
p_mac_addr
,
sizeof
(
bad_mac
)))
{
DEBUG_PRINTF
(
"mac address all one"
);
ip_addr_3
=
DHCPD_CLIENT_IP_MAX
;
goto
_return
;
}
for
(
i
=
0
;
i
<
MAC_TABLE_LEN
;
i
++
)
{
if
(
!
rt_memcmp
(
&
mac_table
[
i
].
mac_addr
,
p_mac_addr
,
sizeof
(
bad_mac
)))
{
//use old ip
ip_addr_3
=
mac_table
[
i
].
ip_addr_3
;
DEBUG_PRINTF
(
"return old ip: %d
\n
"
,
(
int
)
ip_addr_3
);
goto
_return
;
}
}
/* add new ip */
mac_table
[
offset
].
mac_addr
=
*
p_mac_addr
;
mac_table
[
offset
].
ip_addr_3
=
next_client_ip
;
ip_addr_3
=
mac_table
[
offset
].
ip_addr_3
;
offset
++
;
if
(
offset
>=
MAC_TABLE_LEN
)
offset
=
0
;
next_client_ip
++
;
if
(
next_client_ip
>
DHCPD_CLIENT_IP_MAX
)
next_client_ip
=
DHCPD_CLIENT_IP_MIN
;
DEBUG_PRINTF
(
"create new ip: %d
\n
"
,
(
int
)
ip_addr_3
);
DEBUG_PRINTF
(
"next_client_ip %d
\n
"
,
next_client_ip
);
_return:
return
ip_addr_3
;
}
static
void
dhcpd_thread_entry
(
void
*
parameter
)
{
struct
netif
*
netif
=
RT_NULL
;
...
...
@@ -138,9 +214,10 @@ static void dhcpd_thread_entry(void *parameter)
struct
sockaddr_in
server_addr
,
client_addr
;
struct
dhcp_msg
*
msg
;
int
optval
=
1
;
struct
mac_addr_t
mac_addr
;
/* get ethernet interface. */
netif
=
(
struct
netif
*
)
parameter
;
netif
=
(
struct
netif
*
)
parameter
;
RT_ASSERT
(
netif
!=
RT_NULL
);
/* our DHCP server information */
...
...
@@ -206,6 +283,8 @@ static void dhcpd_thread_entry(void *parameter)
continue
;
}
memcpy
(
mac_addr
.
add
,
msg
->
chaddr
,
MAC_ADDR_LEN
);
/* handler. */
{
uint8_t
*
dhcp_opt
;
...
...
@@ -216,6 +295,10 @@ static void dhcpd_thread_entry(void *parameter)
uint8_t
finished
=
0
;
uint32_t
request_ip
=
0
;
uint8_t
client_ip_3
;
client_ip_3
=
get_ip
(
&
mac_addr
);
dhcp_opt
=
(
uint8_t
*
)
msg
+
DHCP_OPTIONS_OFS
;
while
(
finished
==
0
)
{
...
...
@@ -251,7 +334,9 @@ static void dhcpd_thread_entry(void *parameter)
if
(
request_ip
)
{
uint32_t
client_ip
=
DHCPD_SERVER_IPADDR0
<<
24
|
DHCPD_SERVER_IPADDR1
<<
16
|
DHCPD_SERVER_IPADDR2
<<
8
|
(
next_client_ip
);
|
DHCPD_SERVER_IPADDR2
<<
8
|
client_ip_3
;
DEBUG_PRINTF
(
"message_type: %d, request_ip: %08X, client_ip: %08X.
\n
"
,
message_type
,
request_ip
,
client_ip
);
if
(
request_ip
!=
client_ip
)
{
...
...
@@ -261,15 +346,14 @@ static void dhcpd_thread_entry(void *parameter)
*
dhcp_opt
++
=
DHCP_OPTION_END
;
DEBUG_PRINTF
(
"requested IP invalid, reply DHCP_NAK
\n
"
);
if
(
netif
!=
RT_NULL
)
{
int
send_byte
=
(
dhcp_opt
-
(
uint8_t
*
)
msg
);
_low_level_dhcp_send
(
netif
,
msg
,
send_byte
);
DEBUG_PRINTF
(
"DHCP server send %d byte
\n
"
,
send_byte
);
}
next_client_ip
++
;
if
(
next_client_ip
>
DHCPD_CLIENT_IP_MAX
)
next_client_ip
=
DHCPD_CLIENT_IP_MIN
;
continue
;
}
}
...
...
@@ -366,7 +450,7 @@ static void dhcpd_thread_entry(void *parameter)
msg
->
op
=
DHCP_BOOTREPLY
;
IP4_ADDR
(
&
msg
->
yiaddr
,
DHCPD_SERVER_IPADDR0
,
DHCPD_SERVER_IPADDR1
,
DHCPD_SERVER_IPADDR2
,
next_client_ip
);
DHCPD_SERVER_IPADDR2
,
client_ip_3
);
client_addr
.
sin_addr
.
s_addr
=
INADDR_BROADCAST
;
...
...
@@ -381,29 +465,43 @@ static void dhcpd_thread_entry(void *parameter)
}
}
void
dhcpd_start
(
c
har
*
netif_name
)
void
dhcpd_start
(
c
onst
char
*
netif_name
)
{
rt_thread_t
thread
;
struct
netif
*
netif
=
netif_list
;
if
(
strlen
(
netif_name
)
>
sizeof
(
netif
->
name
))
if
(
strlen
(
netif_name
)
>
sizeof
(
netif
->
name
))
{
rt_kprintf
(
"network interface name too long!
\r\n
"
);
return
;
}
while
(
netif
!=
RT_NULL
)
while
(
netif
!=
RT_NULL
)
{
if
(
strncmp
(
netif_name
,
netif
->
name
,
sizeof
(
netif
->
name
))
==
0
)
if
(
strncmp
(
netif_name
,
netif
->
name
,
sizeof
(
netif
->
name
))
==
0
)
break
;
netif
=
netif
->
next
;
if
(
netif
==
RT_NULL
)
if
(
netif
==
RT_NULL
)
{
rt_kprintf
(
"network interface: %s not found!
\r\n
"
,
netif_name
);
return
;
}
}
if
(
1
)
{
extern
void
set_if
(
const
char
*
netif_name
,
const
char
*
ip_addr
,
const
char
*
gw_addr
,
const
char
*
nm_addr
);
char
ip_str
[
4
*
4
+
1
];
dhcp_stop
(
netif
);
sprintf
(
ip_str
,
"%d.%d.%d.%d"
,
DHCPD_SERVER_IPADDR0
,
DHCPD_SERVER_IPADDR1
,
DHCPD_SERVER_IPADDR2
,
DHCPD_SERVER_IPADDR3
);
set_if
(
netif_name
,
ip_str
,
"0.0.0.0"
,
"255.255.255.0"
);
netif_set_up
(
netif
);
}
thread
=
rt_thread_create
(
"dhcpd"
,
dhcpd_thread_entry
,
netif
,
1024
,
...
...
components/net/lwip_dhcpd/dhcp_server.h
浏览文件 @
ea608778
...
...
@@ -25,12 +25,13 @@
* 2013-01-30 aozima the first version
* 2013-08-08 aozima support different network segments.
* 2015-01-30 bernard release to RT-Thread RTOS.
* 2017-12-27 aozima add [mac-ip] table support.
*/
#ifndef DHCPV4_SERVER_H__
#define DHCPV4_SERVER_H__
void
dhcpd_start
(
char
*
netif_name
);
void
dhcpd_start
(
c
onst
c
har
*
netif_name
);
#endif
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录