]> www.infradead.org Git - users/jedix/linux-maple.git/commitdiff
x86/sev: Take advantage of configfs visibility support in TSM
authorTom Lendacky <thomas.lendacky@amd.com>
Wed, 5 Jun 2024 15:18:54 +0000 (10:18 -0500)
committerBorislav Petkov (AMD) <bp@alien8.de>
Mon, 17 Jun 2024 18:42:57 +0000 (20:42 +0200)
The TSM attestation report support provides multiple configfs attribute
types (both for standard and binary attributes) to allow for additional
attributes to be displayed for SNP as compared to TDX. With the ability
to hide attributes via configfs, consolidate the multiple attribute groups
into a single standard attribute group and a single binary attribute
group. Modify the TDX support to hide the attributes that were previously
"hidden" as a result of registering the selective attribute groups.

Co-developed-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
Reviewed-by: Kuppuswamy Sathyanarayanan <sathyanarayanan.kuppuswamy@linux.intel.com>
Link: https://lore.kernel.org/r/8873c45d0c8abc35aaf01d7833a55788a6905727.1717600736.git.thomas.lendacky@amd.com
drivers/virt/coco/sev-guest/sev-guest.c
drivers/virt/coco/tdx-guest/tdx-guest.c
drivers/virt/coco/tsm.c
include/linux/tsm.h

index 3560b3a8bb4db915990b15f584ce79606a008021..0c70a38c8cc0c68742ccb1348488e62be95e8eb6 100644 (file)
@@ -23,6 +23,7 @@
 #include <linux/sockptr.h>
 #include <linux/cleanup.h>
 #include <linux/uuid.h>
+#include <linux/configfs.h>
 #include <uapi/linux/sev-guest.h>
 #include <uapi/linux/psp-sev.h>
 
@@ -982,7 +983,7 @@ static int __init sev_guest_probe(struct platform_device *pdev)
        /* Set the privlevel_floor attribute based on the vmpck_id */
        sev_tsm_ops.privlevel_floor = vmpck_id;
 
-       ret = tsm_register(&sev_tsm_ops, snp_dev, &tsm_report_extra_type);
+       ret = tsm_register(&sev_tsm_ops, snp_dev);
        if (ret)
                goto e_free_cert_data;
 
index 1253bf76b57031884420a35d808483a9cd7267be..2acba56ad42eb32e91968dfb696b5b38c42497b7 100644 (file)
@@ -249,6 +249,28 @@ done:
        return ret;
 }
 
+static bool tdx_report_attr_visible(int n)
+{
+       switch (n) {
+       case TSM_REPORT_GENERATION:
+       case TSM_REPORT_PROVIDER:
+               return true;
+       }
+
+       return false;
+}
+
+static bool tdx_report_bin_attr_visible(int n)
+{
+       switch (n) {
+       case TSM_REPORT_INBLOB:
+       case TSM_REPORT_OUTBLOB:
+               return true;
+       }
+
+       return false;
+}
+
 static long tdx_guest_ioctl(struct file *file, unsigned int cmd,
                            unsigned long arg)
 {
@@ -281,6 +303,8 @@ MODULE_DEVICE_TABLE(x86cpu, tdx_guest_ids);
 static const struct tsm_ops tdx_tsm_ops = {
        .name = KBUILD_MODNAME,
        .report_new = tdx_report_new,
+       .report_attr_visible = tdx_report_attr_visible,
+       .report_bin_attr_visible = tdx_report_bin_attr_visible,
 };
 
 static int __init tdx_guest_init(void)
@@ -301,7 +325,7 @@ static int __init tdx_guest_init(void)
                goto free_misc;
        }
 
-       ret = tsm_register(&tdx_tsm_ops, NULL, NULL);
+       ret = tsm_register(&tdx_tsm_ops, NULL);
        if (ret)
                goto free_quote;
 
index d1c2db83a8ca9be1bb6bea6d2f287abfb8ba4313..7db534b63c9f32a85635b6fa5f4f876d639d2ec3 100644 (file)
@@ -14,7 +14,6 @@
 
 static struct tsm_provider {
        const struct tsm_ops *ops;
-       const struct config_item_type *type;
        void *data;
 } provider;
 static DECLARE_RWSEM(tsm_rwsem);
@@ -252,34 +251,18 @@ static ssize_t tsm_report_auxblob_read(struct config_item *cfg, void *buf,
 }
 CONFIGFS_BIN_ATTR_RO(tsm_report_, auxblob, NULL, TSM_OUTBLOB_MAX);
 
-#define TSM_DEFAULT_ATTRS() \
-       &tsm_report_attr_generation, \
-       &tsm_report_attr_provider
-
 static struct configfs_attribute *tsm_report_attrs[] = {
-       TSM_DEFAULT_ATTRS(),
-       NULL,
-};
-
-static struct configfs_attribute *tsm_report_extra_attrs[] = {
-       TSM_DEFAULT_ATTRS(),
-       &tsm_report_attr_privlevel,
-       &tsm_report_attr_privlevel_floor,
+       [TSM_REPORT_GENERATION] = &tsm_report_attr_generation,
+       [TSM_REPORT_PROVIDER] = &tsm_report_attr_provider,
+       [TSM_REPORT_PRIVLEVEL] = &tsm_report_attr_privlevel,
+       [TSM_REPORT_PRIVLEVEL_FLOOR] = &tsm_report_attr_privlevel_floor,
        NULL,
 };
 
-#define TSM_DEFAULT_BIN_ATTRS() \
-       &tsm_report_attr_inblob, \
-       &tsm_report_attr_outblob
-
 static struct configfs_bin_attribute *tsm_report_bin_attrs[] = {
-       TSM_DEFAULT_BIN_ATTRS(),
-       NULL,
-};
-
-static struct configfs_bin_attribute *tsm_report_bin_extra_attrs[] = {
-       TSM_DEFAULT_BIN_ATTRS(),
-       &tsm_report_attr_auxblob,
+       [TSM_REPORT_INBLOB] = &tsm_report_attr_inblob,
+       [TSM_REPORT_OUTBLOB] = &tsm_report_attr_outblob,
+       [TSM_REPORT_AUXBLOB] = &tsm_report_attr_auxblob,
        NULL,
 };
 
@@ -297,21 +280,44 @@ static struct configfs_item_operations tsm_report_item_ops = {
        .release = tsm_report_item_release,
 };
 
