I am trying to send packets from my Arduino to my desktop. Currently, the Arduino does connect to the network but fails when trying to call endPacket(). Here is the code and log:
/*
WiFi UDP Send and Receive String
This sketch wait an UDP packet on localPort using a WiFi shield.
When a packet is received an Acknowledge packet is sent to the client on port remotePort
Circuit:
* WiFi shield attached
created 30 December 2012
by dlf (Metodo2 srl)
*/
#include <SPI.h>
#include <WiFi.h>
#include <WiFiUdp.h>
int status = WL_IDLE_STATUS;
char ssid[] = "NETGEAR31"; // your network SSID (name)
char pass[] = "oddearth926"; // your network password (use for WPA, or use as key for WEP)
char ReplyBuffer[] = "acknowledged"; // a string to send back
WiFiUDP Udp;
void setup()
{
//Initialize serial and wait for port to open:
Serial.begin(9600);
// check for the presence of the shield:
if (WiFi.status() == WL_NO_SHIELD)
{
Serial.println("WiFi shield not present");
// don't continue:
while (true);
}
// attempt to connect to Wifi network:
while ( status != WL_CONNECTED)
{
Serial.print("Attempting to connect to SSID: ");
Serial.println(ssid);
// Connect to WPA/WPA2 network. Change this line if using open or WEP network:
status = WiFi.begin(ssid, pass);
// wait 10 seconds for connection:
}
Serial.println("Connected to wifi");
printWifiStatus();
Serial.println("\nStarting connection to server...");
if(!Udp.begin(8765))
{
Serial.println(F("failed"));
}
// if you get a connection, report back via serial:
}
void loop()
{
IPAddress ip(10,0,0,5);
int port = 8766;
// send a reply, to the IP address and port that sent us the packet we received
if(!Udp.beginPacket(ip, port))
{
Serial.println(F("Failed beginning packet"));
}
Udp.print(ReplyBuffer);
if(!Udp.endPacket())
{
Serial.println(F("Failed ending packet"));
}
}
void printWifiStatus() {
// print the SSID of the network you're attached to:
Serial.print("SSID: ");
Serial.println(WiFi.SSID());
// print your WiFi shield's IP address:
IPAddress ip = WiFi.localIP();
Serial.print("IP Address: ");
Serial.println(ip);
// print the received signal strength:
long rssi = WiFi.RSSI();
Serial.print("signal strength (RSSI):");
Serial.print(rssi);
Serial.println(" dBm");
}
Attempting to connect to SSID: NETGEAR31
Connected to wifi
SSID: NETGEAR31
IP Address: 10.0.0.34
signal strength (RSSI):-64 dBm
Starting connection to server...
Failed ending packet
Failed ending packet
Failed ending packet
Failed ending packet
Failed ending packet
Failed ending packet
It continues to spam “Failed ending packet” until I terminate it. Any ideas?
EDIT: Updated firmware and it works.