提交 edd757d1 编写于 作者: B Ben Skeggs

drm/nouveau/sec2: initialise SW state for falcon from constructor

This will allow us to register the falcon with ACR, and further customise
its behaviour by providing the nvkm_falcon_func structure directly.
Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
上级 7adc40c5
...@@ -3,13 +3,14 @@ ...@@ -3,13 +3,14 @@
#define __NVKM_SEC2_H__ #define __NVKM_SEC2_H__
#define nvkm_sec2(p) container_of((p), struct nvkm_sec2, engine) #define nvkm_sec2(p) container_of((p), struct nvkm_sec2, engine)
#include <core/engine.h> #include <core/engine.h>
#include <core/falcon.h>
struct nvkm_sec2 { struct nvkm_sec2 {
const struct nvkm_sec2_func *func; const struct nvkm_sec2_func *func;
struct nvkm_engine engine; struct nvkm_engine engine;
struct nvkm_falcon falcon;
u32 addr; u32 addr;
struct nvkm_falcon *falcon;
struct nvkm_msgqueue *queue; struct nvkm_msgqueue *queue;
struct work_struct work; struct work_struct work;
}; };
......
...@@ -24,7 +24,6 @@ ...@@ -24,7 +24,6 @@
#include <core/firmware.h> #include <core/firmware.h>
#include <core/msgqueue.h> #include <core/msgqueue.h>
#include <subdev/top.h> #include <subdev/top.h>
#include <engine/falcon.h>
static void static void
nvkm_sec2_intr(struct nvkm_engine *engine) nvkm_sec2_intr(struct nvkm_engine *engine)
...@@ -62,22 +61,6 @@ nvkm_sec2_recv(struct work_struct *work) ...@@ -62,22 +61,6 @@ nvkm_sec2_recv(struct work_struct *work)
nvkm_msgqueue_recv(sec2->queue); nvkm_msgqueue_recv(sec2->queue);
} }
static int
nvkm_sec2_oneinit(struct nvkm_engine *engine)
{
struct nvkm_sec2 *sec2 = nvkm_sec2(engine);
struct nvkm_subdev *subdev = &sec2->engine.subdev;
if (!sec2->addr) {
sec2->addr = nvkm_top_addr(subdev->device, subdev->index);
if (WARN_ON(!sec2->addr))
return -EINVAL;
}
return nvkm_falcon_v1_new(subdev, "SEC2", sec2->addr, &sec2->falcon);
}
static int static int
nvkm_sec2_fini(struct nvkm_engine *engine, bool suspend) nvkm_sec2_fini(struct nvkm_engine *engine, bool suspend)
{ {
...@@ -91,14 +74,13 @@ nvkm_sec2_dtor(struct nvkm_engine *engine) ...@@ -91,14 +74,13 @@ nvkm_sec2_dtor(struct nvkm_engine *engine)
{ {
struct nvkm_sec2 *sec2 = nvkm_sec2(engine); struct nvkm_sec2 *sec2 = nvkm_sec2(engine);
nvkm_msgqueue_del(&sec2->queue); nvkm_msgqueue_del(&sec2->queue);
nvkm_falcon_del(&sec2->falcon); nvkm_falcon_dtor(&sec2->falcon);
return sec2; return sec2;
} }
static const struct nvkm_engine_func static const struct nvkm_engine_func
nvkm_sec2 = { nvkm_sec2 = {
.dtor = nvkm_sec2_dtor, .dtor = nvkm_sec2_dtor,
.oneinit = nvkm_sec2_oneinit,
.fini = nvkm_sec2_fini, .fini = nvkm_sec2_fini,
.intr = nvkm_sec2_intr, .intr = nvkm_sec2_intr,
}; };
...@@ -124,6 +106,11 @@ nvkm_sec2_new_(const struct nvkm_sec2_fwif *fwif, struct nvkm_device *device, ...@@ -124,6 +106,11 @@ nvkm_sec2_new_(const struct nvkm_sec2_fwif *fwif, struct nvkm_device *device,
sec2->func = fwif->func; sec2->func = fwif->func;
ret = nvkm_falcon_ctor(sec2->func->flcn, &sec2->engine.subdev,
nvkm_subdev_name[index], addr, &sec2->falcon);
if (ret)
return ret;
INIT_WORK(&sec2->work, nvkm_sec2_recv); INIT_WORK(&sec2->work, nvkm_sec2_recv);
return 0; return 0;
}; };
...@@ -26,8 +26,24 @@ static const struct nvkm_acr_lsf_func ...@@ -26,8 +26,24 @@ static const struct nvkm_acr_lsf_func
gp102_sec2_acr_0 = { gp102_sec2_acr_0 = {
}; };
static const struct nvkm_falcon_func
gp102_sec2_flcn = {
.load_imem = nvkm_falcon_v1_load_imem,
.load_dmem = nvkm_falcon_v1_load_dmem,
.read_dmem = nvkm_falcon_v1_read_dmem,
.bind_context = nvkm_falcon_v1_bind_context,
.wait_for_halt = nvkm_falcon_v1_wait_for_halt,
.clear_interrupt = nvkm_falcon_v1_clear_interrupt,
.set_start_addr = nvkm_falcon_v1_set_start_addr,
.start = nvkm_falcon_v1_start,
.enable = nvkm_falcon_v1_enable,
.disable = nvkm_falcon_v1_disable,
};
const struct nvkm_sec2_func const struct nvkm_sec2_func
gp102_sec2 = { gp102_sec2 = {
.flcn = &gp102_sec2_flcn,
}; };
MODULE_FIRMWARE("nvidia/gp102/sec2/desc.bin"); MODULE_FIRMWARE("nvidia/gp102/sec2/desc.bin");
...@@ -52,7 +68,7 @@ gp102_sec2_load(struct nvkm_sec2 *sec2, int ver, ...@@ -52,7 +68,7 @@ gp102_sec2_load(struct nvkm_sec2 *sec2, int ver,
const struct nvkm_sec2_fwif *fwif) const struct nvkm_sec2_fwif *fwif)
{ {
return nvkm_acr_lsfw_load_sig_image_desc_v1(&sec2->engine.subdev, return nvkm_acr_lsfw_load_sig_image_desc_v1(&sec2->engine.subdev,
sec2->falcon, &sec2->falcon,
NVKM_ACR_LSF_SEC2, "sec2/", NVKM_ACR_LSF_SEC2, "sec2/",
ver, fwif->acr); ver, fwif->acr);
} }
......
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
#include <engine/sec2.h> #include <engine/sec2.h>
struct nvkm_sec2_func { struct nvkm_sec2_func {
const struct nvkm_falcon_func *flcn;
}; };
struct nvkm_sec2_fwif { struct nvkm_sec2_fwif {
......
...@@ -21,8 +21,23 @@ ...@@ -21,8 +21,23 @@
*/ */
#include "priv.h" #include "priv.h"
static const struct nvkm_falcon_func
tu102_sec2_flcn = {
.load_imem = nvkm_falcon_v1_load_imem,
.load_dmem = nvkm_falcon_v1_load_dmem,
.read_dmem = nvkm_falcon_v1_read_dmem,
.bind_context = nvkm_falcon_v1_bind_context,
.wait_for_halt = nvkm_falcon_v1_wait_for_halt,
.clear_interrupt = nvkm_falcon_v1_clear_interrupt,
.set_start_addr = nvkm_falcon_v1_set_start_addr,
.start = nvkm_falcon_v1_start,
.enable = nvkm_falcon_v1_enable,
.disable = nvkm_falcon_v1_disable,
};
static const struct nvkm_sec2_func static const struct nvkm_sec2_func
tu102_sec2 = { tu102_sec2 = {
.flcn = &tu102_sec2_flcn,
}; };
static int static int
......
...@@ -172,7 +172,7 @@ acr_r361_generate_sec2_bl_desc(const struct nvkm_acr *acr, ...@@ -172,7 +172,7 @@ acr_r361_generate_sec2_bl_desc(const struct nvkm_acr *acr,
/* For some reason we should not add app_resident_code_offset here */ /* For some reason we should not add app_resident_code_offset here */
addr_code = base; addr_code = base;
addr_data = base + pdesc->app_resident_data_offset; addr_data = base + pdesc->app_resident_data_offset;
addr_args = sec->falcon->data.limit; addr_args = sec->falcon.data.limit;
addr_args -= NVKM_MSGQUEUE_CMDLINE_SIZE; addr_args -= NVKM_MSGQUEUE_CMDLINE_SIZE;
desc->dma_idx = FALCON_SEC2_DMAIDX_UCODE; desc->dma_idx = FALCON_SEC2_DMAIDX_UCODE;
......
...@@ -96,7 +96,7 @@ acr_r370_generate_sec2_bl_desc(const struct nvkm_acr *acr, ...@@ -96,7 +96,7 @@ acr_r370_generate_sec2_bl_desc(const struct nvkm_acr *acr,
/* For some reason we should not add app_resident_code_offset here */ /* For some reason we should not add app_resident_code_offset here */
addr_code = base; addr_code = base;
addr_data = base + pdesc->app_resident_data_offset; addr_data = base + pdesc->app_resident_data_offset;
addr_args = sec->falcon->data.limit; addr_args = sec->falcon.data.limit;
addr_args -= NVKM_MSGQUEUE_CMDLINE_SIZE; addr_args -= NVKM_MSGQUEUE_CMDLINE_SIZE;
desc->ctx_dma = FALCON_SEC2_DMAIDX_UCODE; desc->ctx_dma = FALCON_SEC2_DMAIDX_UCODE;
......
...@@ -138,7 +138,7 @@ nvkm_secboot_oneinit(struct nvkm_subdev *subdev) ...@@ -138,7 +138,7 @@ nvkm_secboot_oneinit(struct nvkm_subdev *subdev)
case NVKM_SECBOOT_FALCON_SEC2: case NVKM_SECBOOT_FALCON_SEC2:
/* we must keep SEC2 alive forever since ACR will run on it */ /* we must keep SEC2 alive forever since ACR will run on it */
nvkm_engine_ref(&subdev->device->sec2->engine); nvkm_engine_ref(&subdev->device->sec2->engine);
sb->boot_falcon = subdev->device->sec2->falcon; sb->boot_falcon = &subdev->device->sec2->falcon;
sb->halt_falcon = &subdev->device->pmu->falcon; sb->halt_falcon = &subdev->device->pmu->falcon;
break; break;
default: default:
......
...@@ -148,7 +148,7 @@ acr_ls_ucode_load_sec2(const struct nvkm_secboot *sb, int maxver, ...@@ -148,7 +148,7 @@ acr_ls_ucode_load_sec2(const struct nvkm_secboot *sb, int maxver,
return ver; return ver;
/* Allocate the PMU queue corresponding to the FW version */ /* Allocate the PMU queue corresponding to the FW version */
ret = nvkm_msgqueue_new(img->ucode_desc.app_version, sec->falcon, ret = nvkm_msgqueue_new(img->ucode_desc.app_version, &sec->falcon,
sb, &sec->queue); sb, &sec->queue);
if (ret) if (ret)
return ret; return ret;
...@@ -166,7 +166,7 @@ acr_ls_sec2_post_run(const struct nvkm_acr *acr, const struct nvkm_secboot *sb) ...@@ -166,7 +166,7 @@ acr_ls_sec2_post_run(const struct nvkm_acr *acr, const struct nvkm_secboot *sb)
const u32 addr_args = 0x01000000; const u32 addr_args = 0x01000000;
int ret; int ret;
ret = acr_ls_msgqueue_post_run(sec->queue, sec->falcon, addr_args); ret = acr_ls_msgqueue_post_run(sec->queue, &sec->falcon, addr_args);
if (ret) if (ret)
return ret; return ret;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册