This patch adds validation for the labeloff field in the indexes.

Signed-off-by: Alexander Duyck <[email protected]>
---
 drivers/nvdimm/label.c |    7 +++++++
 1 file changed, 7 insertions(+)

diff --git a/drivers/nvdimm/label.c b/drivers/nvdimm/label.c
index 1d28cd656536..1f5842509dbc 100644
--- a/drivers/nvdimm/label.c
+++ b/drivers/nvdimm/label.c
@@ -183,6 +183,13 @@ static int __nd_label_validate(struct nvdimm_drvdata *ndd)
                                        __le64_to_cpu(nsindex[i]->otheroff));
                        continue;
                }
+               if (__le64_to_cpu(nsindex[i]->labeloff)
+                               != 2 * sizeof_namespace_index(ndd)) {
+                       dev_dbg(dev, "nsindex%d labeloff: %#llx invalid\n",
+                                       i, (unsigned long long)
+                                       __le64_to_cpu(nsindex[i]->labeloff));
+                       continue;
+               }
 
                size = __le64_to_cpu(nsindex[i]->mysize);
                if (size > sizeof_namespace_index(ndd)

_______________________________________________
Linux-nvdimm mailing list
[email protected]
https://lists.01.org/mailman/listinfo/linux-nvdimm

Reply via email to