2019-06-20 00:13:43 +00:00
|
|
|
/* SPDX-License-Identifier: MIT */
|
2015-08-20 04:54:19 +00:00
|
|
|
#ifndef __NVKM_FIFO_PRIV_H__
|
|
|
|
#define __NVKM_FIFO_PRIV_H__
|
2015-08-20 04:54:22 +00:00
|
|
|
#define nvkm_fifo(p) container_of((p), struct nvkm_fifo, engine)
|
2015-08-20 04:54:19 +00:00
|
|
|
#include <engine/fifo.h>
|
|
|
|
|
2015-08-20 04:54:22 +00:00
|
|
|
int nvkm_fifo_ctor(const struct nvkm_fifo_func *, struct nvkm_device *,
|
|
|
|
int index, int nr, struct nvkm_fifo *);
|
|
|
|
void nvkm_fifo_uevent(struct nvkm_fifo *);
|
2016-11-05 03:12:57 +00:00
|
|
|
void nvkm_fifo_cevent(struct nvkm_fifo *);
|
2016-11-05 03:05:14 +00:00
|
|
|
void nvkm_fifo_kevent(struct nvkm_fifo *, int chid);
|
2017-01-26 02:10:24 +00:00
|
|
|
void nvkm_fifo_recover_chan(struct nvkm_fifo *, int chid);
|
2015-08-20 04:54:22 +00:00
|
|
|
|
2017-01-18 06:01:11 +00:00
|
|
|
struct nvkm_fifo_chan *
|
|
|
|
nvkm_fifo_chan_inst_locked(struct nvkm_fifo *, u64 inst);
|
|
|
|
|
2016-04-08 07:24:40 +00:00
|
|
|
struct nvkm_fifo_chan_oclass;
|
2015-08-20 04:54:22 +00:00
|
|
|
struct nvkm_fifo_func {
|
|
|
|
void *(*dtor)(struct nvkm_fifo *);
|
|
|
|
int (*oneinit)(struct nvkm_fifo *);
|
2018-05-08 10:39:46 +00:00
|
|
|
int (*info)(struct nvkm_fifo *, u64 mthd, u64 *data);
|
2015-08-20 04:54:22 +00:00
|
|
|
void (*init)(struct nvkm_fifo *);
|
|
|
|
void (*fini)(struct nvkm_fifo *);
|
|
|
|
void (*intr)(struct nvkm_fifo *);
|
2018-05-08 10:39:46 +00:00
|
|
|
void (*fault)(struct nvkm_fifo *, struct nvkm_fault_data *);
|
2015-08-20 04:54:22 +00:00
|
|
|
void (*pause)(struct nvkm_fifo *, unsigned long *);
|
|
|
|
void (*start)(struct nvkm_fifo *, unsigned long *);
|
|
|
|
void (*uevent_init)(struct nvkm_fifo *);
|
|
|
|
void (*uevent_fini)(struct nvkm_fifo *);
|
2017-01-26 02:10:24 +00:00
|
|
|
void (*recover_chan)(struct nvkm_fifo *, int chid);
|
2018-05-08 10:39:46 +00:00
|
|
|
int (*class_get)(struct nvkm_fifo *, int index, struct nvkm_oclass *);
|
|
|
|
int (*class_new)(struct nvkm_fifo *, const struct nvkm_oclass *,
|
|
|
|
void *, u32, struct nvkm_object **);
|
2015-08-20 04:54:22 +00:00
|
|
|
const struct nvkm_fifo_chan_oclass *chan[];
|
|
|
|
};
|
|
|
|
|
|
|
|
void nv04_fifo_intr(struct nvkm_fifo *);
|
2015-08-20 04:54:19 +00:00
|
|
|
void nv04_fifo_pause(struct nvkm_fifo *, unsigned long *);
|
|
|
|
void nv04_fifo_start(struct nvkm_fifo *, unsigned long *);
|
2019-06-13 03:58:50 +00:00
|
|
|
|
|
|
|
void gf100_fifo_intr_fault(struct nvkm_fifo *, int);
|
2015-08-20 04:54:19 +00:00
|
|
|
#endif
|