drm/nouveau/secboot: split reset function
authorAlexandre Courbot <acourbot@nvidia.com>
Wed, 14 Dec 2016 08:02:41 +0000 (17:02 +0900)
committerBen Skeggs <bskeggs@redhat.com>
Fri, 17 Feb 2017 05:14:31 +0000 (15:14 +1000)
Split the reset function into more meaningful and reusable ones.

Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/include/nvkm/subdev/secboot.h
drivers/gpu/drm/nouveau/nvkm/subdev/secboot/acr_r352.c

index 6e9e0450220c5c21c82f0ee839d3b3567fc96d47..5dbd8aa4f8c21856ecf2d61afcc70d4d35e92985 100644 (file)
@@ -34,6 +34,9 @@ enum nvkm_secboot_falcon {
        NVKM_SECBOOT_FALCON_INVALID = 0xffffffff,
 };
 
+/**
+ * @wpr_set: whether the WPR region is currently set
+*/
 struct nvkm_secboot {
        const struct nvkm_secboot_func *func;
        struct nvkm_acr *acr;
@@ -42,6 +45,8 @@ struct nvkm_secboot {
 
        u64 wpr_addr;
        u32 wpr_size;
+
+       bool wpr_set;
 };
 #define nvkm_secboot(p) container_of((p), struct nvkm_secboot, subdev)
 
index 0d44575ea272054c82d1862cbc5aea164b8e8a4d..ea2ecd6205008298ffc0de5a204690ee4a6ba2c5 100644 (file)
@@ -740,6 +740,54 @@ acr_r352_load(struct nvkm_acr *_acr, struct nvkm_secboot *sb,
        return 0;
 }
 
+static int
+acr_r352_shutdown(struct acr_r352 *acr, struct nvkm_secboot *sb)
+{
+       int i;
+
+       /* Run the unload blob to unprotect the WPR region */
+       if (acr->unload_blob && sb->wpr_set) {
+               int ret;
+
+               nvkm_debug(&sb->subdev, "running HS unload blob\n");
+               ret = sb->func->run_blob(sb, acr->unload_blob);
+               if (ret)
+                       return ret;
+               nvkm_debug(&sb->subdev, "HS unload blob completed\n");
+       }
+
+       for (i = 0; i < NVKM_SECBOOT_FALCON_END; i++)
+               acr->falcon_state[i] = NON_SECURE;
+
+       sb->wpr_set = false;
+
+       return 0;
+}
+
+static int
+acr_r352_bootstrap(struct acr_r352 *acr, struct nvkm_secboot *sb)
+{
+       int ret;
+
+       if (sb->wpr_set)
+               return 0;
+
+       /* Make sure all blobs are ready */
+       ret = acr_r352_load_blobs(acr, sb);
+       if (ret)
+               return ret;
+
+       nvkm_debug(&sb->subdev, "running HS load blob\n");
+       ret = sb->func->run_blob(sb, acr->load_blob);
+       if (ret)
+               return ret;
+       nvkm_debug(&sb->subdev, "HS load blob completed\n");
+
+       sb->wpr_set = true;
+
+       return 0;
+}
+
 /*
  * acr_r352_reset() - execute secure boot from the prepared state
  *
@@ -754,11 +802,6 @@ acr_r352_reset(struct nvkm_acr *_acr, struct nvkm_secboot *sb,
        struct acr_r352 *acr = acr_r352(_acr);
        int ret;
 
-       /* Make sure all blobs are ready */
-       ret = acr_r352_load_blobs(acr, sb);
-       if (ret)
-               return ret;
-
        /*
         * Dummy GM200 implementation: perform secure boot each time we are
         * called on FECS. Since only FECS and GPCCS are managed and started
@@ -770,16 +813,11 @@ acr_r352_reset(struct nvkm_acr *_acr, struct nvkm_secboot *sb,
        if (falcon != NVKM_SECBOOT_FALCON_FECS)
                goto end;
 
-       /* If WPR is set and we have an unload blob, run it to unlock WPR */
-       if (acr->unload_blob &&
-           acr->falcon_state[NVKM_SECBOOT_FALCON_FECS] != NON_SECURE) {
-               ret = sb->func->run_blob(sb, acr->unload_blob);
-               if (ret)
-                       return ret;
-       }
+       ret = acr_r352_shutdown(acr, sb);
+       if (ret)
+               return ret;
 
-       /* Reload all managed falcons */
-       ret = sb->func->run_blob(sb, acr->load_blob);
+       acr_r352_bootstrap(acr, sb);
        if (ret)
                return ret;
 
@@ -818,18 +856,8 @@ static int
 acr_r352_fini(struct nvkm_acr *_acr, struct nvkm_secboot *sb, bool suspend)
 {
        struct acr_r352 *acr = acr_r352(_acr);
-       int ret = 0;
-       int i;
 
-       /* Run the unload blob to unprotect the WPR region */
-       if (acr->unload_blob &&
-           acr->falcon_state[NVKM_SECBOOT_FALCON_FECS] != NON_SECURE)
-               ret = sb->func->run_blob(sb, acr->unload_blob);
-
-       for (i = 0; i < NVKM_SECBOOT_FALCON_END; i++)
-               acr->falcon_state[i] = NON_SECURE;
-
-       return ret;
+       return acr_r352_shutdown(acr, sb);
 }
 
 static void