Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Manual override of SBE side #3

Open
hanetzer opened this issue Aug 4, 2019 · 6 comments
Open

Manual override of SBE side #3

hanetzer opened this issue Aug 4, 2019 · 6 comments

Comments

@hanetzer
Copy link

hanetzer commented Aug 4, 2019

So, I'm beginning work on porting coreboot to power9, specifically the Talos II family of boards.
In part of this, I'll be altering the hostboot bootloader to kickstart the coreboot way of doing things, and as such will need to alter the seeproms.

I had the idea to use the RebootAttempts variable to force it one way or the other, keeping a
'normal' seeprom image on one side and working on the other, so as to have a safe fallback
(the way the talos machines are wired up one can easily read/write one seeprom side via i2c,
and not the other). However, using busctl set-property for it resets it to 3.

So, I had an idea based on the cfam override file; what if we took the code below

if (getBootCount() > 0)
{
sbeSide = 0;
log<level::INFO>("Setting SBE seeprom side to 0",
entry("SBE_SIDE_SELECT=%d", 0));
}
else
{
sbeSide = 0x00004000;
log<level::INFO>("Setting SBE seeprom side to 1",
entry("SBE_SIDE_SELECT=%d", 1));
}

and altered it to first check for some override file to determine which seeprom side to boot,
then doing the normal RebootAttempts manner? It would keep current behavior, and allow a
bit of flex when doing sbe work.

Do you think this would be a good option for 'everyone' or should it just be a local hack I use
indev?

@geissonator
Copy link
Contributor

I'd tend to lean more towards a openpower setting that could be used to override the boot side selection vs. something like the CFAM override. Maybe a SBE.interface.yaml with a Settings property out at https://github.com/openbmc/openpower-dbus-interfaces/tree/master/org/open_power/Control/? @spinler ?

@amboar
Copy link
Member

amboar commented Aug 5, 2019

@geissonator I'm with you there, not sure why we chose to hide it behind the boot counter initially.

@geissonator
Copy link
Contributor

The current design using the boot counter was just the default rule from previous POWER systems. Providing an override to that policy makes sense to me (for both production and lab debug)

@hanetzer
Copy link
Author

hanetzer commented Aug 7, 2019

@geissonator @amboar as long as something is done along those lines I'd be happy.
Currently I have two unconditional openpower-proc-control-[01] binaries which I manually
swap symlinks to openpower-proc-control which forces the boot of one or the other, but
a less hackish way would be appreciated.

@dcrowell77
Copy link

keeping a 'normal' seeprom image on one side and working on the other, so as to have a safe fallback

This is exactly the way the current code works. We update the active side in Hostboot and then force a reboot. If the reboot succeeds and we boot up to our SBE update step again then we declare it good and write the same image into the backup side. If we can't boot that far, OpenBMC will eventually flip sides and boot us from the backup side. Hostboot knows we're on the wrong side and won't try to update it.

@hanetzer
Copy link
Author

@dcrowell77 Ah, that's cool. On another note I've actually figured a way I should be able to boot
coreboot without changing either the seeprom's sbe firmware or the hostboot binary by wrapping
the coreboot.rom in ffs style headers with the tool fpart, so this particular issue isn't as important
as I thought it to be at the time.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants