> On 1 Mar 2018, at 11.33, Matias Bjørling <mb@xxxxxxxxxxx> wrote: > > On 02/28/2018 04:49 PM, Javier González wrote: >> Assign missing mccap value on 2.0 path >> Signed-off-by: Javier González <javier@xxxxxxxxxxxx> >> --- >> drivers/nvme/host/lightnvm.c | 4 +++- >> include/linux/lightnvm.h | 8 +++++--- >> 2 files changed, 8 insertions(+), 4 deletions(-) >> diff --git a/drivers/nvme/host/lightnvm.c b/drivers/nvme/host/lightnvm.c >> index e276ace28c64..5b2024ebac76 100644 >> --- a/drivers/nvme/host/lightnvm.c >> +++ b/drivers/nvme/host/lightnvm.c >> @@ -318,7 +318,7 @@ static int nvme_nvm_setup_12(struct nvme_nvm_id12 *id, >> geo->ws_opt = sec_per_pg; >> geo->mw_cunits = geo->ws_opt << 3; /* default to MLC safe values */ >> - geo->mccap = le32_to_cpu(src->mccap); >> + geo->cap = le32_to_cpu(src->mccap); >> geo->trdt = le32_to_cpu(src->trdt); >> geo->trdm = le32_to_cpu(src->trdm); >> @@ -396,6 +396,8 @@ static int nvme_nvm_setup_20(struct nvme_nvm_id20 *id, >> geo->ws_opt = le32_to_cpu(id->ws_opt); >> geo->mw_cunits = le32_to_cpu(id->mw_cunits); >> + geo->cap = le32_to_cpu(id->mccap); >> + >> geo->trdt = le32_to_cpu(id->trdt); >> geo->trdm = le32_to_cpu(id->trdm); >> geo->tprt = le32_to_cpu(id->twrt); >> diff --git a/include/linux/lightnvm.h b/include/linux/lightnvm.h >> index 16255fcd5250..b9f0d2070de9 100644 >> --- a/include/linux/lightnvm.h >> +++ b/include/linux/lightnvm.h >> @@ -288,8 +288,10 @@ struct nvm_geo { >> u32 ws_opt; /* optimal write size */ >> u32 mw_cunits; /* distance required for successful read */ >> - /* device capabilities */ >> - u32 mccap; >> + /* device capabilities. Note that this represents capabilities in 1.2 >> + * and media and controller capabilities in 2.0 >> + */ >> + u32 cap; > > Here is a list of capabilities: > > 1.2 > Bad block mgmt > Hybrid command support > > 2.0 > > Vector copy > Double reset > > The way I was thinking it would be implemented is to split the upper cap bits to 2.0, and let the lower bits be reserved for 1.2. > > Such that one would define the following: > > enum { > NVM_CAP_BBM 1 << 0; > NVM_CAP_HCS 1 << 1; > > NVM_CAP_VCPY 1 << 16; > NVM_CAP_DRST 1 << 17; > }; > > That way, the assignment from 2.0 can easily be done with cap = le32_to_cpu(id->mccap) << 16; > > and targets and other don't need to understand the difference between 1.2 and 2.0 format. I can see that you already have a way to do it in mind. I'll remove this patch and you can implement it later on. Javier
Attachment:
signature.asc
Description: Message signed with OpenPGP