2018-05-15 15:49:10 +02:00
|
|
|
#include "no_warn_host.h"
|
2018-05-14 15:03:37 +02:00
|
|
|
#include "lwip/opt.h"
|
|
|
|
#include "lwip/def.h"
|
|
|
|
#include "lwip/pbuf.h"
|
|
|
|
#include "lwip/udp.h"
|
|
|
|
#include "tcpip_adapter.h"
|
|
|
|
#include <string.h>
|
2018-05-15 15:49:10 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
const ip_addr_t ip_addr_any;
|
|
|
|
const ip_addr_t ip_addr_broadcast;
|
2018-05-18 15:54:08 +02:00
|
|
|
const ip_addr_t ip_addr_any_type;
|
2018-05-15 15:49:10 +02:00
|
|
|
struct ip_globals ip_data;
|
|
|
|
struct netif *netif_list;
|
2018-05-18 15:54:08 +02:00
|
|
|
struct udp_pcb mock_pcb;
|
|
|
|
uint32_t g_random_numbers[8] = {0};
|
|
|
|
uint32_t g_random_numbers_cnt = 0;
|
2018-05-15 15:49:10 +02:00
|
|
|
|
2018-05-14 15:03:37 +02:00
|
|
|
|
2018-05-18 15:54:08 +02:00
|
|
|
struct pbuf* pbuf_skip(struct pbuf* in, u16_t in_offset, u16_t* out_offset)
|
|
|
|
{
|
|
|
|
u16_t offset_left = in_offset;
|
|
|
|
struct pbuf* q = in;
|
|
|
|
|
|
|
|
/* get the correct pbuf */
|
|
|
|
while ((q != NULL) && (q->len <= offset_left)) {
|
|
|
|
offset_left -= q->len;
|
|
|
|
q = q->next;
|
|
|
|
}
|
|
|
|
if (out_offset != NULL) {
|
|
|
|
*out_offset = offset_left;
|
|
|
|
}
|
|
|
|
return q;
|
|
|
|
}
|
|
|
|
|
|
|
|
void pbuf_put_at(struct pbuf* p, u16_t offset, u8_t data)
|
|
|
|
{
|
|
|
|
u16_t q_idx;
|
|
|
|
struct pbuf* q = pbuf_skip(p, offset, &q_idx);
|
|
|
|
|
|
|
|
/* write requested data if pbuf is OK */
|
|
|
|
if ((q != NULL) && (q->len > q_idx)) {
|
|
|
|
((u8_t*)q->payload)[q_idx] = data;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
u8_t pbuf_get_at(struct pbuf* p, u16_t offset)
|
|
|
|
{
|
|
|
|
u16_t q_idx;
|
|
|
|
struct pbuf* q = pbuf_skip(p, offset, &q_idx);
|
|
|
|
|
|
|
|
/* return requested data if pbuf is OK */
|
|
|
|
if ((q != NULL) && (q->len > q_idx)) {
|
|
|
|
return ((u8_t*)q->payload)[q_idx];
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t pbuf_take(struct pbuf *buf, const void *dataptr, u16_t len)
|
|
|
|
{
|
|
|
|
return ERR_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t pbuf_take_at(struct pbuf *buf, const void *dataptr, u16_t len, u16_t offset)
|
|
|
|
{
|
|
|
|
return ERR_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct udp_pcb * udp_new_ip_type(u8_t type)
|
|
|
|
{
|
|
|
|
return &mock_pcb;
|
|
|
|
}
|
|
|
|
|
2018-05-14 15:03:37 +02:00
|
|
|
u16_t lwip_htons(u16_t n)
|
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
return ((n & 0xff) << 8) | ((n & 0xff00) >> 8);
|
2018-05-14 15:03:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
u32_t lwip_htonl(u32_t n)
|
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
return ((n & 0xff) << 24) |
|
|
|
|
((n & 0xff00) << 8) |
|
|
|
|
((n & 0xff0000UL) >> 8) |
|
|
|
|
((n & 0xff000000UL) >> 24);
|
2018-05-14 15:03:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
esp_err_t tcpip_adapter_get_ip_info(tcpip_adapter_if_t tcpip_if, tcpip_adapter_ip_info_t *ip_info)
|
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
return ESP_OK;
|
2018-05-14 15:03:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
struct pbuf * pbuf_alloc(pbuf_layer layer, u16_t length, pbuf_type type)
|
|
|
|
{
|
|
|
|
struct pbuf * p;
|
|
|
|
p = (struct pbuf *)malloc(MEMP_PBUF_POOL);
|
|
|
|
p->tot_len = length;
|
|
|
|
p->next = NULL;
|
|
|
|
p->type = PBUF_POOL;
|
|
|
|
p->len = length;
|
|
|
|
p->payload = malloc(length);
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
u8_t pbuf_free(struct pbuf *p)
|
|
|
|
{
|
|
|
|
if (p) {
|
|
|
|
if (p->payload) {
|
|
|
|
free(p->payload);
|
|
|
|
p->payload = NULL;
|
|
|
|
}
|
|
|
|
free (p);
|
|
|
|
p = NULL;
|
|
|
|
}
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t udp_sendto(struct udp_pcb *pcb, struct pbuf *p, const ip_addr_t *dst_ip, u16_t dst_port)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
void udp_remove(struct udp_pcb *pcb)
|
|
|
|
{
|
2018-05-15 15:49:10 +02:00
|
|
|
if (pcb == NULL)
|
|
|
|
{
|
|
|
|
free(pcb);
|
|
|
|
}
|
2018-05-14 15:03:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
struct udp_pcb *udp_new(void)
|
|
|
|
{
|
2018-05-15 15:49:10 +02:00
|
|
|
return malloc(sizeof(struct udp_pcb));
|
2018-05-14 15:03:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
err_t udp_bind(struct udp_pcb *pcb, const ip_addr_t *ipaddr, u16_t port)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
void udp_recv(struct udp_pcb *pcb, udp_recv_fn recv, void *recv_arg)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void udp_disconnect(struct udp_pcb *pcb)
|
|
|
|
{
|
|
|
|
}
|
2018-05-15 15:49:10 +02:00
|
|
|
|
2018-05-18 15:54:08 +02:00
|
|
|
#ifndef NOT_MOCK_DNS
|
2018-05-15 15:49:10 +02:00
|
|
|
void dns_setserver(u8_t numdns, const ip_addr_t *dnsserver)
|
|
|
|
{
|
|
|
|
}
|
2018-05-18 15:54:08 +02:00
|
|
|
#endif
|
2018-05-15 15:49:10 +02:00
|
|
|
|
|
|
|
uint32_t esp_random(void)
|
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
// Preparation for injecting favorable random numbers
|
|
|
|
return g_random_numbers[g_random_numbers_cnt++ % 8];
|
2018-05-15 15:49:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
err_t etharp_query(struct netif *netif, const ip4_addr_t *ipaddr, struct pbuf *q)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
u32_t lwip_ntohl(u32_t x)
|
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
return lwip_htonl(x);
|
2018-05-15 15:49:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void netif_set_addr(struct netif *netif, const ip4_addr_t *ipaddr, const ip4_addr_t *netmask,
|
|
|
|
const ip4_addr_t *gw)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void pbuf_realloc(struct pbuf *p, u16_t size)
|
|
|
|
{
|
|
|
|
if (p != NULL)
|
|
|
|
{
|
|
|
|
uint8_t *buf = malloc(size);
|
|
|
|
free(p->payload);
|
|
|
|
p->payload = buf;
|
|
|
|
p->len = size;
|
|
|
|
p->tot_len = size;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-05-18 15:54:08 +02:00
|
|
|
u16_t pbuf_copy_partial(struct pbuf *buf, void *dataptr, u16_t len, u16_t offset)
|
2018-05-15 15:49:10 +02:00
|
|
|
{
|
2018-05-18 15:54:08 +02:00
|
|
|
struct pbuf *p;
|
|
|
|
u16_t left;
|
|
|
|
u16_t buf_copy_len;
|
|
|
|
u16_t copied_total = 0;
|
|
|
|
|
|
|
|
LWIP_ERROR("pbuf_copy_partial: invalid buf", (buf != NULL), return 0;);
|
|
|
|
LWIP_ERROR("pbuf_copy_partial: invalid dataptr", (dataptr != NULL), return 0;);
|
|
|
|
|
|
|
|
left = 0;
|
|
|
|
|
|
|
|
if ((buf == NULL) || (dataptr == NULL)) {
|
2018-05-15 15:49:10 +02:00
|
|
|
return 0;
|
2018-05-18 15:54:08 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Note some systems use byte copy if dataptr or one of the pbuf payload pointers are unaligned. */
|
|
|
|
for (p = buf; len != 0 && p != NULL; p = p->next) {
|
|
|
|
if ((offset != 0) && (offset >= p->len)) {
|
|
|
|
/* don't copy from this buffer -> on to the next */
|
|
|
|
offset -= p->len;
|
|
|
|
} else {
|
|
|
|
/* copy from this buffer. maybe only partially. */
|
|
|
|
buf_copy_len = p->len - offset;
|
|
|
|
if (buf_copy_len > len)
|
|
|
|
buf_copy_len = len;
|
|
|
|
/* copy the necessary parts of the buffer */
|
|
|
|
MEMCPY(&((char*)dataptr)[left], &((char*)p->payload)[offset], buf_copy_len);
|
|
|
|
copied_total += buf_copy_len;
|
|
|
|
left += buf_copy_len;
|
|
|
|
len -= buf_copy_len;
|
|
|
|
offset = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return copied_total;
|
2018-05-15 15:49:10 +02:00
|
|
|
}
|
2018-05-18 15:54:08 +02:00
|
|
|
|
2018-05-15 15:49:10 +02:00
|
|
|
err_t udp_connect(struct udp_pcb *pcb, const ip_addr_t *ipaddr, u16_t port)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t udp_sendto_if(struct udp_pcb *pcb, struct pbuf *p, const ip_addr_t *dst_ip, u16_t dst_port, struct netif *netif)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
err_t udp_sendto_if_src(struct udp_pcb *pcb, struct pbuf *p, const ip_addr_t *dst_ip, u16_t dst_port, struct netif *netif, const ip_addr_t *src_ip)
|
|
|
|
{
|
|
|
|
return ESP_OK;
|
|
|
|
}
|