123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- #include "nouveau_drm.h"
- #include "nouveau_compat.h"
- #include <subdev/bios.h>
- #include <subdev/gpio.h>
- void *nouveau_newpriv(struct drm_device *);
- u8
- _nv_rd08(struct drm_device *dev, u32 reg)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- return nv_ro08(drm->device, reg);
- }
- void
- _nv_wr08(struct drm_device *dev, u32 reg, u8 val)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- nv_wo08(drm->device, reg, val);
- }
- u32
- _nv_rd32(struct drm_device *dev, u32 reg)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- return nv_ro32(drm->device, reg);
- }
- void
- _nv_wr32(struct drm_device *dev, u32 reg, u32 val)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- nv_wo32(drm->device, reg, val);
- }
- u32
- _nv_mask(struct drm_device *dev, u32 reg, u32 mask, u32 val)
- {
- u32 tmp = _nv_rd32(dev, reg);
- _nv_wr32(dev, reg, (tmp & ~mask) | val);
- return tmp;
- }
- bool
- _nv_bios(struct drm_device *dev, u8 **data, u32 *size)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_bios *bios = nouveau_bios(drm->device);
- *data = bios->data;
- *size = bios->size;
- return true;
- }
- void
- nouveau_gpio_reset(struct drm_device *dev)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- gpio->reset(gpio);
- }
- int
- nouveau_gpio_find(struct drm_device *dev, int idx, u8 tag, u8 line,
- struct dcb_gpio_func *func)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- return gpio->find(gpio, idx, tag, line, func);
- }
- bool
- nouveau_gpio_func_valid(struct drm_device *dev, u8 tag)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- struct dcb_gpio_func func;
- return gpio->find(gpio, 0, tag, 0xff, &func) == 0;
- }
- int
- nouveau_gpio_func_set(struct drm_device *dev, u8 tag, int state)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- if (gpio && gpio->get)
- return gpio->set(gpio, 0, tag, 0xff, state);
- return -ENODEV;
- }
- int
- nouveau_gpio_func_get(struct drm_device *dev, u8 tag)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- if (gpio && gpio->get)
- return gpio->get(gpio, 0, tag, 0xff);
- return -ENODEV;
- }
- int
- nouveau_gpio_irq(struct drm_device *dev, int idx, u8 tag, u8 line, bool on)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- if (gpio && gpio->irq)
- return gpio->irq(gpio, idx, tag, line, on);
- return -ENODEV;
- }
- int
- nouveau_gpio_isr_add(struct drm_device *dev, int idx, u8 tag, u8 line,
- void (*exec)(void *, int state), void *data)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- if (gpio && gpio->isr_add)
- return gpio->isr_add(gpio, idx, tag, line, exec, data);
- return -ENODEV;
- }
- void
- nouveau_gpio_isr_del(struct drm_device *dev, int idx, u8 tag, u8 line,
- void (*exec)(void *, int state), void *data)
- {
- struct nouveau_drm *drm = nouveau_newpriv(dev);
- struct nouveau_gpio *gpio = nouveau_gpio(drm->device);
- if (gpio && gpio->isr_del)
- gpio->isr_del(gpio, idx, tag, line, exec, data);
- }
|