Commit e1cc5798 authored by Ben Skeggs's avatar Ben Skeggs

drm/nouveau/flcn/msgq: pass explicit message queue pointer to recv()

Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent d114a139
...@@ -73,4 +73,5 @@ void nvkm_falcon_msgq_del(struct nvkm_falcon_msgq **); ...@@ -73,4 +73,5 @@ void nvkm_falcon_msgq_del(struct nvkm_falcon_msgq **);
void nvkm_falcon_msgq_init(struct nvkm_falcon_msgq *, void nvkm_falcon_msgq_init(struct nvkm_falcon_msgq *,
u32 index, u32 offset, u32 size); u32 index, u32 offset, u32 size);
int nvkm_falcon_msgq_recv_initmsg(struct nvkm_falcon_msgq *, void *, u32 size); int nvkm_falcon_msgq_recv_initmsg(struct nvkm_falcon_msgq *, void *, u32 size);
void nvkm_falcon_msgq_recv(struct nvkm_falcon_msgq *);
#endif #endif
...@@ -31,7 +31,6 @@ struct nvkm_msgqueue; ...@@ -31,7 +31,6 @@ struct nvkm_msgqueue;
int nvkm_msgqueue_new(u32, struct nvkm_falcon *, const struct nvkm_secboot *, int nvkm_msgqueue_new(u32, struct nvkm_falcon *, const struct nvkm_secboot *,
struct nvkm_msgqueue **); struct nvkm_msgqueue **);
void nvkm_msgqueue_del(struct nvkm_msgqueue **); void nvkm_msgqueue_del(struct nvkm_msgqueue **);
void nvkm_msgqueue_recv(struct nvkm_msgqueue *);
/* useful if we run a NVIDIA-signed firmware */ /* useful if we run a NVIDIA-signed firmware */
void nvkm_msgqueue_write_cmdline(struct nvkm_msgqueue *, void *); void nvkm_msgqueue_write_cmdline(struct nvkm_msgqueue *, void *);
......
...@@ -41,13 +41,7 @@ nvkm_sec2_recv(struct work_struct *work) ...@@ -41,13 +41,7 @@ nvkm_sec2_recv(struct work_struct *work)
sec2->initmsg_received = true; sec2->initmsg_received = true;
} }
if (!sec2->queue) { nvkm_falcon_msgq_recv(sec2->msgq);
nvkm_warn(&sec2->engine.subdev,
"recv function called while no firmware set!\n");
return;
}
nvkm_msgqueue_recv(sec2->queue);
} }
static void static void
......
...@@ -160,8 +160,7 @@ nvkm_falcon_msgq_recv_initmsg(struct nvkm_falcon_msgq *msgq, ...@@ -160,8 +160,7 @@ nvkm_falcon_msgq_recv_initmsg(struct nvkm_falcon_msgq *msgq,
} }
void void
nvkm_msgqueue_process_msgs(struct nvkm_msgqueue *priv, nvkm_falcon_msgq_recv(struct nvkm_falcon_msgq *queue)
struct nvkm_msgqueue_queue *queue)
{ {
/* /*
* We are invoked from a worker thread, so normally we have plenty of * We are invoked from a worker thread, so normally we have plenty of
......
...@@ -77,19 +77,6 @@ nvkm_msgqueue_del(struct nvkm_msgqueue **queue) ...@@ -77,19 +77,6 @@ nvkm_msgqueue_del(struct nvkm_msgqueue **queue)
} }
} }
void
nvkm_msgqueue_recv(struct nvkm_msgqueue *queue)
{
if (!queue->func || !queue->func->recv) {
const struct nvkm_subdev *subdev = queue->falcon->owner;
nvkm_warn(subdev, "missing msgqueue recv function\n");
return;
}
queue->func->recv(queue);
}
void void
nvkm_msgqueue_ctor(const struct nvkm_msgqueue_func *func, nvkm_msgqueue_ctor(const struct nvkm_msgqueue_func *func,
struct nvkm_falcon *falcon, struct nvkm_falcon *falcon,
......
...@@ -67,7 +67,6 @@ struct nvkm_msgqueue_init_func { ...@@ -67,7 +67,6 @@ struct nvkm_msgqueue_init_func {
struct nvkm_msgqueue_func { struct nvkm_msgqueue_func {
const struct nvkm_msgqueue_init_func *init_func; const struct nvkm_msgqueue_init_func *init_func;
void (*dtor)(struct nvkm_msgqueue *); void (*dtor)(struct nvkm_msgqueue *);
void (*recv)(struct nvkm_msgqueue *queue);
}; };
/** /**
...@@ -114,8 +113,6 @@ struct nvkm_msgqueue { ...@@ -114,8 +113,6 @@ struct nvkm_msgqueue {
void nvkm_msgqueue_ctor(const struct nvkm_msgqueue_func *, struct nvkm_falcon *, void nvkm_msgqueue_ctor(const struct nvkm_msgqueue_func *, struct nvkm_falcon *,
struct nvkm_msgqueue *); struct nvkm_msgqueue *);
void nvkm_msgqueue_process_msgs(struct nvkm_msgqueue *,
struct nvkm_msgqueue_queue *);
int msgqueue_0137c63d_new(struct nvkm_falcon *, const struct nvkm_secboot *, int msgqueue_0137c63d_new(struct nvkm_falcon *, const struct nvkm_secboot *,
struct nvkm_msgqueue **); struct nvkm_msgqueue **);
......
...@@ -40,12 +40,6 @@ struct msgqueue_0137bca5 { ...@@ -40,12 +40,6 @@ struct msgqueue_0137bca5 {
container_of(container_of(q, struct msgqueue_0137c63d, base), \ container_of(container_of(q, struct msgqueue_0137c63d, base), \
struct msgqueue_0137bca5, base); struct msgqueue_0137bca5, base);
static void
msgqueue_0137c63d_process_msgs(struct nvkm_msgqueue *queue)
{
nvkm_msgqueue_process_msgs(queue, queue->falcon->owner->device->pmu->msgq);
}
/* Init unit */ /* Init unit */
static void static void
init_gen_cmdline(struct nvkm_msgqueue *queue, void *buf) init_gen_cmdline(struct nvkm_msgqueue *queue, void *buf)
...@@ -87,7 +81,6 @@ msgqueue_0137c63d_dtor(struct nvkm_msgqueue *queue) ...@@ -87,7 +81,6 @@ msgqueue_0137c63d_dtor(struct nvkm_msgqueue *queue)
static const struct nvkm_msgqueue_func static const struct nvkm_msgqueue_func
msgqueue_0137c63d_func = { msgqueue_0137c63d_func = {
.init_func = &msgqueue_0137c63d_init_func, .init_func = &msgqueue_0137c63d_init_func,
.recv = msgqueue_0137c63d_process_msgs,
.dtor = msgqueue_0137c63d_dtor, .dtor = msgqueue_0137c63d_dtor,
}; };
...@@ -111,7 +104,6 @@ msgqueue_0137c63d_new(struct nvkm_falcon *falcon, const struct nvkm_secboot *sb, ...@@ -111,7 +104,6 @@ msgqueue_0137c63d_new(struct nvkm_falcon *falcon, const struct nvkm_secboot *sb,
static const struct nvkm_msgqueue_func static const struct nvkm_msgqueue_func
msgqueue_0137bca5_func = { msgqueue_0137bca5_func = {
.init_func = &msgqueue_0137c63d_init_func, .init_func = &msgqueue_0137c63d_init_func,
.recv = msgqueue_0137c63d_process_msgs,
.dtor = msgqueue_0137c63d_dtor, .dtor = msgqueue_0137c63d_dtor,
}; };
......
...@@ -37,13 +37,6 @@ struct msgqueue_0148cdec { ...@@ -37,13 +37,6 @@ struct msgqueue_0148cdec {
#define msgqueue_0148cdec(q) \ #define msgqueue_0148cdec(q) \
container_of(q, struct msgqueue_0148cdec, base) container_of(q, struct msgqueue_0148cdec, base)
static void
msgqueue_0148cdec_process_msgs(struct nvkm_msgqueue *queue)
{
nvkm_msgqueue_process_msgs(queue, queue->falcon->owner->device->sec2->msgq);
}
static void static void
init_gen_cmdline(struct nvkm_msgqueue *queue, void *buf) init_gen_cmdline(struct nvkm_msgqueue *queue, void *buf)
{ {
...@@ -73,7 +66,6 @@ msgqueue_0148cdec_dtor(struct nvkm_msgqueue *queue) ...@@ -73,7 +66,6 @@ msgqueue_0148cdec_dtor(struct nvkm_msgqueue *queue)
const struct nvkm_msgqueue_func const struct nvkm_msgqueue_func
msgqueue_0148cdec_func = { msgqueue_0148cdec_func = {
.init_func = &msgqueue_0148cdec_init_func, .init_func = &msgqueue_0148cdec_init_func,
.recv = msgqueue_0148cdec_process_msgs,
.dtor = msgqueue_0148cdec_dtor, .dtor = msgqueue_0148cdec_dtor,
}; };
......
...@@ -135,13 +135,7 @@ gm20b_pmu_recv(struct nvkm_pmu *pmu) ...@@ -135,13 +135,7 @@ gm20b_pmu_recv(struct nvkm_pmu *pmu)
pmu->initmsg_received = true; pmu->initmsg_received = true;
} }
if (!pmu->queue) { nvkm_falcon_msgq_recv(pmu->msgq);
nvkm_warn(&pmu->subdev,
"recv function called while no firmware set!\n");
return;
}
nvkm_msgqueue_recv(pmu->queue);
} }
static const struct nvkm_pmu_func static const struct nvkm_pmu_func
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment