be83cd4ef9
The namespace of NVKM is being changed to nvkm_ instead of nouveau_, which will be used for the DRM part of the driver. This is being done in order to make it very clear as to what part of the driver a given symbol belongs to, and as a minor step towards splitting the DRM driver out to be able to stand on its own (for virt). Because there's already a large amount of churn here anyway, this is as good a time as any to also switch to NVIDIA's device and chipset naming to ease collaboration with them. A comparison of objdump disassemblies proves no code changes. Signed-off-by: Ben Skeggs <bskeggs@redhat.com>
40 lines
1.1 KiB
C
40 lines
1.1 KiB
C
#ifndef __NVIF_CLIENT_H__
|
|
#define __NVIF_CLIENT_H__
|
|
|
|
#include <nvif/object.h>
|
|
|
|
struct nvif_client {
|
|
struct nvif_object base;
|
|
struct nvif_object *object; /*XXX: hack for nvif_object() */
|
|
const struct nvif_driver *driver;
|
|
bool super;
|
|
};
|
|
|
|
static inline struct nvif_client *
|
|
nvif_client(struct nvif_object *object)
|
|
{
|
|
while (object && object->parent != object)
|
|
object = object->parent;
|
|
return (void *)object;
|
|
}
|
|
|
|
int nvif_client_init(void (*dtor)(struct nvif_client *), const char *,
|
|
const char *, u64, const char *, const char *,
|
|
struct nvif_client *);
|
|
void nvif_client_fini(struct nvif_client *);
|
|
int nvif_client_new(const char *, const char *, u64, const char *,
|
|
const char *, struct nvif_client **);
|
|
void nvif_client_ref(struct nvif_client *, struct nvif_client **);
|
|
int nvif_client_ioctl(struct nvif_client *, void *, u32);
|
|
int nvif_client_suspend(struct nvif_client *);
|
|
int nvif_client_resume(struct nvif_client *);
|
|
|
|
/*XXX*/
|
|
#include <core/client.h>
|
|
#define nvxx_client(a) ({ \
|
|
struct nvif_client *_client = nvif_client(nvif_object(a)); \
|
|
nvkm_client(_client->base.priv); \
|
|
})
|
|
|
|
#endif
|