mirror of
https://github.com/dborth/fceugx.git
synced 2025-01-24 22:41:12 +01:00
update net code
This commit is contained in:
parent
af4e153893
commit
95ccb7450b
@ -175,7 +175,7 @@ bool DownloadUpdate()
|
||||
***************************************************************************/
|
||||
|
||||
static lwp_t networkthread = LWP_THREAD_NULL;
|
||||
static u8 netstack[8192] ATTRIBUTE_ALIGN (32);
|
||||
static u8 netstack[32768] ATTRIBUTE_ALIGN (32);
|
||||
|
||||
static void * netcb (void *arg)
|
||||
{
|
||||
@ -189,7 +189,7 @@ static void * netcb (void *arg)
|
||||
retry = 5;
|
||||
|
||||
while (retry>0 && (netHalt != 2))
|
||||
{
|
||||
{
|
||||
if(!first)
|
||||
{
|
||||
bool reset=false;
|
||||
@ -199,6 +199,7 @@ static void * netcb (void *arg)
|
||||
res = net_get_status();
|
||||
if(res != -EBUSY) // trying to init net so we can't kill the net
|
||||
{
|
||||
usleep(2000);
|
||||
net_wc24cleanup(); //kill the net
|
||||
reset=true;
|
||||
break;
|
||||
@ -213,6 +214,7 @@ static void * netcb (void *arg)
|
||||
}
|
||||
first=false;
|
||||
net_deinit();
|
||||
usleep(2000);
|
||||
res = net_init_async(NULL, NULL);
|
||||
|
||||
if(res != 0)
|
||||
@ -223,7 +225,7 @@ static void * netcb (void *arg)
|
||||
}
|
||||
|
||||
res = net_get_status();
|
||||
wait = 400; // only wait 10 sec
|
||||
wait = 400; // only wait 8 sec
|
||||
while (res == -EBUSY && wait > 0 && (netHalt != 2))
|
||||
{
|
||||
usleep(20000);
|
||||
@ -232,7 +234,6 @@ static void * netcb (void *arg)
|
||||
}
|
||||
|
||||
if(res==0) break;
|
||||
|
||||
retry--;
|
||||
usleep(2000);
|
||||
}
|
||||
@ -273,13 +274,11 @@ void StartNetworkThread()
|
||||
***************************************************************************/
|
||||
void StopNetworkThread()
|
||||
{
|
||||
if(networkthread == LWP_THREAD_NULL)
|
||||
if(networkthread == LWP_THREAD_NULL || !LWP_ThreadIsSuspended(networkthread))
|
||||
return;
|
||||
|
||||
netHalt = 2;
|
||||
|
||||
if(LWP_ThreadIsSuspended(networkthread))
|
||||
LWP_ResumeThread(networkthread);
|
||||
LWP_ResumeThread(networkthread);
|
||||
|
||||
// wait for thread to finish
|
||||
LWP_JoinThread(networkthread, NULL);
|
||||
|
Loading…
x
Reference in New Issue
Block a user