EFI_IPv6_ADDRESS AllNodes;\r
IP6_NEIGHBOR_ENTRY *NeighborCache;\r
\r
+ IpSb->State = IP6_SERVICE_DESTROY;\r
+\r
+ if (IpSb->Timer != NULL) {\r
+ gBS->SetTimer (IpSb->Timer, TimerCancel, 0);\r
+ gBS->CloseEvent (IpSb->Timer);\r
+\r
+ IpSb->Timer = NULL;\r
+ }\r
+\r
+ if (IpSb->FasterTimer != NULL) {\r
+ gBS->SetTimer (IpSb->FasterTimer, TimerCancel, 0);\r
+ gBS->CloseEvent (IpSb->FasterTimer);\r
+\r
+ IpSb->FasterTimer = NULL;\r
+ }\r
+\r
Ip6ConfigCleanInstance (&IpSb->Ip6ConfigInstance);\r
\r
if (!IpSb->LinkLocalDadFail) {\r
gBS->CloseEvent (IpSb->RecvRequest.MnpToken.Event);\r
}\r
\r
- if (IpSb->Timer != NULL) {\r
- gBS->SetTimer (IpSb->Timer, TimerCancel, 0);\r
- gBS->CloseEvent (IpSb->Timer);\r
-\r
- IpSb->Timer = NULL;\r
- }\r
-\r
- if (IpSb->FasterTimer != NULL) {\r
- gBS->SetTimer (IpSb->FasterTimer, TimerCancel, 0);\r
- gBS->CloseEvent (IpSb->FasterTimer);\r
-\r
- IpSb->FasterTimer = NULL;\r
- }\r
//\r
// Free the Neighbor Discovery resources\r
//\r
DataItem->DataSize,\r
DataItem->Data.Ptr\r
);\r
- if (EFI_ERROR(Status)) {\r
+ if (EFI_ERROR(Status) && Status != EFI_NOT_READY) {\r
goto ON_ERROR;\r
}\r
}\r
}\r
}\r
\r
- if (!EFI_ERROR (Status)) {\r
- //\r
- // ready to go: start the receiving and timer\r
- //\r
- Status = Ip6ReceiveFrame (Ip6AcceptFrame, IpSb);\r
- if (EFI_ERROR (Status)) {\r
- goto ON_ERROR;\r
- }\r
+ //\r
+ // ready to go: start the receiving and timer\r
+ //\r
+ Status = Ip6ReceiveFrame (Ip6AcceptFrame, IpSb);\r
+ if (EFI_ERROR (Status)) {\r
+ goto ON_ERROR;\r
+ }\r
\r
- //\r
- // The timer expires every 100 (IP6_TIMER_INTERVAL_IN_MS) milliseconds.\r
- //\r
- Status = gBS->SetTimer (\r
- IpSb->FasterTimer,\r
- TimerPeriodic,\r
- TICKS_PER_MS * IP6_TIMER_INTERVAL_IN_MS\r
- );\r
- if (EFI_ERROR (Status)) {\r
- goto ON_ERROR;\r
- }\r
+ //\r
+ // The timer expires every 100 (IP6_TIMER_INTERVAL_IN_MS) milliseconds.\r
+ //\r
+ Status = gBS->SetTimer (\r
+ IpSb->FasterTimer,\r
+ TimerPeriodic,\r
+ TICKS_PER_MS * IP6_TIMER_INTERVAL_IN_MS\r
+ );\r
+ if (EFI_ERROR (Status)) {\r
+ goto ON_ERROR;\r
+ }\r
\r
- //\r
- // The timer expires every 1000 (IP6_ONE_SECOND_IN_MS) milliseconds.\r
- //\r
- Status = gBS->SetTimer (\r
- IpSb->Timer,\r
- TimerPeriodic,\r
- TICKS_PER_MS * IP6_ONE_SECOND_IN_MS\r
- );\r
- if (EFI_ERROR (Status)) {\r
- goto ON_ERROR;\r
- } \r
+ //\r
+ // The timer expires every 1000 (IP6_ONE_SECOND_IN_MS) milliseconds.\r
+ //\r
+ Status = gBS->SetTimer (\r
+ IpSb->Timer,\r
+ TimerPeriodic,\r
+ TICKS_PER_MS * IP6_ONE_SECOND_IN_MS\r
+ );\r
+ if (EFI_ERROR (Status)) {\r
+ goto ON_ERROR;\r
+ } \r
\r
- //\r
- // Initialize the IP6 ID\r
- //\r
- mIp6Id = NET_RANDOM (NetRandomInitSeed ());\r
+ //\r
+ // Initialize the IP6 ID\r
+ //\r
+ mIp6Id = NET_RANDOM (NetRandomInitSeed ());\r
\r
- return EFI_SUCCESS;\r
- }\r
+ return EFI_SUCCESS;\r
\r
ON_ERROR:\r
Ip6CleanService (IpSb);\r
);\r
} else if (IsListEmpty (&IpSb->Children)) {\r
State = IpSb->State;\r
- IpSb->State = IP6_SERVICE_DESTROY;\r
-\r
Status = Ip6CleanService (IpSb);\r
if (EFI_ERROR (Status)) {\r
IpSb->State = State;\r
the existing child handle.\r
\r
@retval EFI_SUCCES The child handle was created with the I/O services.\r
- @retval EFI_OUT_OF_RESOURCES There are not enough resources availabe to create\r
+ @retval EFI_OUT_OF_RESOURCES There are not enough resources available to create\r
the child.\r
@retval other The child handle was not created.\r
\r