drm/nouveau/devinit: add interface to check if a mmio access by scripts is ok
Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
This commit is contained in:
parent
0a8649f1c6
commit
3219adc29c
@ -9,6 +9,7 @@ struct nouveau_devinit {
|
||||
bool post;
|
||||
void (*meminit)(struct nouveau_devinit *);
|
||||
int (*pll_set)(struct nouveau_devinit *, u32 type, u32 freq);
|
||||
u32 (*mmio)(struct nouveau_devinit *, u32 addr);
|
||||
};
|
||||
|
||||
static inline struct nouveau_devinit *
|
||||
|
@ -118,6 +118,8 @@ init_conn(struct nvbios_init *init)
|
||||
static inline u32
|
||||
init_nvreg(struct nvbios_init *init, u32 reg)
|
||||
{
|
||||
struct nouveau_devinit *devinit = nouveau_devinit(init->bios);
|
||||
|
||||
/* C51 (at least) sometimes has the lower bits set which the VBIOS
|
||||
* interprets to mean that access needs to go through certain IO
|
||||
* ports instead. The NVIDIA binary driver has been seen to access
|
||||
@ -147,6 +149,9 @@ init_nvreg(struct nvbios_init *init, u32 reg)
|
||||
|
||||
if (reg & ~0x00fffffc)
|
||||
warn("unknown bits in register 0x%08x\n", reg);
|
||||
|
||||
if (devinit->mmio)
|
||||
reg = devinit->mmio(devinit, reg);
|
||||
return reg;
|
||||
}
|
||||
|
||||
@ -154,7 +159,7 @@ static u32
|
||||
init_rd32(struct nvbios_init *init, u32 reg)
|
||||
{
|
||||
reg = init_nvreg(init, reg);
|
||||
if (init_exec(init))
|
||||
if (reg != ~0 && init_exec(init))
|
||||
return nv_rd32(init->subdev, reg);
|
||||
return 0x00000000;
|
||||
}
|
||||
@ -163,7 +168,7 @@ static void
|
||||
init_wr32(struct nvbios_init *init, u32 reg, u32 val)
|
||||
{
|
||||
reg = init_nvreg(init, reg);
|
||||
if (init_exec(init))
|
||||
if (reg != ~0 && init_exec(init))
|
||||
nv_wr32(init->subdev, reg, val);
|
||||
}
|
||||
|
||||
@ -171,7 +176,7 @@ static u32
|
||||
init_mask(struct nvbios_init *init, u32 reg, u32 mask, u32 val)
|
||||
{
|
||||
reg = init_nvreg(init, reg);
|
||||
if (init_exec(init)) {
|
||||
if (reg != ~0 && init_exec(init)) {
|
||||
u32 tmp = nv_rd32(init->subdev, reg);
|
||||
nv_wr32(init->subdev, reg, (tmp & ~mask) | val);
|
||||
return tmp;
|
||||
|
@ -96,5 +96,6 @@ nouveau_devinit_create_(struct nouveau_object *parent,
|
||||
devinit->post = nouveau_boolopt(device->cfgopt, "NvForcePost", false);
|
||||
devinit->meminit = impl->meminit;
|
||||
devinit->pll_set = impl->pll_set;
|
||||
devinit->mmio = impl->mmio;
|
||||
return 0;
|
||||
}
|
||||
|
@ -11,6 +11,7 @@ struct nouveau_devinit_impl {
|
||||
void (*meminit)(struct nouveau_devinit *);
|
||||
int (*pll_set)(struct nouveau_devinit *, u32 type, u32 freq);
|
||||
u64 (*disable)(struct nouveau_devinit *);
|
||||
u32 (*mmio)(struct nouveau_devinit *, u32);
|
||||
};
|
||||
|
||||
#define nouveau_devinit_create(p,e,o,d) \
|
||||
|
Loading…
x
Reference in New Issue
Block a user