-const struct config_item_type tsm_report_default_type = {
-       .ct_owner = THIS_MODULE,
-       .ct_bin_attrs = tsm_report_bin_attrs,
-       .ct_attrs = tsm_report_attrs,
-       .ct_item_ops = &tsm_report_item_ops,
+static bool tsm_report_is_visible(struct config_item *item,
+                                 struct configfs_attribute *attr, int n)
+{
+       guard(rwsem_read)(&tsm_rwsem);
+       if (!provider.ops)
+               return false;
+
+       if (!provider.ops->report_attr_visible)
+               return true;
+
+       return provider.ops->report_attr_visible(n);
+}
+
+static bool tsm_report_is_bin_visible(struct config_item *item,
+                                     struct configfs_bin_attribute *attr, int n)
+{
+       guard(rwsem_read)(&tsm_rwsem);
+       if (!provider.ops)
+               return false;
+
+       if (!provider.ops->report_bin_attr_visible)
+               return true;
+
+       return provider.ops->report_bin_attr_visible(n);
+}
+
+static struct configfs_group_operations tsm_report_attr_group_ops = {
+       .is_visible = tsm_report_is_visible,
+       .is_bin_visible = tsm_report_is_bin_visible,
 };
-EXPORT_SYMBOL_GPL(tsm_report_default_type);
 
-const struct config_item_type tsm_report_extra_type = {
+static const struct config_item_type tsm_report_type = {
        .ct_owner = THIS_MODULE,
-       .ct_bin_attrs = tsm_report_bin_extra_attrs,
-       .ct_attrs = tsm_report_extra_attrs,
+       .ct_bin_attrs = tsm_report_bin_attrs,
+       .ct_attrs = tsm_report_attrs,
        .ct_item_ops = &tsm_report_item_ops,
+       .ct_group_ops = &tsm_report_attr_group_ops,
 };
-EXPORT_SYMBOL_GPL(tsm_report_extra_type);
 
 static struct config_item *tsm_report_make_item(struct config_group *group,
                                                const char *name)
@@ -326,7 +332,7 @@ static struct config_item *tsm_report_make_item(struct config_group *group,
        if (!state)
                return ERR_PTR(-ENOMEM);
 
-       config_item_init_type_name(&state->cfg, name, provider.type);
+       config_item_init_type_name(&state->cfg, name, &tsm_report_type);
        return &state->cfg;
 }
 
@@ -353,16 +359,10 @@ static struct configfs_subsystem tsm_configfs = {
        .su_mutex = __MUTEX_INITIALIZER(tsm_configfs.su_mutex),
 };
 
-int tsm_register(const struct tsm_ops *ops, void *priv,
-                const struct config_item_type *type)
+int tsm_register(const struct tsm_ops *ops, void *priv)
 {
        const struct tsm_ops *conflict;
 
-       if (!type)
-               type = &tsm_report_default_type;
-       if (!(type == &tsm_report_default_type || type == &tsm_report_extra_type))
-               return -EINVAL;
-
        guard(rwsem_write)(&tsm_rwsem);
        conflict = provider.ops;
        if (conflict) {
@@ -372,7 +372,6 @@ int tsm_register(const struct tsm_ops *ops, void *priv,
 
        provider.ops = ops;
        provider.data = priv;
-       provider.type = type;
        return 0;
 }
 EXPORT_SYMBOL_GPL(tsm_register);
@@ -384,7 +383,6 @@ int tsm_unregister(const struct tsm_ops *ops)
                return -EBUSY;
        provider.ops = NULL;
        provider.data = NULL;
-       provider.type = NULL;
        return 0;
 }
 EXPORT_SYMBOL_GPL(tsm_unregister);
index 50c5769657d824a990153dc2fbd15b5781818d89..30d9d270b44636abbda57b8b12be58905653b64a 100644 (file)
@@ -42,12 +42,40 @@ struct tsm_report {
        u8 *auxblob;
 };
 
+/**
+ * enum tsm_attr_index - index used to reference report attributes
+ * @TSM_REPORT_GENERATION: index of the report generation number attribute
+ * @TSM_REPORT_PROVIDER: index of the provider name attribute
+ * @TSM_REPORT_PRIVLEVEL: index of the desired privilege level attribute
+ * @TSM_REPORT_PRIVLEVEL_FLOOR: index of the minimum allowed privileg level attribute
+ */
+enum tsm_attr_index {
+       TSM_REPORT_GENERATION,
+       TSM_REPORT_PROVIDER,
+       TSM_REPORT_PRIVLEVEL,
+       TSM_REPORT_PRIVLEVEL_FLOOR,
+};
+
+/**
+ * enum tsm_bin_attr_index - index used to reference binary report attributes
+ * @TSM_REPORT_INBLOB: index of the binary report input attribute
+ * @TSM_REPORT_OUTBLOB: index of the binary report output attribute
+ * @TSM_REPORT_AUXBLOB: index of the binary auxiliary data attribute
+ */
+enum tsm_bin_attr_index {
+       TSM_REPORT_INBLOB,
+       TSM_REPORT_OUTBLOB,
+       TSM_REPORT_AUXBLOB,
+};
+
 /**
  * struct tsm_ops - attributes and operations for tsm instances
  * @name: tsm id reflected in /sys/kernel/config/tsm/report/$report/provider
  * @privlevel_floor: convey base privlevel for nested scenarios
  * @report_new: Populate @report with the report blob and auxblob
  * (optional), return 0 on successful population, or -errno otherwise
+ * @report_attr_visible: show or hide a report attribute entry
+ * @report_bin_attr_visible: show or hide a report binary attribute entry
  *
  * Implementation specific ops, only one is expected to be registered at
  * a time i.e. only one of "sev-guest", "tdx-guest", etc.
@@ -56,14 +84,10 @@ struct tsm_ops {
        const char *name;
        unsigned int privlevel_floor;
        int (*report_new)(struct tsm_report *report, void *data);
+       bool (*report_attr_visible)(int n);
+       bool (*report_bin_attr_visible)(int n);
 };
 
-extern const struct config_item_type tsm_report_default_type;
-
-/* publish @privlevel, @privlevel_floor, and @auxblob attributes */
-extern const struct config_item_type tsm_report_extra_type;
-
-int tsm_register(const struct tsm_ops *ops, void *priv,
-                const struct config_item_type *type);
+int tsm_register(const struct tsm_ops *ops, void *priv);
 int tsm_unregister(const struct tsm_ops *ops);
 #endif /* __TSM_H */