LGTM Reviewed-by: Jon Derrick <jonathan.derrick@xxxxxxxxx> On Wed, 2019-05-01 at 01:20 +0200, David Kozub wrote: > From: Jonas Rabenstein <jonas.rabenstein@xxxxxxxxxxxxxxxxxxxxxxx> > > Enable users to mark the shadow mbr as done without completely > deactivating the shadow mbr feature. This may be useful on reboots, > when the power to the disk is not disconnected in between and the > shadow > mbr stores the required boot files. Of course, this saves also the > (few) commands required to enable the feature if it is already > enabled > and one only wants to mark the shadow mbr as done. > > Co-authored-by: David Kozub <zub@xxxxxxxxxxxxxxxxxx> > Signed-off-by: Jonas Rabenstein < > jonas.rabenstein@xxxxxxxxxxxxxxxxxxxxxxx> > Signed-off-by: David Kozub <zub@xxxxxxxxxxxxxxxxxx> > --- > block/sed-opal.c | 27 +++++++++++++++++++++++++++ > include/linux/sed-opal.h | 1 + > include/uapi/linux/sed-opal.h | 12 ++++++++++++ > 3 files changed, 40 insertions(+) > > diff --git a/block/sed-opal.c b/block/sed-opal.c > index b1aa0cc25803..f1eb9c18e335 100644 > --- a/block/sed-opal.c > +++ b/block/sed-opal.c > @@ -1986,6 +1986,30 @@ static int > opal_enable_disable_shadow_mbr(struct opal_dev *dev, > return ret; > } > > +static int opal_set_mbr_done(struct opal_dev *dev, > + struct opal_mbr_done *mbr_done) > +{ > + u8 mbr_done_tf = mbr_done->done_flag == OPAL_MBR_DONE ? > + OPAL_TRUE : OPAL_FALSE; > + > + const struct opal_step mbr_steps[] = { > + { start_admin1LSP_opal_session, &mbr_done->key }, > + { set_mbr_done, &mbr_done_tf }, > + { end_opal_session, } > + }; > + int ret; > + > + if (mbr_done->done_flag != OPAL_MBR_DONE && > + mbr_done->done_flag != OPAL_MBR_NOT_DONE) > + return -EINVAL; > + > + mutex_lock(&dev->dev_lock); > + setup_opal_dev(dev); > + ret = execute_steps(dev, mbr_steps, ARRAY_SIZE(mbr_steps)); > + mutex_unlock(&dev->dev_lock); > + return ret; > +} > + > static int opal_save(struct opal_dev *dev, struct opal_lock_unlock > *lk_unlk) > { > struct opal_suspend_data *suspend; > @@ -2299,6 +2323,9 @@ int sed_ioctl(struct opal_dev *dev, unsigned > int cmd, void __user *arg) > case IOC_OPAL_ENABLE_DISABLE_MBR: > ret = opal_enable_disable_shadow_mbr(dev, p); > break; > + case IOC_OPAL_MBR_DONE: > + ret = opal_set_mbr_done(dev, p); > + break; > case IOC_OPAL_ERASE_LR: > ret = opal_erase_locking_range(dev, p); > break; > diff --git a/include/linux/sed-opal.h b/include/linux/sed-opal.h > index 04b124fca51e..42b2ce5da7b3 100644 > --- a/include/linux/sed-opal.h > +++ b/include/linux/sed-opal.h > @@ -47,6 +47,7 @@ static inline bool is_sed_ioctl(unsigned int cmd) > case IOC_OPAL_ENABLE_DISABLE_MBR: > case IOC_OPAL_ERASE_LR: > case IOC_OPAL_SECURE_ERASE_LR: > + case IOC_OPAL_MBR_DONE: > return true; > } > return false; > diff --git a/include/uapi/linux/sed-opal.h b/include/uapi/linux/sed- > opal.h > index e092e124dd16..81dd0e8886a1 100644 > --- a/include/uapi/linux/sed-opal.h > +++ b/include/uapi/linux/sed-opal.h > @@ -29,6 +29,11 @@ enum opal_mbr { > OPAL_MBR_DISABLE = 0x01, > }; > > +enum opal_mbr_done_flag { > + OPAL_MBR_NOT_DONE = 0x0, > + OPAL_MBR_DONE = 0x01 > +}; > + > enum opal_user { > OPAL_ADMIN1 = 0x0, > OPAL_USER1 = 0x01, > @@ -104,6 +109,12 @@ struct opal_mbr_data { > __u8 __align[7]; > }; > > +struct opal_mbr_done { > + struct opal_key key; > + __u8 done_flag; > + __u8 __align[7]; > +}; > + > #define IOC_OPAL_SAVE _IOW('p', 220, struct > opal_lock_unlock) > #define IOC_OPAL_LOCK_UNLOCK _IOW('p', 221, struct > opal_lock_unlock) > #define IOC_OPAL_TAKE_OWNERSHIP _IOW('p', 222, struct > opal_key) > @@ -116,5 +127,6 @@ struct opal_mbr_data { > #define IOC_OPAL_ENABLE_DISABLE_MBR _IOW('p', 229, struct > opal_mbr_data) > #define IOC_OPAL_ERASE_LR _IOW('p', 230, struct > opal_session_info) > #define IOC_OPAL_SECURE_ERASE_LR _IOW('p', 231, struct > opal_session_info) > +#define IOC_OPAL_MBR_DONE _IOW('p', 232, struct > opal_mbr_done) > > #endif /* _UAPI_SED_OPAL_H */
Attachment:
smime.p7s
Description: S/MIME cryptographic signature