> On Apr 1, 2015, at 3:34 PM, Narinder Dhillon <ndhillo...@gmail.com> wrote:
>
> Hi Andrew,
>
> I did do a hex dump but was not sure why there would be difference. The boot
> options are stored in flash and I can see that the source path matches the
> one stored in flash. Not sure why the TmpDevicePath is different as it is set
> to SourcePath at the top of the function. But the old variable stored in
> flash does differ in that one byte from the new one that I created. Hmmm.
> What is that byte 0x44 ?
>
I should probably charge for this….
Looks like the MAC address is changing?
> OLD Variable:
> -----------------
> Variable NV+RT+BS '8BE4DF61-93CA-11D2-AA0D-00E098032B8C:Boot0000' DataSize =
> 0x5
> F
>
> 00000000: 00 00 00 00
UINT32 Attributes;
> 41 00
UINT16 FilePathListLength
> 6E 00-30 00 73 00 67 00 6D 00 *....A.n.0.s.g.m.*
> 00000010: 69 00 69 00 70 00 78 00-65 00 00 00
CHAR16 Description[]
Now we have FilePathList[]
> 02 01 0C 00 *i.i.p.x.e.......*
> 00000020: D0 41 03 0A 02 00 00 00-
ACPI “PCI Root Bridge"
> 01 01 06 00 00 02
PCI_DEVICE_PATH Dev 2 Func 0
> 01 01 *.A..............*
> 00000030: 06 00 00 00
PCI_DEVICE_PATH Dev 0 Func 0
> 03 0B 25 00-
> 12 34 56 78 9A BC
> 00 00 *......%..4Vx....*
> 00000040: 00 00 00 00 70 79 69 FF-03 00 00 00 98 2C 97 FF
> *....pyi......,..*
> 00000050: 03 01 00 00 34 46 67 FF
MAC_ADDR_DEVICE_PATH.EFI_MAC_ADDRESS
> -01
MAC_ADDR_DEVICE_PATH.IfType
MAC_ADDR_DEVICE_PATH
> 7F FF 04 00
END Device Path
> 00 00 *....4Fg........*
>
Thanks,
Andrew Fish
> NEW VARIABLE:
> --------------------
> Variable NV+RT+BS '8BE4DF61-93CA-11D2-AA0D-00E098032B8C:Boot0000' DataSize =
> 0x5
> F
>
> 00000000: 00 00 00 00 41 00 6E 00-30 00 73 00 67 00 6D 00
> *....A.n.0.s.g.m.*
> 00000010: 69 00 69 00 70 00 78 00-65 00 00 00 02 01 0C 00
> *i.i.p.x.e.......*
> 00000020: D0 41 03 0A 02 00 00 00-01 01 06 00 00 02 01 01
> *.A..............*
> 00000030: 06 00 00 00 03 0B 25 00-12 34 56 78 9A BC 00 00
> *......%..4Vx....*
> 00000040: 00 00 00 00 E0 79 69 FF-03 00 00 00 98 2C 97 FF
> *.....yi......,..*
> 00000050: 03 01 00 00 34 46 67 FF-01 7F FF 04 00 00 00
> *....4Fg........*
>
>
> Tmp Device Path
> 'PciRoot(0x2)/Pci(0x2,0x0)/Pci(0x0,0x0)/MAC(123456789ABC,0x1)'
> CoreLocateDevicePath 515
>
> CoreLocateDevicePath 518 Size:61 SourceSize:61
>
> 0x2 == 0x2
>
> 0x1 == 0x1
>
> 0xC == 0xC
>
> 0x0 == 0x0
>
> 0xD0 == 0xD0
>
> 0x41 == 0x41
>
> 0x3 == 0x3
>
> 0xA == 0xA
>
> 0x2 == 0x2
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x1 == 0x1
>
> 0x1 == 0x1
>
> 0x6 == 0x6
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x2 == 0x2
>
> 0x1 == 0x1
>
> 0x1 == 0x1
>
> 0x6 == 0x6
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x3 == 0x3
>
> 0xB == 0xB
>
> 0x25 == 0x25
>
> 0x0 == 0x0
>
> 0x12 == 0x12
>
> 0x34 == 0x34
>
> 0x56 == 0x56
>
> 0x78 == 0x78
>
> 0x9A == 0x9A
>
> 0xBC == 0xBC
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x70 == 0xE0 <<<<<<<<<<<<<<
>
> 0x79 == 0x79
>
> 0x69 == 0x69
>
> 0xFF == 0xFF
>
> 0x3 == 0x3
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x98 == 0x98
>
> 0x2C == 0x2C
>
> 0x97 == 0x97
>
> 0xFF == 0xFF
>
> 0x3 == 0x3
>
> 0x1 == 0x1
>
> 0x0 == 0x0
>
> 0x0 == 0x0
>
> 0x34 == 0x34
>
> 0x46 == 0x46
>
> 0x67 == 0x67
>
> 0xFF == 0xFF
>
> 0x1 == 0x1
>
>
>
> On Wed, Apr 1, 2015 at 2:58 PM, Andrew Fish <af...@apple.com
> <mailto:af...@apple.com>> wrote:
>
> > On Apr 1, 2015, at 2:27 PM, Narinder Dhillon <ndhillo...@gmail.com
> > <mailto:ndhillo...@gmail.com>> wrote:
> >
> > Hi All,
> >
> > I add a boot option for PXE boot, pointed to a network interface, and boot
> > from it successfully. If I update my firmware, flash into spi-nor device
> > and then try pxe boot again, fails.
> > If I now delete the old boot option in boot manager and add a new one, then
> > PXE boot works.
> >
> > I have chased this down to a comparison in
> > MdeModulePkg/Core/Dxe/Hand/Locate.c and in function CoreLocateDevicePath,
> > the following comparison fails even though the device path strings look the
> > same.
> >
> > ----------------------------------------------------------------------------------------------------------------
> > if ((Size <= SourceSize) && CompareMem (SourcePath, TmpDevicePath,
> > (UINTN) Size) == 0) {
> > ----------------------------------------------------------------------------------------------------------------
> >
> > I used the device path to text protocol to print both paths and they look
> > the same but I am not sure why this comparison is failing.
> >
> > Tmp Device Path
> > 'PciRoot(0x2)/Pci(0x2,0x0)/Pci(0x0,0x0)/MAC(123456789ABC,0x1)'
> >
> > Source Device Path
> > 'PciRoot(0x2)/Pci(0x2,0x0)/Pci(0x0,0x0)/MAC(123456789ABC,0x1)'
> >
>
> The text representation of a device path is a summary. The compare is done on
> the actual device path binary. The device paths are binary bits with no
> strings. The strings are just convention to make things human readable. So
> hexdump the device paths to see the difference.
>
> Thanks,
>
> Andrew Fish
>
> > Any suggestions on how I can debug this ?
> > Thanx,
> >
> >
> > ------------------------------------------------------------------------------
> > Dive into the World of Parallel Programming The Go Parallel Website,
> > sponsored
> > by Intel and developed in partnership with Slashdot Media, is your hub for
> > all
> > things parallel software development, from weekly thought leadership blogs
> > to
> > news, videos, case studies, tutorials and more. Take a look and join the
> > conversation now.
> > http://goparallel.sourceforge.net/_______________________________________________
> >
> > <http://goparallel.sourceforge.net/_______________________________________________>
> > edk2-devel mailing list
> > edk2-devel@lists.sourceforge.net <mailto:edk2-devel@lists.sourceforge.net>
> > https://lists.sourceforge.net/lists/listinfo/edk2-devel
> > <https://lists.sourceforge.net/lists/listinfo/edk2-devel>
>
>
> ------------------------------------------------------------------------------
> Dive into the World of Parallel Programming The Go Parallel Website, sponsored
> by Intel and developed in partnership with Slashdot Media, is your hub for all
> things parallel software development, from weekly thought leadership blogs to
> news, videos, case studies, tutorials and more. Take a look and join the
> conversation now. http://goparallel.sourceforge.net/
> <http://goparallel.sourceforge.net/>
> _______________________________________________
> edk2-devel mailing list
> edk2-devel@lists.sourceforge.net <mailto:edk2-devel@lists.sourceforge.net>
> https://lists.sourceforge.net/lists/listinfo/edk2-devel
> <https://lists.sourceforge.net/lists/listinfo/edk2-devel>
>
>
------------------------------------------------------------------------------
Dive into the World of Parallel Programming The Go Parallel Website, sponsored
by Intel and developed in partnership with Slashdot Media, is your hub for all
things parallel software development, from weekly thought leadership blogs to
news, videos, case studies, tutorials and more. Take a look and join the
conversation now. http://goparallel.sourceforge.net/
_______________________________________________
edk2-devel mailing list
edk2-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/edk2-devel