Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 228565
b: refs/heads/master
c: 8f8a544
h: refs/heads/master
i:
  228563: 5008e84
v: v3
  • Loading branch information
Ben Skeggs committed Dec 3, 2010
1 parent 785f263 commit 623cb6d
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 2 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: a169f09b96306cc353ffe0e1bc4bc0e1e9492281
refs/heads/master: 8f8a54482b008714ccfad15f4592b3802b80d479
4 changes: 4 additions & 0 deletions trunk/drivers/gpu/drm/nouveau/nouveau_drv.h
Original file line number Diff line number Diff line change
Expand Up @@ -614,6 +614,7 @@ struct drm_nouveau_private {
struct nouveau_bo *vga_ram;

/* interrupt handling */
void (*irq_handler[32])(struct drm_device *);
bool msi_enabled;
struct workqueue_struct *wq;
struct work_struct irq_work;
Expand Down Expand Up @@ -900,6 +901,9 @@ extern int nouveau_ioctl_gpuobj_free(struct drm_device *, void *data,
extern int nouveau_irq_init(struct drm_device *);
extern void nouveau_irq_fini(struct drm_device *);
extern irqreturn_t nouveau_irq_handler(DRM_IRQ_ARGS);
extern void nouveau_irq_register(struct drm_device *, int status_bit,
void (*)(struct drm_device *));
extern void nouveau_irq_unregister(struct drm_device *, int status_bit);
extern void nouveau_irq_preinstall(struct drm_device *);
extern int nouveau_irq_postinstall(struct drm_device *);
extern void nouveau_irq_uninstall(struct drm_device *);
Expand Down
34 changes: 33 additions & 1 deletion trunk/drivers/gpu/drm/nouveau/nouveau_irq.c
Original file line number Diff line number Diff line change
Expand Up @@ -1216,8 +1216,9 @@ nouveau_irq_handler(DRM_IRQ_ARGS)
{
struct drm_device *dev = (struct drm_device *)arg;
struct drm_nouveau_private *dev_priv = dev->dev_private;
uint32_t status;
unsigned long flags;
u32 status;
int i;

status = nv_rd32(dev, NV03_PMC_INTR_0);
if (!status)
Expand Down Expand Up @@ -1267,6 +1268,14 @@ nouveau_irq_handler(DRM_IRQ_ARGS)
NV_PMC_INTR_0_NV50_I2C_PENDING);
}

for (i = 0; i < 32 && status; i++) {
if (!(status & (1 << i)) || !dev_priv->irq_handler[i])
continue;

dev_priv->irq_handler[i](dev);
status &= ~(1 << i);
}

if (status)
NV_ERROR(dev, "Unhandled PMC INTR status bits 0x%08x\n", status);

Expand Down Expand Up @@ -1304,3 +1313,26 @@ nouveau_irq_fini(struct drm_device *dev)
if (dev_priv->msi_enabled)
pci_disable_msi(dev->pdev);
}

void
nouveau_irq_register(struct drm_device *dev, int status_bit,
void (*handler)(struct drm_device *))
{
struct drm_nouveau_private *dev_priv = dev->dev_private;
unsigned long flags;

spin_lock_irqsave(&dev_priv->context_switch_lock, flags);
dev_priv->irq_handler[status_bit] = handler;
spin_unlock_irqrestore(&dev_priv->context_switch_lock, flags);
}

void
nouveau_irq_unregister(struct drm_device *dev, int status_bit)
{
struct drm_nouveau_private *dev_priv = dev->dev_private;
unsigned long flags;

spin_lock_irqsave(&dev_priv->context_switch_lock, flags);
dev_priv->irq_handler[status_bit] = NULL;
spin_unlock_irqrestore(&dev_priv->context_switch_lock, flags);
}

0 comments on commit 623cb6d

Please sign in to comment.