현재 이더넷을 통한 간단한 전송 프로토콜을 만들기 위해 노력하고 있습니다. 우리 프로젝트의 이더넷 부분을 디버깅하는 데 사용할 SP605 자일링스 평가 보드가있다. 나는 그 예를 식인하려고 시도했지만 지금까지 실패했다. 현재, 통신은 오직 한 가지 방법 일 필요가 있습니다. 현재 netcat과 함께 전송되는 데이터를 확인하려고합니다. 나는 또한 Wireshark를 열고을 가지고 요구를 반복 시스템이 박히면서보고 있어요 :lwip ARP에서 RAW UDP 연결 만들기 ARP
2217 1323.697811000 Xilinx_00 : 01 : 192.168.1.11을 가지고 02 방송
ARP (60)? 192.168.1.10
에게 내가 가진 호스트 컴퓨터의 응답을 볼 수
2217 1323.697811000 Xilinx_00 : 01 : 192.168.1.11을 가지고 02 방송
ARP (60)? Tell 192.168.1.10
구성과 관련된 몇 가지 문제가 있지만 그것이 무엇인지 파악할 수없는 것 같습니다. 나는 그것이 recv 핸들러를 가지고 있지 않은 것과 관련이 있을지 모르지만 나는 확실하지 않다.
아래 코드는 제가 사용하고있는 코드입니다. lwip_init()는 자일링스가 제공 한 예제에서 호출을 모방 한 것입니다.
/*
* main.c
*
* Created on: Sep 24, 2013
* Author: Ian
*/
#include <stdio.h>
#include <string.h>
#include <stdio.h>
#include "lwip/init.h"
#include "xparameters.h"
#include "netif/xadapter.h"
#include "xenv_standalone.h"
#include "platform_config.h"
#include "xparameters.h"
#include "xintc.h"
#include "xil_exception.h"
#include "mb_interface.h"
#include "xtmrctr_l.h"
#include "lwip/udp.h"
#include "lwipopts.h"
#include "xil_printf.h"
struct ip_addr ipaddr, ipaddr_remote, netmask, gw;
void udp_test(void *arg, struct udp_pcb *pcb, struct pbuf *p, struct ip_addr *addr, u16_t port);
void print_ip(char *msg, struct ip_addr *ip)
{
print(msg);
xil_printf("%d.%d.%d.%d\r\n", ip4_addr1(ip), ip4_addr2(ip),
ip4_addr3(ip), ip4_addr4(ip));
}
void print_ip_settings(struct ip_addr *ip, struct ip_addr *mask, struct ip_addr *gw)
{
print_ip("Board IP: ", ip);
print_ip("Netmask : ", mask);
print_ip("Gateway : ", gw);
}
int main()
{
err_t error;
struct netif *netif, server_netif;
struct udp_pcb *udp_1;
struct pbuf *p;
char data[8] = "";
u16_t Port;
Port = 69;
int count = 0;
int n = 0;
int buflen = 8;
/* the mac address of the board. this should be unique per board */
unsigned char mac_ethernet_address[] = { 0x00, 0x0a, 0x35, 0x00, 0x01, 0x02 };
netif = &server_netif;
xil_printf("\r\n\r\n");
xil_printf("-----lwIP RAW Application ------\r\n");
/* initliaze IP addresses to be used */
IP4_ADDR(&ipaddr_remote, 192, 168, 1, 11);
IP4_ADDR(&ipaddr, 192, 168, 1, 10);
IP4_ADDR(&netmask, 255, 255, 255, 0);
IP4_ADDR(&gw, 192, 168, 1, 1);
print_ip_settings(&ipaddr, &netmask, &gw);
lwip_init();
if (!xemac_add(netif, &ipaddr, &netmask, &gw, mac_ethernet_address, PLATFORM_EMAC_BASEADDR)) {
xil_printf("Error adding N/W interface\r\n");
return -1;
}
netif_set_default(netif);
netif_set_up(netif);
Xil_ExceptionEnable(); //Setup complete start interrupts
udp_1 = udp_new();
error = udp_bind(udp_1, IP_ADDR_ANY, Port);
if (error != 0)
{
xil_printf("Failed %d\r\n", error);
}
else if (error == 0)
{
xil_printf("Success\r\n");
}
error = udp_connect(udp_1, &ipaddr_remote, Port);
if (error != 0)
{
xil_printf("Failed %d\r\n", error);
}
else if (error == 0)
{
xil_printf("Success\r\n");
}
while(1)
{
count++;
xemacif_input(netif);
if (count == 100000)
{
p = pbuf_alloc(PBUF_TRANSPORT, buflen, PBUF_POOL);
if (!p) {
xil_printf("error allocating pbuf\r\n");
return ERR_MEM;
}
memcpy(p->payload, data, buflen);
udp_send(udp_1, p);
xil_printf("SEND\r\n");
count = 0;
pbuf_free(p);
}
}
data[1] = '2';
}
UDP가 연결 지향적이지 않습니까? 따라서 UDP 연결이 없습니다. 그리고 전송 프로토콜은 이더넷을 통하지 않고 UDP를 넘는 것 같습니다 (심지어 UDP는 이더넷을 통해 전송됩니다). 어쨌든 당신의 플랫폼을 모르겠습니다. –
나는 전송 프로토콜이 UDP를 통해되어야한다는 것을 알고 있지만, 내 문제는 그것이 핸드셋이나 초기화의 일종을 놓치고있는 것 같아서 내 보드가 누가 내 터미널의 위치에 있는지 계속 묻는다. –
전송 프로토콜은 UDP를 초과하지만 반드시 그렇게 할 필요는 없습니다. 또한 코드를 읽지 않지만 대상 IP MAC을 검색하려고합니다. http://ask.wireshark.org/questions/9892/60-who-has-1692542531 –