IpIoCreateSndEntry (\r
IN OUT IP_IO *IpIo,\r
IN OUT NET_BUF *Pkt,\r
- IN VOID *Sender,\r
+ IN IP_IO_IP_PROTOCOL Sender,\r
IN VOID *Context OPTIONAL,\r
IN VOID *NotifyData OPTIONAL,\r
IN EFI_IP_ADDRESS *Dest OPTIONAL,\r
// Continue the receive.\r
//\r
if (IpInfo->IpVersion == IP_VERSION_4) {\r
- ((EFI_IP4_PROTOCOL *) (IpInfo->Ip))->Receive (\r
- (EFI_IP4_PROTOCOL *) (IpInfo->Ip),\r
- &IpInfo->DummyRcvToken.Ip4Token\r
- );\r
+ IpInfo->Ip.Ip4->Receive (\r
+ IpInfo->Ip.Ip4,\r
+ &IpInfo->DummyRcvToken.Ip4Token\r
+ );\r
} else {\r
- ((EFI_IP6_PROTOCOL *) (IpInfo->Ip))->Receive (\r
- (EFI_IP6_PROTOCOL *) (IpInfo->Ip),\r
- &IpInfo->DummyRcvToken.Ip6Token\r
- );\r
+ IpInfo->Ip.Ip6->Receive (\r
+ IpInfo->Ip.Ip6,\r
+ &IpInfo->DummyRcvToken.Ip6Token\r
+ );\r
}\r
}\r
\r
IP_IO *IpIo;\r
EFI_STATUS Status;\r
IP_IO_IP_RX_DATA *RxData;\r
- VOID *Ip;\r
EFI_NET_SESSION_DATA Session;\r
NET_BUF *Pkt;\r
\r
IpIo = (IP_IO *) Context;\r
- Ip = IpIo->Ip;\r
\r
if (IpIo->IpVersion == IP_VERSION_4) {\r
Status = IpIo->RcvToken.Ip4Token.Status;\r
Resume:\r
\r
if (IpIo->IpVersion == IP_VERSION_4){\r
- ((EFI_IP4_PROTOCOL *) Ip)->Receive (Ip, &(IpIo->RcvToken.Ip4Token));\r
+ IpIo->Ip.Ip4->Receive (IpIo->Ip.Ip4, &(IpIo->RcvToken.Ip4Token));\r
} else {\r
- ((EFI_IP6_PROTOCOL *) Ip)->Receive (Ip, &(IpIo->RcvToken.Ip6Token));\r
+ IpIo->Ip.Ip6->Receive (IpIo->Ip.Ip6, &(IpIo->RcvToken.Ip6Token));\r
}\r
}\r
\r
)\r
{\r
EFI_STATUS Status;\r
- VOID *Ip;\r
UINT8 IpVersion;\r
\r
if (IpIo->IsConfigured) {\r
\r
ASSERT ((IpVersion == IP_VERSION_4) || (IpVersion == IP_VERSION_6));\r
\r
- Ip = IpIo->Ip;\r
-\r
//\r
// configure ip\r
//\r
if (IpVersion == IP_VERSION_4){\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Configure (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- &OpenData->IpConfigData.Ip4CfgData\r
- );\r
+ Status = IpIo->Ip.Ip4->Configure (\r
+ IpIo->Ip.Ip4,\r
+ &OpenData->IpConfigData.Ip4CfgData\r
+ );\r
} else {\r
\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Configure (\r
- (EFI_IP6_PROTOCOL *) Ip, \r
- &OpenData->IpConfigData.Ip6CfgData\r
- );\r
+ Status = IpIo->Ip.Ip6->Configure (\r
+ IpIo->Ip.Ip6, \r
+ &OpenData->IpConfigData.Ip6CfgData\r
+ );\r
}\r
\r
if (EFI_ERROR (Status)) {\r
// @bug its code\r
//\r
if (IpVersion == IP_VERSION_4){\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Routes (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- TRUE,\r
- &mZeroIp4Addr,\r
- &mZeroIp4Addr,\r
- &mZeroIp4Addr\r
- );\r
+ Status = IpIo->Ip.Ip4->Routes (\r
+ IpIo->Ip.Ip4,\r
+ TRUE,\r
+ &mZeroIp4Addr,\r
+ &mZeroIp4Addr,\r
+ &mZeroIp4Addr\r
+ );\r
\r
if (EFI_ERROR (Status) && (EFI_NOT_FOUND != Status)) {\r
return Status;\r
//\r
// start to listen incoming packet\r
//\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Receive (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- &(IpIo->RcvToken.Ip4Token)\r
- );\r
+ Status = IpIo->Ip.Ip4->Receive (\r
+ IpIo->Ip.Ip4,\r
+ &(IpIo->RcvToken.Ip4Token)\r
+ );\r
if (EFI_ERROR (Status)) {\r
- ((EFI_IP4_PROTOCOL *) Ip)->Configure ((EFI_IP4_PROTOCOL *) Ip, NULL);\r
+ IpIo->Ip.Ip4->Configure (IpIo->Ip.Ip4, NULL);\r
goto ErrorExit;\r
}\r
\r
} else {\r
\r
IpIo->Protocol = OpenData->IpConfigData.Ip6CfgData.DefaultProtocol;\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Receive (\r
- (EFI_IP6_PROTOCOL *) Ip,\r
- &(IpIo->RcvToken.Ip6Token)\r
- );\r
+ Status = IpIo->Ip.Ip6->Receive (\r
+ IpIo->Ip.Ip6,\r
+ &(IpIo->RcvToken.Ip6Token)\r
+ );\r
if (EFI_ERROR (Status)) {\r
- ((EFI_IP6_PROTOCOL *) Ip)->Configure ((EFI_IP6_PROTOCOL *) Ip, NULL);\r
+ IpIo->Ip.Ip6->Configure (IpIo->Ip.Ip6, NULL);\r
goto ErrorExit;\r
}\r
}\r
)\r
{\r
EFI_STATUS Status;\r
- VOID *Ip;\r
IP_IO_IP_INFO *IpInfo;\r
UINT8 IpVersion;\r
\r
//\r
RemoveEntryList (&IpIo->Entry);\r
\r
- Ip = IpIo->Ip;\r
-\r
//\r
// Configure NULL Ip\r
//\r
if (IpVersion == IP_VERSION_4) {\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Configure ((EFI_IP4_PROTOCOL *) Ip, NULL);\r
+ Status = IpIo->Ip.Ip4->Configure (IpIo->Ip.Ip4, NULL);\r
} else {\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Configure ((EFI_IP6_PROTOCOL *) Ip, NULL);\r
+ Status = IpIo->Ip.Ip6->Configure (IpIo->Ip.Ip6, NULL);\r
}\r
if (EFI_ERROR (Status)) {\r
return Status;\r
)\r
{\r
EFI_STATUS Status;\r
- VOID *Ip;\r
+ IP_IO_IP_PROTOCOL Ip;\r
IP_IO_SEND_ENTRY *SndEntry;\r
\r
ASSERT ((IpIo->IpVersion != IP_VERSION_4) || (Dest != NULL));\r
// Send this Packet\r
//\r
if (IpIo->IpVersion == IP_VERSION_4){\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Transmit (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- &SndEntry->SndToken.Ip4Token\r
- );\r
+ Status = Ip.Ip4->Transmit (\r
+ Ip.Ip4,\r
+ &SndEntry->SndToken.Ip4Token\r
+ );\r
} else {\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Transmit (\r
- (EFI_IP6_PROTOCOL *) Ip,\r
- &SndEntry->SndToken.Ip6Token\r
- );\r
+ Status = Ip.Ip6->Transmit (\r
+ Ip.Ip6,\r
+ &SndEntry->SndToken.Ip6Token\r
+ );\r
}\r
\r
if (EFI_ERROR (Status)) {\r
{\r
LIST_ENTRY *Node;\r
IP_IO_SEND_ENTRY *SndEntry;\r
- VOID *Ip;\r
+ IP_IO_IP_PROTOCOL Ip;\r
\r
ASSERT ((IpIo != NULL) && (Packet != NULL));\r
\r
Ip = SndEntry->Ip;\r
\r
if (IpIo->IpVersion == IP_VERSION_4) {\r
- ((EFI_IP4_PROTOCOL *) Ip)->Cancel (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- &SndEntry->SndToken.Ip4Token\r
- );\r
+ Ip.Ip4->Cancel (\r
+ Ip.Ip4,\r
+ &SndEntry->SndToken.Ip4Token\r
+ );\r
} else {\r
- ((EFI_IP6_PROTOCOL *) Ip)->Cancel (\r
- (EFI_IP6_PROTOCOL *) Ip,\r
- &SndEntry->SndToken.Ip6Token\r
- );\r
+ Ip.Ip6->Cancel (\r
+ Ip.Ip6,\r
+ &SndEntry->SndToken.Ip6Token\r
+ );\r
}\r
\r
break;\r
)\r
{\r
EFI_STATUS Status;\r
- VOID *Ip;\r
+ IP_IO_IP_PROTOCOL Ip;\r
UINT8 IpVersion;\r
EFI_IP4_MODE_DATA Ip4ModeData;\r
EFI_IP6_MODE_DATA Ip6ModeData;\r
Ip = IpInfo->Ip;\r
\r
if (IpInfo->IpVersion == IP_VERSION_4) {\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Configure ((EFI_IP4_PROTOCOL *) Ip, IpConfigData);\r
+ Status = Ip.Ip4->Configure (Ip.Ip4, IpConfigData);\r
} else {\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Configure ((EFI_IP6_PROTOCOL *) Ip, IpConfigData);\r
+ Status = Ip.Ip6->Configure (Ip.Ip6, IpConfigData);\r
}\r
\r
if (EFI_ERROR (Status)) {\r
if (IpInfo->IpVersion == IP_VERSION_4){\r
\r
if (((EFI_IP4_CONFIG_DATA *) IpConfigData)->UseDefaultAddress) {\r
- ((EFI_IP4_PROTOCOL *) Ip)->GetModeData (\r
- (EFI_IP4_PROTOCOL *) Ip, \r
- &Ip4ModeData, \r
- NULL, \r
- NULL\r
- );\r
+ Ip.Ip4->GetModeData (\r
+ Ip.Ip4, \r
+ &Ip4ModeData, \r
+ NULL, \r
+ NULL\r
+ );\r
\r
((EFI_IP4_CONFIG_DATA*) IpConfigData)->StationAddress = Ip4ModeData.ConfigData.StationAddress;\r
((EFI_IP4_CONFIG_DATA*) IpConfigData)->SubnetMask = Ip4ModeData.ConfigData.SubnetMask;\r
sizeof (IP4_ADDR)\r
);\r
\r
- Status = ((EFI_IP4_PROTOCOL *) Ip)->Receive (\r
- (EFI_IP4_PROTOCOL *) Ip,\r
- &IpInfo->DummyRcvToken.Ip4Token\r
- );\r
+ Status = Ip.Ip4->Receive (\r
+ Ip.Ip4,\r
+ &IpInfo->DummyRcvToken.Ip4Token\r
+ );\r
if (EFI_ERROR (Status)) {\r
- ((EFI_IP4_PROTOCOL*)Ip)->Configure (Ip, NULL);\r
+ Ip.Ip4->Configure (Ip.Ip4, NULL);\r
}\r
} else {\r
-\r
- ((EFI_IP6_PROTOCOL *) Ip)->GetModeData (\r
- (EFI_IP6_PROTOCOL *) Ip,\r
- &Ip6ModeData,\r
- NULL,\r
- NULL\r
- );\r
+ Ip.Ip6->GetModeData (\r
+ Ip.Ip6,\r
+ &Ip6ModeData,\r
+ NULL,\r
+ NULL\r
+ );\r
\r
if (Ip6ModeData.IsConfigured) {\r
CopyMem (\r
sizeof (EFI_IPv6_ADDRESS)\r
);\r
\r
- Status = ((EFI_IP6_PROTOCOL *) Ip)->Receive (\r
- (EFI_IP6_PROTOCOL *) Ip,\r
- &IpInfo->DummyRcvToken.Ip6Token\r
- );\r
+ Status = Ip.Ip6->Receive (\r
+ Ip.Ip6,\r
+ &IpInfo->DummyRcvToken.Ip6Token\r
+ );\r
if (EFI_ERROR (Status)) {\r
- ((EFI_IP6_PROTOCOL *) Ip)->Configure ((EFI_IP6_PROTOCOL *) Ip, NULL);\r
+ Ip.Ip6->Configure (Ip.Ip6, NULL);\r
}\r
} \r
} else {\r
RemoveEntryList (&IpInfo->Entry);\r
\r
if (IpVersion == IP_VERSION_4){\r
- ((EFI_IP4_PROTOCOL *) (IpInfo->Ip))->Configure (\r
- (EFI_IP4_PROTOCOL *) (IpInfo->Ip),\r
- NULL\r
- );\r
+ IpInfo->Ip.Ip4->Configure (\r
+ IpInfo->Ip.Ip4,\r
+ NULL\r
+ );\r
IpIoCloseProtocolDestroyIpChild (\r
IpIo->Controller,\r
IpIo->Image,\r
\r
} else {\r
\r
- ((EFI_IP6_PROTOCOL *) (IpInfo->Ip))->Configure (\r
- (EFI_IP6_PROTOCOL *) (IpInfo->Ip),\r
- NULL\r
- );\r
+ IpInfo->Ip.Ip6->Configure (\r
+ IpInfo->Ip.Ip6,\r
+ NULL\r
+ );\r
\r
IpIoCloseProtocolDestroyIpChild (\r
IpIo->Controller,\r
return EFI_NOT_STARTED;\r
}\r
\r
- Ip = (EFI_IP6_PROTOCOL *) (IpIo->Ip);\r
+ Ip = IpIo->Ip.Ip6;\r
\r
return Ip->Neighbors (Ip, FALSE, &Neighbor->v6, NULL, Timeout, TRUE);\r
}\r