Re: [edk2] Force reconnect children from within a DXE driver

2016-10-26 Thread Laszlo Ersek
On 10/26/16 18:02, Marcin Wojtas wrote:
> Hi Laszlo,
> 
> Thank you for your help. It worked finally worked.

Thanks for the feedback! :)
Laszlo

> 2016-10-17 19:00 GMT+02:00 Laszlo Ersek :
>> On 10/17/16 18:05, Marcin Wojtas wrote:
>>> Hi,
>>>
>>> Short introduction to the problem I'm facing with EDK2: I implemented
>>> 'ifconfig' command extension allowing to change interface's MAC
>>> address or reset it to the default value. For that I needed to add a
>>> couple of helper functions in DxeNetLib, which parse input string and
>>> one that calls Snp->StationAddress callback from the NIC driver.
>>>
>>> The problem is that the drivers associated to interface device
>>> comprise a copy of SnpMode, not original pointer. It causes an obvious
>>> mismatch, because only the latter got updated with new
>>> Snp->Mode->CurrentAddress. I found out that using 'reconnect' command
>>> after MAC address change from uefi shell helps and the network can
>>> operate properly.
>>>
>>> Hence I have a question - is there a way to force reconnecting all
>>> children drivers from the network controller driver level? I.e. it
>>> would be great if it was possible not to be forced to call 'ifconfig'
>>> command and then 'reconnect', but call some function(s) e.g. from
>>> Snp->StationAddress callback.
>>
>> I would try this:
>> - From the shell command (which is running in the shell application),
>> open the SNP interface in exclusive mode. This should either fail (if
>> there's already an exclusive open on the interface), or succeed and
>> force other drivers to disconnect, recursively.
>> - Call Snp->StationAddress to change the MAC.
>> - Close the protocol interface.
>> - Call gBS->ConnectController() to (re)connect all the drivers,
>> recursively, to the handle with the SNP on it.
>>
>> Thanks
>> Laszlo
>>

___
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel


Re: [edk2] Force reconnect children from within a DXE driver

2016-10-26 Thread Marcin Wojtas
Hi Laszlo,

Thank you for your help. It worked finally worked.

Best regards,
Marcin

2016-10-17 19:00 GMT+02:00 Laszlo Ersek :
> On 10/17/16 18:05, Marcin Wojtas wrote:
>> Hi,
>>
>> Short introduction to the problem I'm facing with EDK2: I implemented
>> 'ifconfig' command extension allowing to change interface's MAC
>> address or reset it to the default value. For that I needed to add a
>> couple of helper functions in DxeNetLib, which parse input string and
>> one that calls Snp->StationAddress callback from the NIC driver.
>>
>> The problem is that the drivers associated to interface device
>> comprise a copy of SnpMode, not original pointer. It causes an obvious
>> mismatch, because only the latter got updated with new
>> Snp->Mode->CurrentAddress. I found out that using 'reconnect' command
>> after MAC address change from uefi shell helps and the network can
>> operate properly.
>>
>> Hence I have a question - is there a way to force reconnecting all
>> children drivers from the network controller driver level? I.e. it
>> would be great if it was possible not to be forced to call 'ifconfig'
>> command and then 'reconnect', but call some function(s) e.g. from
>> Snp->StationAddress callback.
>
> I would try this:
> - From the shell command (which is running in the shell application),
> open the SNP interface in exclusive mode. This should either fail (if
> there's already an exclusive open on the interface), or succeed and
> force other drivers to disconnect, recursively.
> - Call Snp->StationAddress to change the MAC.
> - Close the protocol interface.
> - Call gBS->ConnectController() to (re)connect all the drivers,
> recursively, to the handle with the SNP on it.
>
> Thanks
> Laszlo
>
___
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel


Re: [edk2] Force reconnect children from within a DXE driver

2016-10-17 Thread Laszlo Ersek
On 10/17/16 18:05, Marcin Wojtas wrote:
> Hi,
> 
> Short introduction to the problem I'm facing with EDK2: I implemented
> 'ifconfig' command extension allowing to change interface's MAC
> address or reset it to the default value. For that I needed to add a
> couple of helper functions in DxeNetLib, which parse input string and
> one that calls Snp->StationAddress callback from the NIC driver.
> 
> The problem is that the drivers associated to interface device
> comprise a copy of SnpMode, not original pointer. It causes an obvious
> mismatch, because only the latter got updated with new
> Snp->Mode->CurrentAddress. I found out that using 'reconnect' command
> after MAC address change from uefi shell helps and the network can
> operate properly.
> 
> Hence I have a question - is there a way to force reconnecting all
> children drivers from the network controller driver level? I.e. it
> would be great if it was possible not to be forced to call 'ifconfig'
> command and then 'reconnect', but call some function(s) e.g. from
> Snp->StationAddress callback.

I would try this:
- From the shell command (which is running in the shell application),
open the SNP interface in exclusive mode. This should either fail (if
there's already an exclusive open on the interface), or succeed and
force other drivers to disconnect, recursively.
- Call Snp->StationAddress to change the MAC.
- Close the protocol interface.
- Call gBS->ConnectController() to (re)connect all the drivers,
recursively, to the handle with the SNP on it.

Thanks
Laszlo

___
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel


[edk2] Force reconnect children from within a DXE driver

2016-10-17 Thread Marcin Wojtas
Hi,

Short introduction to the problem I'm facing with EDK2: I implemented
'ifconfig' command extension allowing to change interface's MAC
address or reset it to the default value. For that I needed to add a
couple of helper functions in DxeNetLib, which parse input string and
one that calls Snp->StationAddress callback from the NIC driver.

The problem is that the drivers associated to interface device
comprise a copy of SnpMode, not original pointer. It causes an obvious
mismatch, because only the latter got updated with new
Snp->Mode->CurrentAddress. I found out that using 'reconnect' command
after MAC address change from uefi shell helps and the network can
operate properly.

Hence I have a question - is there a way to force reconnecting all
children drivers from the network controller driver level? I.e. it
would be great if it was possible not to be forced to call 'ifconfig'
command and then 'reconnect', but call some function(s) e.g. from
Snp->StationAddress callback.

I would appreciate any help.

Best regards,
Marcin
___
edk2-devel mailing list
edk2-devel@lists.01.org
https://lists.01.org/mailman/listinfo/edk2-devel