提交 8e8832e8 编写于 作者: B Ben Skeggs

drm/nouveau/core: allow event source to handle multiple event types per index

Signed-off-by: NBen Skeggs <bskeggs@redhat.com>
上级 255b329c
...@@ -28,14 +28,20 @@ nouveau_event_put(struct nouveau_eventh *handler) ...@@ -28,14 +28,20 @@ nouveau_event_put(struct nouveau_eventh *handler)
{ {
struct nouveau_event *event = handler->event; struct nouveau_event *event = handler->event;
unsigned long flags; unsigned long flags;
if (__test_and_clear_bit(NVKM_EVENT_ENABLE, &handler->flags)) { u32 m, t;
spin_lock_irqsave(&event->refs_lock, flags);
if (!--event->index[handler->index].refs) { if (!__test_and_clear_bit(NVKM_EVENT_ENABLE, &handler->flags))
return;
spin_lock_irqsave(&event->refs_lock, flags);
for (m = handler->types; t = __ffs(m), m; m &= ~(1 << t)) {
if (!--event->refs[handler->index * event->types_nr + t]) {
if (event->disable) if (event->disable)
event->disable(event, handler->index); event->disable(event, 1 << t, handler->index);
} }
spin_unlock_irqrestore(&event->refs_lock, flags);
} }
spin_unlock_irqrestore(&event->refs_lock, flags);
} }
void void
...@@ -43,14 +49,20 @@ nouveau_event_get(struct nouveau_eventh *handler) ...@@ -43,14 +49,20 @@ nouveau_event_get(struct nouveau_eventh *handler)
{ {
struct nouveau_event *event = handler->event; struct nouveau_event *event = handler->event;
unsigned long flags; unsigned long flags;
if (!__test_and_set_bit(NVKM_EVENT_ENABLE, &handler->flags)) { u32 m, t;
spin_lock_irqsave(&event->refs_lock, flags);
if (!event->index[handler->index].refs++) { if (__test_and_set_bit(NVKM_EVENT_ENABLE, &handler->flags))
return;
spin_lock_irqsave(&event->refs_lock, flags);
for (m = handler->types; t = __ffs(m), m; m &= ~(1 << t)) {
if (!event->refs[handler->index * event->types_nr + t]++) {
if (event->enable) if (event->enable)
event->enable(event, handler->index); event->enable(event, 1 << t, handler->index);
} }
spin_unlock_irqrestore(&event->refs_lock, flags);
} }
spin_unlock_irqrestore(&event->refs_lock, flags);
} }
static void static void
...@@ -65,38 +77,47 @@ nouveau_event_fini(struct nouveau_eventh *handler) ...@@ -65,38 +77,47 @@ nouveau_event_fini(struct nouveau_eventh *handler)
} }
static int static int
nouveau_event_init(struct nouveau_event *event, int index, nouveau_event_init(struct nouveau_event *event, u32 types, int index,
int (*func)(void *, int), void *priv, int (*func)(void *, u32, int), void *priv,
struct nouveau_eventh *handler) struct nouveau_eventh *handler)
{ {
unsigned long flags; unsigned long flags;
if (types & ~((1 << event->types_nr) - 1))
return -EINVAL;
if (index >= event->index_nr) if (index >= event->index_nr)
return -EINVAL; return -EINVAL;
handler->event = event; handler->event = event;
handler->flags = 0; handler->flags = 0;
handler->types = types;
handler->index = index; handler->index = index;
handler->func = func; handler->func = func;
handler->priv = priv; handler->priv = priv;
spin_lock_irqsave(&event->list_lock, flags); spin_lock_irqsave(&event->list_lock, flags);
list_add_tail(&handler->head, &event->index[index].list); list_add_tail(&handler->head, &event->list[index]);
spin_unlock_irqrestore(&event->list_lock, flags); spin_unlock_irqrestore(&event->list_lock, flags);
return 0; return 0;
} }
int int
nouveau_event_new(struct nouveau_event *event, int index, nouveau_event_new(struct nouveau_event *event, u32 types, int index,
int (*func)(void *, int), void *priv, int (*func)(void *, u32, int), void *priv,
struct nouveau_eventh **phandler) struct nouveau_eventh **phandler)
{ {
struct nouveau_eventh *handler; struct nouveau_eventh *handler;
int ret = -ENOMEM; int ret = -ENOMEM;
if (event->check) {
ret = event->check(event, types, index);
if (ret)
return ret;
}
handler = *phandler = kmalloc(sizeof(*handler), GFP_KERNEL); handler = *phandler = kmalloc(sizeof(*handler), GFP_KERNEL);
if (handler) { if (handler) {
ret = nouveau_event_init(event, index, func, priv, handler); ret = nouveau_event_init(event, types, index, func, priv, handler);
if (ret) if (ret)
kfree(handler); kfree(handler);
} }
...@@ -116,7 +137,7 @@ nouveau_event_ref(struct nouveau_eventh *handler, struct nouveau_eventh **ref) ...@@ -116,7 +137,7 @@ nouveau_event_ref(struct nouveau_eventh *handler, struct nouveau_eventh **ref)
} }
void void
nouveau_event_trigger(struct nouveau_event *event, int index) nouveau_event_trigger(struct nouveau_event *event, u32 types, int index)
{ {
struct nouveau_eventh *handler; struct nouveau_eventh *handler;
unsigned long flags; unsigned long flags;
...@@ -125,10 +146,15 @@ nouveau_event_trigger(struct nouveau_event *event, int index) ...@@ -125,10 +146,15 @@ nouveau_event_trigger(struct nouveau_event *event, int index)
return; return;
spin_lock_irqsave(&event->list_lock, flags); spin_lock_irqsave(&event->list_lock, flags);
list_for_each_entry(handler, &event->index[index].list, head) { list_for_each_entry(handler, &event->list[index], head) {
if (test_bit(NVKM_EVENT_ENABLE, &handler->flags) && if (!test_bit(NVKM_EVENT_ENABLE, &handler->flags))
handler->func(handler->priv, index) == NVKM_EVENT_DROP) continue;
nouveau_event_put(handler); if (!(handler->types & types))
continue;
if (handler->func(handler->priv, handler->types & types, index)
!= NVKM_EVENT_DROP)
continue;
nouveau_event_put(handler);
} }
spin_unlock_irqrestore(&event->list_lock, flags); spin_unlock_irqrestore(&event->list_lock, flags);
} }
...@@ -144,20 +170,27 @@ nouveau_event_destroy(struct nouveau_event **pevent) ...@@ -144,20 +170,27 @@ nouveau_event_destroy(struct nouveau_event **pevent)
} }
int int
nouveau_event_create(int index_nr, struct nouveau_event **pevent) nouveau_event_create(int types_nr, int index_nr, struct nouveau_event **pevent)
{ {
struct nouveau_event *event; struct nouveau_event *event;
int i; int i;
event = *pevent = kzalloc(sizeof(*event) + index_nr * event = *pevent = kzalloc(sizeof(*event) + (index_nr * types_nr) *
sizeof(event->index[0]), GFP_KERNEL); sizeof(event->refs[0]), GFP_KERNEL);
if (!event) if (!event)
return -ENOMEM; return -ENOMEM;
event->list = kmalloc(sizeof(*event->list) * index_nr, GFP_KERNEL);
if (!event->list) {
kfree(event);
return -ENOMEM;
}
spin_lock_init(&event->list_lock); spin_lock_init(&event->list_lock);
spin_lock_init(&event->refs_lock); spin_lock_init(&event->refs_lock);
for (i = 0; i < index_nr; i++) for (i = 0; i < index_nr; i++)
INIT_LIST_HEAD(&event->index[i].list); INIT_LIST_HEAD(&event->list[i]);
event->types_nr = types_nr;
event->index_nr = index_nr; event->index_nr = index_nr;
return 0; return 0;
} }
...@@ -48,5 +48,5 @@ nouveau_disp_create_(struct nouveau_object *parent, ...@@ -48,5 +48,5 @@ nouveau_disp_create_(struct nouveau_object *parent,
if (ret) if (ret)
return ret; return ret;
return nouveau_event_create(heads, &disp->vblank); return nouveau_event_create(1, heads, &disp->vblank);
} }
...@@ -86,13 +86,13 @@ nv04_disp_sclass[] = { ...@@ -86,13 +86,13 @@ nv04_disp_sclass[] = {
******************************************************************************/ ******************************************************************************/
static void static void
nv04_disp_vblank_enable(struct nouveau_event *event, int head) nv04_disp_vblank_enable(struct nouveau_event *event, int type, int head)
{ {
nv_wr32(event->priv, 0x600140 + (head * 0x2000) , 0x00000001); nv_wr32(event->priv, 0x600140 + (head * 0x2000) , 0x00000001);
} }
static void static void
nv04_disp_vblank_disable(struct nouveau_event *event, int head) nv04_disp_vblank_disable(struct nouveau_event *event, int type, int head)
{ {
nv_wr32(event->priv, 0x600140 + (head * 0x2000) , 0x00000000); nv_wr32(event->priv, 0x600140 + (head * 0x2000) , 0x00000000);
} }
...@@ -106,12 +106,12 @@ nv04_disp_intr(struct nouveau_subdev *subdev) ...@@ -106,12 +106,12 @@ nv04_disp_intr(struct nouveau_subdev *subdev)
u32 pvideo; u32 pvideo;
if (crtc0 & 0x00000001) { if (crtc0 & 0x00000001) {
nouveau_event_trigger(priv->base.vblank, 0); nouveau_event_trigger(priv->base.vblank, 1, 0);
nv_wr32(priv, 0x600100, 0x00000001); nv_wr32(priv, 0x600100, 0x00000001);
} }
if (crtc1 & 0x00000001) { if (crtc1 & 0x00000001) {
nouveau_event_trigger(priv->base.vblank, 1); nouveau_event_trigger(priv->base.vblank, 1, 1);
nv_wr32(priv, 0x602100, 0x00000001); nv_wr32(priv, 0x602100, 0x00000001);
} }
......
...@@ -829,13 +829,13 @@ nv50_disp_base_scanoutpos(struct nouveau_object *object, u32 mthd, ...@@ -829,13 +829,13 @@ nv50_disp_base_scanoutpos(struct nouveau_object *object, u32 mthd,
} }
static void static void
nv50_disp_base_vblank_enable(struct nouveau_event *event, int head) nv50_disp_base_vblank_enable(struct nouveau_event *event, int type, int head)
{ {
nv_mask(event->priv, 0x61002c, (4 << head), (4 << head)); nv_mask(event->priv, 0x61002c, (4 << head), (4 << head));
} }
static void static void
nv50_disp_base_vblank_disable(struct nouveau_event *event, int head) nv50_disp_base_vblank_disable(struct nouveau_event *event, int type, int head)
{ {
nv_mask(event->priv, 0x61002c, (4 << head), 0); nv_mask(event->priv, 0x61002c, (4 << head), 0);
} }
...@@ -1610,13 +1610,13 @@ nv50_disp_intr(struct nouveau_subdev *subdev) ...@@ -1610,13 +1610,13 @@ nv50_disp_intr(struct nouveau_subdev *subdev)
} }
if (intr1 & 0x00000004) { if (intr1 & 0x00000004) {
nouveau_event_trigger(priv->base.vblank, 0); nouveau_event_trigger(priv->base.vblank, 1, 0);
nv_wr32(priv, 0x610024, 0x00000004); nv_wr32(priv, 0x610024, 0x00000004);
intr1 &= ~0x00000004; intr1 &= ~0x00000004;
} }
if (intr1 & 0x00000008) { if (intr1 & 0x00000008) {
nouveau_event_trigger(priv->base.vblank, 1); nouveau_event_trigger(priv->base.vblank, 1, 1);
nv_wr32(priv, 0x610024, 0x00000008); nv_wr32(priv, 0x610024, 0x00000008);
intr1 &= ~0x00000008; intr1 &= ~0x00000008;
} }
......
...@@ -748,13 +748,13 @@ nvd0_disp_base_scanoutpos(struct nouveau_object *object, u32 mthd, ...@@ -748,13 +748,13 @@ nvd0_disp_base_scanoutpos(struct nouveau_object *object, u32 mthd,
} }
static void static void
nvd0_disp_base_vblank_enable(struct nouveau_event *event, int head) nvd0_disp_base_vblank_enable(struct nouveau_event *event, int type, int head)
{ {
nv_mask(event->priv, 0x6100c0 + (head * 0x800), 0x00000001, 0x00000001); nv_mask(event->priv, 0x6100c0 + (head * 0x800), 0x00000001, 0x00000001);
} }
static void static void
nvd0_disp_base_vblank_disable(struct nouveau_event *event, int head) nvd0_disp_base_vblank_disable(struct nouveau_event *event, int type, int head)
{ {
nv_mask(event->priv, 0x6100c0 + (head * 0x800), 0x00000001, 0x00000000); nv_mask(event->priv, 0x6100c0 + (head * 0x800), 0x00000001, 0x00000000);
} }
...@@ -1317,7 +1317,7 @@ nvd0_disp_intr(struct nouveau_subdev *subdev) ...@@ -1317,7 +1317,7 @@ nvd0_disp_intr(struct nouveau_subdev *subdev)
if (mask & intr) { if (mask & intr) {
u32 stat = nv_rd32(priv, 0x6100bc + (i * 0x800)); u32 stat = nv_rd32(priv, 0x6100bc + (i * 0x800));
if (stat & 0x00000001) if (stat & 0x00000001)
nouveau_event_trigger(priv->base.vblank, i); nouveau_event_trigger(priv->base.vblank, 1, i);
nv_mask(priv, 0x6100bc + (i * 0x800), 0, 0); nv_mask(priv, 0x6100bc + (i * 0x800), 0, 0);
nv_rd32(priv, 0x6100c0 + (i * 0x800)); nv_rd32(priv, 0x6100c0 + (i * 0x800));
} }
......
...@@ -91,7 +91,7 @@ nouveau_fifo_channel_create_(struct nouveau_object *parent, ...@@ -91,7 +91,7 @@ nouveau_fifo_channel_create_(struct nouveau_object *parent,
if (!chan->user) if (!chan->user)
return -EFAULT; return -EFAULT;
nouveau_event_trigger(priv->cevent, 0); nouveau_event_trigger(priv->cevent, 1, 0);
chan->size = size; chan->size = size;
return 0; return 0;
...@@ -194,11 +194,11 @@ nouveau_fifo_create_(struct nouveau_object *parent, ...@@ -194,11 +194,11 @@ nouveau_fifo_create_(struct nouveau_object *parent,
if (!priv->channel) if (!priv->channel)
return -ENOMEM; return -ENOMEM;
ret = nouveau_event_create(1, &priv->cevent); ret = nouveau_event_create(1, 1, &priv->cevent);
if (ret) if (ret)
return ret; return ret;
ret = nouveau_event_create(1, &priv->uevent); ret = nouveau_event_create(1, 1, &priv->uevent);
if (ret) if (ret)
return ret; return ret;
......
...@@ -539,7 +539,7 @@ nv04_fifo_intr(struct nouveau_subdev *subdev) ...@@ -539,7 +539,7 @@ nv04_fifo_intr(struct nouveau_subdev *subdev)
} }
if (status & 0x40000000) { if (status & 0x40000000) {
nouveau_event_trigger(priv->base.uevent, 0); nouveau_event_trigger(priv->base.uevent, 1, 0);
nv_wr32(priv, 0x002100, 0x40000000); nv_wr32(priv, 0x002100, 0x40000000);
status &= ~0x40000000; status &= ~0x40000000;
} }
......
...@@ -389,14 +389,14 @@ nv84_fifo_cclass = { ...@@ -389,14 +389,14 @@ nv84_fifo_cclass = {
******************************************************************************/ ******************************************************************************/
static void static void
nv84_fifo_uevent_enable(struct nouveau_event *event, int index) nv84_fifo_uevent_enable(struct nouveau_event *event, int type, int index)
{ {
struct nv84_fifo_priv *priv = event->priv; struct nv84_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x40000000, 0x40000000); nv_mask(priv, 0x002140, 0x40000000, 0x40000000);
} }
static void static void
nv84_fifo_uevent_disable(struct nouveau_event *event, int index) nv84_fifo_uevent_disable(struct nouveau_event *event, int type, int index)
{ {
struct nv84_fifo_priv *priv = event->priv; struct nv84_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x40000000, 0x00000000); nv_mask(priv, 0x002140, 0x40000000, 0x00000000);
......
...@@ -730,7 +730,7 @@ nvc0_fifo_intr_engine_unit(struct nvc0_fifo_priv *priv, int engn) ...@@ -730,7 +730,7 @@ nvc0_fifo_intr_engine_unit(struct nvc0_fifo_priv *priv, int engn)
for (unkn = 0; unkn < 8; unkn++) { for (unkn = 0; unkn < 8; unkn++) {
u32 ints = (intr >> (unkn * 0x04)) & inte; u32 ints = (intr >> (unkn * 0x04)) & inte;
if (ints & 0x1) { if (ints & 0x1) {
nouveau_event_trigger(priv->base.uevent, 0); nouveau_event_trigger(priv->base.uevent, 1, 0);
ints &= ~1; ints &= ~1;
} }
if (ints) { if (ints) {
...@@ -827,14 +827,14 @@ nvc0_fifo_intr(struct nouveau_subdev *subdev) ...@@ -827,14 +827,14 @@ nvc0_fifo_intr(struct nouveau_subdev *subdev)
} }
static void static void
nvc0_fifo_uevent_enable(struct nouveau_event *event, int index) nvc0_fifo_uevent_enable(struct nouveau_event *event, int type, int index)
{ {
struct nvc0_fifo_priv *priv = event->priv; struct nvc0_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x80000000, 0x80000000); nv_mask(priv, 0x002140, 0x80000000, 0x80000000);
} }
static void static void
nvc0_fifo_uevent_disable(struct nouveau_event *event, int index) nvc0_fifo_uevent_disable(struct nouveau_event *event, int type, int index)
{ {
struct nvc0_fifo_priv *priv = event->priv; struct nvc0_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x80000000, 0x00000000); nv_mask(priv, 0x002140, 0x80000000, 0x00000000);
......
...@@ -859,7 +859,7 @@ nve0_fifo_intr_runlist(struct nve0_fifo_priv *priv) ...@@ -859,7 +859,7 @@ nve0_fifo_intr_runlist(struct nve0_fifo_priv *priv)
static void static void
nve0_fifo_intr_engine(struct nve0_fifo_priv *priv) nve0_fifo_intr_engine(struct nve0_fifo_priv *priv)
{ {
nouveau_event_trigger(priv->base.uevent, 0); nouveau_event_trigger(priv->base.uevent, 1, 0);
} }
static void static void
...@@ -952,14 +952,14 @@ nve0_fifo_intr(struct nouveau_subdev *subdev) ...@@ -952,14 +952,14 @@ nve0_fifo_intr(struct nouveau_subdev *subdev)
} }
static void static void
nve0_fifo_uevent_enable(struct nouveau_event *event, int index) nve0_fifo_uevent_enable(struct nouveau_event *event, int type, int index)
{ {
struct nve0_fifo_priv *priv = event->priv; struct nve0_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x80000000, 0x80000000); nv_mask(priv, 0x002140, 0x80000000, 0x80000000);
} }
static void static void
nve0_fifo_uevent_disable(struct nouveau_event *event, int index) nve0_fifo_uevent_disable(struct nouveau_event *event, int type, int index)
{ {
struct nve0_fifo_priv *priv = event->priv; struct nve0_fifo_priv *priv = event->priv;
nv_mask(priv, 0x002140, 0x80000000, 0x00000000); nv_mask(priv, 0x002140, 0x80000000, 0x00000000);
......
...@@ -124,7 +124,7 @@ nv50_software_sclass[] = { ...@@ -124,7 +124,7 @@ nv50_software_sclass[] = {
******************************************************************************/ ******************************************************************************/
static int static int
nv50_software_vblsem_release(void *data, int head) nv50_software_vblsem_release(void *data, u32 type, int head)
{ {
struct nv50_software_chan *chan = data; struct nv50_software_chan *chan = data;
struct nv50_software_priv *priv = (void *)nv_object(chan)->engine; struct nv50_software_priv *priv = (void *)nv_object(chan)->engine;
...@@ -183,7 +183,7 @@ nv50_software_context_ctor(struct nouveau_object *parent, ...@@ -183,7 +183,7 @@ nv50_software_context_ctor(struct nouveau_object *parent,
return -ENOMEM; return -ENOMEM;
for (i = 0; i < chan->vblank.nr_event; i++) { for (i = 0; i < chan->vblank.nr_event; i++) {
ret = nouveau_event_new(pdisp->vblank, i, pclass->vblank, ret = nouveau_event_new(pdisp->vblank, 1, i, pclass->vblank,
chan, &chan->vblank.event[i]); chan, &chan->vblank.event[i]);
if (ret) if (ret)
return ret; return ret;
......
...@@ -19,7 +19,7 @@ int nv50_software_ctor(struct nouveau_object *, struct nouveau_object *, ...@@ -19,7 +19,7 @@ int nv50_software_ctor(struct nouveau_object *, struct nouveau_object *,
struct nv50_software_cclass { struct nv50_software_cclass {
struct nouveau_oclass base; struct nouveau_oclass base;
int (*vblank)(void *, int); int (*vblank)(void *, u32, int);
}; };
struct nv50_software_chan { struct nv50_software_chan {
......
...@@ -104,7 +104,7 @@ nvc0_software_sclass[] = { ...@@ -104,7 +104,7 @@ nvc0_software_sclass[] = {
******************************************************************************/ ******************************************************************************/
static int static int
nvc0_software_vblsem_release(void *data, int head) nvc0_software_vblsem_release(void *data, u32 type, int head)
{ {
struct nv50_software_chan *chan = data; struct nv50_software_chan *chan = data;
struct nv50_software_priv *priv = (void *)nv_object(chan)->engine; struct nv50_software_priv *priv = (void *)nv_object(chan)->engine;
......
...@@ -12,32 +12,33 @@ struct nouveau_eventh { ...@@ -12,32 +12,33 @@ struct nouveau_eventh {
struct nouveau_event *event; struct nouveau_event *event;
struct list_head head; struct list_head head;
unsigned long flags; unsigned long flags;
u32 types;
int index; int index;
int (*func)(void *, int); int (*func)(void *, u32, int);
void *priv; void *priv;
}; };
struct nouveau_event { struct nouveau_event {
spinlock_t list_lock;
spinlock_t refs_lock;
void *priv; void *priv;
void (*enable)(struct nouveau_event *, int index); int (*check)(struct nouveau_event *, u32 type, int index);
void (*disable)(struct nouveau_event *, int index); void (*enable)(struct nouveau_event *, int type, int index);
void (*disable)(struct nouveau_event *, int type, int index);
int types_nr;
int index_nr; int index_nr;
struct {
struct list_head list; spinlock_t list_lock;
int refs; struct list_head *list;
} index[]; spinlock_t refs_lock;
int refs[];
}; };
int nouveau_event_create(int index_nr, struct nouveau_event **); int nouveau_event_create(int types_nr, int index_nr, struct nouveau_event **);
void nouveau_event_destroy(struct nouveau_event **); void nouveau_event_destroy(struct nouveau_event **);
void nouveau_event_trigger(struct nouveau_event *, int index); void nouveau_event_trigger(struct nouveau_event *, u32 types, int index);
int nouveau_event_new(struct nouveau_event *, int index, int nouveau_event_new(struct nouveau_event *, u32 types, int index,
int (*func)(void *, int), void *, int (*func)(void *, u32, int), void *,
struct nouveau_eventh **); struct nouveau_eventh **);
void nouveau_event_ref(struct nouveau_eventh *, struct nouveau_eventh **); void nouveau_event_ref(struct nouveau_eventh *, struct nouveau_eventh **);
void nouveau_event_get(struct nouveau_eventh *); void nouveau_event_get(struct nouveau_eventh *);
......
...@@ -125,7 +125,7 @@ nouveau_gpio_create_(struct nouveau_object *parent, ...@@ -125,7 +125,7 @@ nouveau_gpio_create_(struct nouveau_object *parent,
if (ret) if (ret)
return ret; return ret;
ret = nouveau_event_create(lines, &gpio->events); ret = nouveau_event_create(1, lines, &gpio->events);
if (ret) if (ret)
return ret; return ret;
......
...@@ -93,7 +93,7 @@ nv10_gpio_intr(struct nouveau_subdev *subdev) ...@@ -93,7 +93,7 @@ nv10_gpio_intr(struct nouveau_subdev *subdev)
for (i = 0; (hi | lo) && i < 32; i++) { for (i = 0; (hi | lo) && i < 32; i++) {
if ((hi | lo) & (1 << i)) if ((hi | lo) & (1 << i))
nouveau_event_trigger(priv->base.events, i); nouveau_event_trigger(priv->base.events, 1, i);
} }
nv_wr32(priv, 0x001104, intr); nv_wr32(priv, 0x001104, intr);
......
...@@ -112,7 +112,7 @@ nv50_gpio_intr(struct nouveau_subdev *subdev) ...@@ -112,7 +112,7 @@ nv50_gpio_intr(struct nouveau_subdev *subdev)
for (i = 0; (hi | lo) && i < 32; i++) { for (i = 0; (hi | lo) && i < 32; i++) {
if ((hi | lo) & (1 << i)) if ((hi | lo) & (1 << i))
nouveau_event_trigger(priv->base.events, i); nouveau_event_trigger(priv->base.events, 1, i);
} }
nv_wr32(priv, 0xe054, intr0); nv_wr32(priv, 0xe054, intr0);
......
...@@ -40,7 +40,7 @@ nve0_gpio_intr(struct nouveau_subdev *subdev) ...@@ -40,7 +40,7 @@ nve0_gpio_intr(struct nouveau_subdev *subdev)
for (i = 0; (hi | lo) && i < 32; i++) { for (i = 0; (hi | lo) && i < 32; i++) {
if ((hi | lo) & (1 << i)) if ((hi | lo) & (1 << i))
nouveau_event_trigger(priv->base.events, i); nouveau_event_trigger(priv->base.events, 1, i);
} }
nv_wr32(priv, 0xdc00, intr0); nv_wr32(priv, 0xdc00, intr0);
......
...@@ -934,7 +934,7 @@ nouveau_connector_hotplug_work(struct work_struct *work) ...@@ -934,7 +934,7 @@ nouveau_connector_hotplug_work(struct work_struct *work)
} }
static int static int
nouveau_connector_hotplug(void *data, int index) nouveau_connector_hotplug(void *data, u32 type, int index)
{ {
struct nouveau_connector *nv_connector = data; struct nouveau_connector *nv_connector = data;
schedule_work(&nv_connector->hpd_work); schedule_work(&nv_connector->hpd_work);
...@@ -1013,7 +1013,8 @@ nouveau_connector_create(struct drm_device *dev, int index) ...@@ -1013,7 +1013,8 @@ nouveau_connector_create(struct drm_device *dev, int index)
nv_connector->hpd.func = DCB_GPIO_UNUSED; nv_connector->hpd.func = DCB_GPIO_UNUSED;
if (nv_connector->hpd.func != DCB_GPIO_UNUSED) { if (nv_connector->hpd.func != DCB_GPIO_UNUSED) {
nouveau_event_new(gpio->events, nv_connector->hpd.line, nouveau_event_new(gpio->events, 1,
nv_connector->hpd.line,
nouveau_connector_hotplug, nouveau_connector_hotplug,
nv_connector, nv_connector,
&nv_connector->hpd_func); &nv_connector->hpd_func);
......
...@@ -42,7 +42,7 @@ ...@@ -42,7 +42,7 @@
#include <core/class.h> #include <core/class.h>
static int static int
nouveau_display_vblank_handler(void *data, int head) nouveau_display_vblank_handler(void *data, u32 type, int head)
{ {
struct nouveau_drm *drm = data; struct nouveau_drm *drm = data;
drm_handle_vblank(drm->dev, head); drm_handle_vblank(drm->dev, head);
...@@ -178,7 +178,7 @@ nouveau_display_vblank_init(struct drm_device *dev) ...@@ -178,7 +178,7 @@ nouveau_display_vblank_init(struct drm_device *dev)
return -ENOMEM; return -ENOMEM;
for (i = 0; i < dev->mode_config.num_crtc; i++) { for (i = 0; i < dev->mode_config.num_crtc; i++) {
ret = nouveau_event_new(pdisp->vblank, i, ret = nouveau_event_new(pdisp->vblank, 1, i,
nouveau_display_vblank_handler, nouveau_display_vblank_handler,
drm, &disp->vblank[i]); drm, &disp->vblank[i]);
if (ret) { if (ret) {
......
...@@ -166,7 +166,7 @@ nouveau_fence_done(struct nouveau_fence *fence) ...@@ -166,7 +166,7 @@ nouveau_fence_done(struct nouveau_fence *fence)
} }
static int static int
nouveau_fence_wait_uevent_handler(void *data, int index) nouveau_fence_wait_uevent_handler(void *data, u32 type, int index)
{ {
struct nouveau_fence_priv *priv = data; struct nouveau_fence_priv *priv = data;
wake_up_all(&priv->waiting); wake_up_all(&priv->waiting);
...@@ -183,7 +183,7 @@ nouveau_fence_wait_uevent(struct nouveau_fence *fence, bool intr) ...@@ -183,7 +183,7 @@ nouveau_fence_wait_uevent(struct nouveau_fence *fence, bool intr)
struct nouveau_eventh *handler; struct nouveau_eventh *handler;
int ret = 0; int ret = 0;
ret = nouveau_event_new(pfifo->uevent, 0, ret = nouveau_event_new(pfifo->uevent, 1, 0,
nouveau_fence_wait_uevent_handler, nouveau_fence_wait_uevent_handler,
priv, &handler); priv, &handler);
if (ret) if (ret)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册