drm/nouveau/gr/gk20a: move firmware bundle release to gf100
authorAlexandre Courbot <acourbot@nvidia.com>
Wed, 24 Feb 2016 05:42:15 +0000 (14:42 +0900)
committerBen Skeggs <bskeggs@redhat.com>
Mon, 14 Mar 2016 00:13:19 +0000 (10:13 +1000)
Some members of gf100_gr were freed by the gk20a driver. That's not
where it should be done - free them in gf100 so other chips that use
NVIDIA-provided firmware free these structures properly.

This also removes the need for a GK20A-specific destructor.

Signed-off-by: Alexandre Courbot <acourbot@nvidia.com>
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
drivers/gpu/drm/nouveau/nvkm/engine/gr/gf100.c
drivers/gpu/drm/nouveau/nvkm/engine/gr/gf100.h
drivers/gpu/drm/nouveau/nvkm/engine/gr/gk20a.c
drivers/gpu/drm/nouveau/nvkm/engine/gr/gm20b.c

index f2410aff07cf3d3476f4ef6dad8344511172287b..7a8a0c7139e5e2f0ff28515df2bfc31561b5d872 100644 (file)
@@ -1684,6 +1684,12 @@ gf100_gr_dtor_fw(struct gf100_gr_fuc *fuc)
        fuc->data = NULL;
 }
 
+static void
+gf100_gr_dtor_init(struct gf100_gr_pack *pack)
+{
+       vfree(pack);
+}
+
 void *
 gf100_gr_dtor(struct nvkm_gr *base)
 {
@@ -1698,6 +1704,11 @@ gf100_gr_dtor(struct nvkm_gr *base)
        gf100_gr_dtor_fw(&gr->fuc41ac);
        gf100_gr_dtor_fw(&gr->fuc41ad);
 
+       gf100_gr_dtor_init(gr->fuc_bundle);
+       gf100_gr_dtor_init(gr->fuc_method);
+       gf100_gr_dtor_init(gr->fuc_sw_ctx);
+       gf100_gr_dtor_init(gr->fuc_sw_nonctx);
+
        nvkm_memory_del(&gr->unk4188b8);
        nvkm_memory_del(&gr->unk4188b4);
        return gr;
index 8dca40dde06be2efe5e1fae1088ad86097d54f28..cff4b40d887ed31430a1258732d56fd0ce93e1aa 100644 (file)
@@ -82,7 +82,7 @@ struct gf100_gr {
 
        /*
         * Used if the register packs are loaded from NVIDIA fw instead of
-        * using hardcoded arrays.
+        * using hardcoded arrays. To be allocated with vzalloc().
         */
        struct gf100_gr_pack *fuc_sw_nonctx;
        struct gf100_gr_pack *fuc_sw_ctx;
@@ -140,7 +140,6 @@ int gk104_gr_init(struct gf100_gr *);
 
 int gk20a_gr_new_(const struct gf100_gr_func *, struct nvkm_device *,
                  int, struct nvkm_gr **);
-void gk20a_gr_dtor(struct gf100_gr *);
 int gk20a_gr_init(struct gf100_gr *);
 
 int gm200_gr_init(struct gf100_gr *);
index b8758d3b8b51b0d4f45c3c5d5bc5451c2d0dcaa4..a321dd0199325d5b4b5632c5c5574e74f82b78aa 100644 (file)
 
 #include <nvif/class.h>
 
-static void
-gk20a_gr_init_dtor(struct gf100_gr_pack *pack)
-{
-       vfree(pack);
-}
-
 struct gk20a_fw_av
 {
        u32 addr;
@@ -273,15 +267,6 @@ gk20a_gr_init(struct gf100_gr *gr)
        return gf100_gr_init_ctxctl(gr);
 }
 
-void
-gk20a_gr_dtor(struct gf100_gr *gr)
-{
-       gk20a_gr_init_dtor(gr->fuc_method);
-       gk20a_gr_init_dtor(gr->fuc_bundle);
-       gk20a_gr_init_dtor(gr->fuc_sw_ctx);
-       gk20a_gr_init_dtor(gr->fuc_sw_nonctx);
-}
-
 int
 gk20a_gr_new_(const struct gf100_gr_func *func, struct nvkm_device *device,
              int index, struct nvkm_gr **pgr)
@@ -335,7 +320,6 @@ gk20a_gr_new_(const struct gf100_gr_func *func, struct nvkm_device *device,
 
 static const struct gf100_gr_func
 gk20a_gr = {
-       .dtor = gk20a_gr_dtor,
        .init = gk20a_gr_init,
        .set_hww_esr_report_mask = gk20a_gr_set_hww_esr_report_mask,
        .ppc_nr = 1,
index 65b6e3d1e90dca9e6ba8f16ef3c6bbbce1db9c31..443922e46ff945b1bb2ed8d2e5d0b80bcd005776 100644 (file)
@@ -61,7 +61,6 @@ gm20b_gr_set_hww_esr_report_mask(struct gf100_gr *gr)
 
 static const struct gf100_gr_func
 gm20b_gr = {
-       .dtor = gk20a_gr_dtor,
        .init = gk20a_gr_init,
        .init_gpc_mmu = gm20b_gr_init_gpc_mmu,
        .set_hww_esr_report_mask = gm20b_gr_set_hww_esr_report_mask,