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

Keyword VPD:Write keyword's value on hardware #459

Open
wants to merge 1 commit into
base: P11_Dev
Choose a base branch
from

Conversation

PriyangaRamasamy
Copy link

This commit implements API to write keyword's value on hardware for keyword VPD types.

Test:
busctl call com.ibm.VPD.Manager /com/ibm/VPD/Manager com.ibm.VPD.Manager WriteKeyword sv "/tmp/keyword.dat" "(say)" "FN" 2 0x65 0x66

hexdump -C keyword.dat
00000010 53 41 53 84 9b 00 46 4e 08 65 66 31 4b 55 37 32 |SAS...FN.ef1KU72|

busctl get-property xyz.openbmc_project.Inventory.Manager /xyz/openbmc_project/inventory/system/chassis/motherboard /keyword_vpd_type com.ibm.ipzvpd.VINI FN

ay 8 101 102 49 75 85 55 50 52

Change-Id: I203c7d6def40830459f90adf9c0e3c88560956e5

This commit implements API to write keyword's value on hardware for
keyword VPD types.

Test:
busctl call com.ibm.VPD.Manager /com/ibm/VPD/Manager com.ibm.VPD.Manager
WriteKeyword  sv "/tmp/keyword.dat" "(say)" "FN" 2 0x65 0x66

hexdump -C keyword.dat
00000010 53 41 53 84 9b 00 46 4e  08 65 66 31 4b 55 37 32
|SAS...FN.ef1KU72|

busctl get-property xyz.openbmc_project.Inventory.Manager
/xyz/openbmc_project/inventory/system/chassis/motherboard
/keyword_vpd_type com.ibm.ipzvpd.VINI FN

ay 8 101 102 49 75 85 55 50 52

Change-Id: I203c7d6def40830459f90adf9c0e3c88560956e5
Signed-off-by: Priyanga Ramasamy <priyanga24@in.ibm.com>
@@ -120,7 +120,8 @@ std::shared_ptr<ParserInterface>
{
logging::logMessage("KWD vpd parser selected for VPD file path " +
i_vpdFilePath);
return std::make_shared<KeywordVpdParser>(i_vpdVector);
return std::make_shared<KeywordVpdParser>(i_vpdVector,

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this file path validated before using ?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

validated at the caller's place here https://github.com/ibm-openbmc/openpower-vpd-parser/blob/P11_Dev/src/manager.cpp#L218 . But yeah we have to validate in this API as well so that we are safe even if anyother caller failed to validate.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we will create a new issue to address such validations across the repo.

}

// Iterate through VPD vector to find the keyword
if (findKeyword(l_keywordName) != 0)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Where is this defined? Can this be done soon after line 161, so that you don't need to check the keyword data size if this keyword is not a valid one

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The l_keywordData is the user given keyword's data to update on EEPROM.
The l_keywordName is the user given keyword's name which we are finding in the EEPROM at line 169.


if (l_keywordData.size() == 0)
{
logging::logMessage("Given keyword's data is of length 0");

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What are the possibilities of a keyword value being size 0?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

User by mistake sending an empty buffer to update on VPD.

{
// Resize the given array to the right size
l_keywordData.resize(l_keywordActualSize);
l_keywordData.shrink_to_fit();

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

How to ensure the shrinking will get the correct value as a result? Will this not corrupt it? Should you throw here as invalid?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

resize will erase the extra contents and resizes the vector to l_keywordActualSize. Here only the contents are erased but the vector capacity doesn't change.
So we use shrink_to_fit to remove the unused capacity. So it won't corrupt the vpd.

@branupama
Copy link

Test:
In the commit message under test section, can you specify in both primary and secondary paths keyword's value got synced.
and can specify which is primary and backup paths, mention these paths has updated value.

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

Successfully merging this pull request may close these issues.

3 participants