Improve gecko logging over WiFi
This commit is contained in:
parent
bd9e707e6c
commit
27bce4d461
1 changed files with 30 additions and 38 deletions
|
@ -23,16 +23,22 @@
|
||||||
*
|
*
|
||||||
* for WiiXplorer 2010
|
* for WiiXplorer 2010
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
|
#include <errno.h>
|
||||||
|
#include <network.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <network.h>
|
|
||||||
|
|
||||||
#define DESTINATION_IP "192.168.1.255"
|
#define DESTINATION_IP "192.168.1.255"
|
||||||
#define DESTINATION_PORT 4405
|
#define DESTINATION_PORT 4405
|
||||||
|
|
||||||
|
#define GPRINTF_SIZE 256
|
||||||
|
#define WIFIGECKO_SIZE 1024
|
||||||
|
|
||||||
|
char wifigeckobuffer[WIFIGECKO_SIZE];
|
||||||
|
|
||||||
static int connection = -1;
|
static int connection = -1;
|
||||||
|
|
||||||
void WifiGecko_Close()
|
void WifiGecko_Close()
|
||||||
|
@ -69,45 +75,31 @@ int WifiGecko_Connect()
|
||||||
|
|
||||||
int WifiGecko_Send(const char *data, int datasize)
|
int WifiGecko_Send(const char *data, int datasize)
|
||||||
{
|
{
|
||||||
|
if ((strlen(wifigeckobuffer) + datasize) < WIFIGECKO_SIZE)
|
||||||
|
strcat(wifigeckobuffer, data);
|
||||||
|
|
||||||
if (WifiGecko_Connect() < 0)
|
if (WifiGecko_Connect() < 0)
|
||||||
return connection;
|
return connection;
|
||||||
|
|
||||||
int ret = 0, done = 0, blocksize = 1024;
|
u32 sendsize = strlen(wifigeckobuffer);
|
||||||
|
|
||||||
while (done < datasize)
|
while (net_get_status() == -EBUSY)
|
||||||
{
|
usleep(10000);
|
||||||
if(blocksize > datasize-done)
|
int ret = net_send(connection, wifigeckobuffer, sendsize, 0);
|
||||||
blocksize = datasize-done;
|
|
||||||
|
|
||||||
ret = net_send(connection, data+done, blocksize, 0);
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
|
||||||
WifiGecko_Close();
|
WifiGecko_Close();
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
else if(ret == 0)
|
|
||||||
{
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
done += ret;
|
|
||||||
usleep (1000);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
memset(wifigeckobuffer, 0, WIFIGECKO_SIZE);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
void wifi_printf(const char *format, ...)
|
void wifi_printf(const char *format, ...)
|
||||||
{
|
{
|
||||||
char * tmp = NULL;
|
char gprintfBuffer[GPRINTF_SIZE];
|
||||||
va_list va;
|
va_list va;
|
||||||
va_start(va, format);
|
va_start(va, format);
|
||||||
if((vasprintf(&tmp, format, va) >= 0) && tmp)
|
size_t len = vsnprintf(gprintfBuffer, GPRINTF_SIZE - 1, format, va);
|
||||||
{
|
|
||||||
WifiGecko_Send(tmp, strlen(tmp));
|
|
||||||
}
|
|
||||||
va_end(va);
|
va_end(va);
|
||||||
|
if (len)
|
||||||
if(tmp)
|
WifiGecko_Send(gprintfBuffer, len);
|
||||||
free(tmp);
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue