drm/nouveau/clk: namespace + nvidia gpu names (no binary change)
authorBen Skeggs <bskeggs@redhat.com>
Wed, 14 Jan 2015 04:47:24 +0000 (14:47 +1000)
committerBen Skeggs <bskeggs@redhat.com>
Thu, 22 Jan 2015 02:17:51 +0000 (12:17 +1000)
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>
25 files changed:
drivers/gpu/drm/nouveau/include/nvkm/core/os.h
drivers/gpu/drm/nouveau/include/nvkm/subdev/clk.h
drivers/gpu/drm/nouveau/nvkm/engine/device/gm100.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nv50.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nvc0.c
drivers/gpu/drm/nouveau/nvkm/engine/device/nve0.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/Kbuild
drivers/gpu/drm/nouveau/nvkm/subdev/clk/base.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/g84.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/nv84.c with 84% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/gf100.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/nvc0.c with 75% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/gk104.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/nve0.c with 75% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/gk20a.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/nva3.c with 75% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.h [new file with mode: 0644]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/mcp77.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/nvaa.c with 85% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/nv04.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/nv40.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/nv50.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/nv50.h
drivers/gpu/drm/nouveau/nvkm/subdev/clk/nva3.h [deleted file]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/pll.h
drivers/gpu/drm/nouveau/nvkm/subdev/clk/pllgt215.c [moved from drivers/gpu/drm/nouveau/nvkm/subdev/clk/pllnva3.c with 94% similarity]
drivers/gpu/drm/nouveau/nvkm/subdev/clk/pllnv04.c
drivers/gpu/drm/nouveau/nvkm/subdev/clk/seq.h
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramnva3.c

index af07bbb..70ad99d 100644 (file)
 #define nouveau_bios_oclass nvkm_bios_oclass
 #define nouveau_pll_vals nvkm_pll_vals
 #define nouveau_therm_trip_point nvkm_therm_trip_point
+#define nouveau_fb nvkm_fb
+#define nouveau_fifo nvkm_fifo
+#define nouveau_therm nvkm_therm
+#define nouveau_therm_cstate nvkm_therm_cstate
+#define nouveau_volt nvkm_volt
+#define nouveau_timer nvkm_timer
+#define nouveau_timer_wait_eq nvkm_timer_wait_eq
+#define nva3_pll_calc gt215_pll_calc
+#define nouveau_clk nvkm_clk
+#define nouveau_domain nvkm_domain
+#define nouveau_cstate nvkm_cstate
+#define nouveau_pstate nvkm_pstate
+#define nouveau_clk_astate nvkm_clk_astate
+#define nouveau_clk_ustate nvkm_clk_ustate
+#define nva3_clk_pre gt215_clk_pre
+#define nva3_clk_post gt215_clk_post
+#define nva3_clk_info gt215_clk_info
+#define nva3_pll_info gt215_pll_info
 
 #endif
index d42a088..f5d3038 100644 (file)
@@ -1,12 +1,9 @@
-#ifndef __NOUVEAU_CLK_H__
-#define __NOUVEAU_CLK_H__
-
-#include <core/device.h>
-#include <core/notify.h>
+#ifndef __NVKM_CLK_H__
+#define __NVKM_CLK_H__
 #include <core/subdev.h>
-
-struct nouveau_pll_vals;
+#include <core/notify.h>
 struct nvbios_pll;
+struct nvkm_pll_vals;
 
 enum nv_clk_src {
        nv_clk_src_crystal,
@@ -50,25 +47,34 @@ enum nv_clk_src {
        nv_clk_src_max,
 };
 
-struct nouveau_cstate {
+struct nvkm_cstate {
        struct list_head head;
        u8  voltage;
        u32 domain[nv_clk_src_max];
 };
 
-struct nouveau_pstate {
+struct nvkm_pstate {
        struct list_head head;
        struct list_head list; /* c-states */
-       struct nouveau_cstate base;
+       struct nvkm_cstate base;
        u8 pstate;
        u8 fanspeed;
 };
 
-struct nouveau_clk {
-       struct nouveau_subdev base;
+struct nvkm_domain {
+       enum nv_clk_src name;
+       u8 bios; /* 0xff for none */
+#define NVKM_CLK_DOM_FLAG_CORE 0x01
+       u8 flags;
+       const char *mname;
+       int mdiv;
+};
 
-       struct nouveau_domain *domains;
-       struct nouveau_pstate bstate;
+struct nvkm_clk {
+       struct nvkm_subdev base;
+
+       struct nvkm_domain *domains;
+       struct nvkm_pstate bstate;
 
        struct list_head states;
        int state_nr;
@@ -88,80 +94,68 @@ struct nouveau_clk {
 
        bool allow_reclock;
 
-       int  (*read)(struct nouveau_clk *, enum nv_clk_src);
-       int  (*calc)(struct nouveau_clk *, struct nouveau_cstate *);
-       int  (*prog)(struct nouveau_clk *);
-       void (*tidy)(struct nouveau_clk *);
+       int  (*read)(struct nvkm_clk *, enum nv_clk_src);
+       int  (*calc)(struct nvkm_clk *, struct nvkm_cstate *);
+       int  (*prog)(struct nvkm_clk *);
+       void (*tidy)(struct nvkm_clk *);
 
        /*XXX: die, these are here *only* to support the completely
-        *     bat-shit insane what-was-nouveau_hw.c code
+        *     bat-shit insane what-was-nvkm_hw.c code
         */
-       int (*pll_calc)(struct nouveau_clk *, struct nvbios_pll *,
-                       int clk, struct nouveau_pll_vals *pv);
-       int (*pll_prog)(struct nouveau_clk *, u32 reg1,
-                       struct nouveau_pll_vals *pv);
+       int (*pll_calc)(struct nvkm_clk *, struct nvbios_pll *, int clk,
+                       struct nvkm_pll_vals *pv);
+       int (*pll_prog)(struct nvkm_clk *, u32 reg1, struct nvkm_pll_vals *pv);
 };
 
-static inline struct nouveau_clk *
-nouveau_clk(void *obj)
+static inline struct nvkm_clk *
+nvkm_clk(void *obj)
 {
-       return (void *)nouveau_subdev(obj, NVDEV_SUBDEV_CLK);
+       return (void *)nvkm_subdev(obj, NVDEV_SUBDEV_CLK);
 }
 
-struct nouveau_domain {
-       enum nv_clk_src name;
-       u8 bios; /* 0xff for none */
-#define NVKM_CLK_DOM_FLAG_CORE 0x01
-       u8 flags;
-       const char *mname;
-       int mdiv;
-};
-
-#define nouveau_clk_create(p,e,o,i,r,s,n,d)                                  \
-       nouveau_clk_create_((p), (e), (o), (i), (r), (s), (n), sizeof(**d),  \
+#define nvkm_clk_create(p,e,o,i,r,s,n,d)                                  \
+       nvkm_clk_create_((p), (e), (o), (i), (r), (s), (n), sizeof(**d),  \
                              (void **)d)
-#define nouveau_clk_destroy(p) ({                                            \
-       struct nouveau_clk *clk = (p);                                       \
-       _nouveau_clk_dtor(nv_object(clk));                                   \
+#define nvkm_clk_destroy(p) ({                                            \
+       struct nvkm_clk *clk = (p);                                       \
+       _nvkm_clk_dtor(nv_object(clk));                                   \
 })
-#define nouveau_clk_init(p) ({                                               \
-       struct nouveau_clk *clk = (p);                                       \
-       _nouveau_clk_init(nv_object(clk));                                   \
+#define nvkm_clk_init(p) ({                                               \
+       struct nvkm_clk *clk = (p);                                       \
+       _nvkm_clk_init(nv_object(clk));                                   \
 })
-#define nouveau_clk_fini(p,s) ({                                             \
-       struct nouveau_clk *clk = (p);                                       \
-       _nouveau_clk_fini(nv_object(clk), (s));                              \
+#define nvkm_clk_fini(p,s) ({                                             \
+       struct nvkm_clk *clk = (p);                                       \
+       _nvkm_clk_fini(nv_object(clk), (s));                              \
 })
 
-int  nouveau_clk_create_(struct nouveau_object *, struct nouveau_object *,
-                          struct nouveau_oclass *,
-                          struct nouveau_domain *, struct nouveau_pstate *,
+int  nvkm_clk_create_(struct nvkm_object *, struct nvkm_object *,
+                          struct nvkm_oclass *,
+                          struct nvkm_domain *, struct nvkm_pstate *,
                           int, bool, int, void **);
-void _nouveau_clk_dtor(struct nouveau_object *);
-int  _nouveau_clk_init(struct nouveau_object *);
-int  _nouveau_clk_fini(struct nouveau_object *, bool);
-
-extern struct nouveau_oclass nv04_clk_oclass;
-extern struct nouveau_oclass nv40_clk_oclass;
-extern struct nouveau_oclass *nv50_clk_oclass;
-extern struct nouveau_oclass *nv84_clk_oclass;
-extern struct nouveau_oclass *nvaa_clk_oclass;
-extern struct nouveau_oclass nva3_clk_oclass;
-extern struct nouveau_oclass nvc0_clk_oclass;
-extern struct nouveau_oclass nve0_clk_oclass;
-extern struct nouveau_oclass gk20a_clk_oclass;
-
-int nv04_clk_pll_set(struct nouveau_clk *, u32 type, u32 freq);
-int nv04_clk_pll_calc(struct nouveau_clk *, struct nvbios_pll *,
-                       int clk, struct nouveau_pll_vals *);
-int nv04_clk_pll_prog(struct nouveau_clk *, u32 reg1,
-                       struct nouveau_pll_vals *);
-int nva3_clk_pll_calc(struct nouveau_clk *, struct nvbios_pll *,
-                       int clk, struct nouveau_pll_vals *);
-
-int nouveau_clk_ustate(struct nouveau_clk *, int req, int pwr);
-int nouveau_clk_astate(struct nouveau_clk *, int req, int rel, bool wait);
-int nouveau_clk_dstate(struct nouveau_clk *, int req, int rel);
-int nouveau_clk_tstate(struct nouveau_clk *, int req, int rel);
-
+void _nvkm_clk_dtor(struct nvkm_object *);
+int  _nvkm_clk_init(struct nvkm_object *);
+int  _nvkm_clk_fini(struct nvkm_object *, bool);
+
+extern struct nvkm_oclass nv04_clk_oclass;
+extern struct nvkm_oclass nv40_clk_oclass;
+extern struct nvkm_oclass *nv50_clk_oclass;
+extern struct nvkm_oclass *g84_clk_oclass;
+extern struct nvkm_oclass *mcp77_clk_oclass;
+extern struct nvkm_oclass gt215_clk_oclass;
+extern struct nvkm_oclass gf100_clk_oclass;
+extern struct nvkm_oclass gk104_clk_oclass;
+extern struct nvkm_oclass gk20a_clk_oclass;
+
+int nv04_clk_pll_set(struct nvkm_clk *, u32 type, u32 freq);
+int nv04_clk_pll_calc(struct nvkm_clk *, struct nvbios_pll *, int clk,
+                     struct nvkm_pll_vals *);
+int nv04_clk_pll_prog(struct nvkm_clk *, u32 reg1, struct nvkm_pll_vals *);
+int gt215_clk_pll_calc(struct nvkm_clk *, struct nvbios_pll *,
+                      int clk, struct nvkm_pll_vals *);
+
+int nvkm_clk_ustate(struct nvkm_clk *, int req, int pwr);
+int nvkm_clk_astate(struct nvkm_clk *, int req, int rel, bool wait);
+int nvkm_clk_dstate(struct nvkm_clk *, int req, int rel);
+int nvkm_clk_tstate(struct nvkm_clk *, int req, int rel);
 #endif
index f6004cc..6dc59ff 100644 (file)
@@ -65,7 +65,7 @@ gm100_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nvd0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gm107_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &gm107_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  gm107_devinit_oclass;
@@ -107,7 +107,7 @@ gm100_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gm107_fuse_oclass;
 #if 0
                /* looks to be some non-trivial changes */
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                /* priv ring says no to 0x10eb14 writes */
                device->oclass[NVDEV_SUBDEV_THERM  ] = &gm107_therm_oclass;
 #endif
index e60deae..9df93c5 100644 (file)
@@ -93,7 +93,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv50_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv50_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -122,7 +122,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv50_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv50_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -151,7 +151,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv50_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv50_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -180,7 +180,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -209,7 +209,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -238,7 +238,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv98_devinit_oclass;
@@ -267,7 +267,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv50_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nv84_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  g84_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv84_devinit_oclass;
@@ -296,7 +296,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nvaa_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  mcp77_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv98_devinit_oclass;
@@ -325,7 +325,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] =  nvaa_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] =  mcp77_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nv84_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nv98_devinit_oclass;
@@ -354,7 +354,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nva3_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gt215_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nva3_devinit_oclass;
@@ -385,7 +385,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nva3_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gt215_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nva3_devinit_oclass;
@@ -415,7 +415,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nva3_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gt215_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nva3_devinit_oclass;
@@ -445,7 +445,7 @@ nv50_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] =  &g80_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nva3_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gt215_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvaf_devinit_oclass;
index 89ff7d0..8d0304f 100644 (file)
@@ -65,7 +65,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -98,7 +98,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -131,7 +131,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -163,7 +163,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -196,7 +196,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -228,7 +228,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -260,7 +260,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nv94_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nv94_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nva3_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -293,7 +293,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nvd0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nvd0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -325,7 +325,7 @@ nvc0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nvd0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  gf117_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nvc0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gf100_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
index 11805f7..9f0efb1 100644 (file)
@@ -65,7 +65,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -99,7 +99,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -133,7 +133,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -189,7 +189,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -223,7 +223,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nvd0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -257,7 +257,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
@@ -290,7 +290,7 @@ nve0_identify(struct nouveau_device *device)
                device->oclass[NVDEV_SUBDEV_GPIO   ] =  nve0_gpio_oclass;
                device->oclass[NVDEV_SUBDEV_I2C    ] =  nve0_i2c_oclass;
                device->oclass[NVDEV_SUBDEV_FUSE   ] = &gf100_fuse_oclass;
-               device->oclass[NVDEV_SUBDEV_CLK    ] = &nve0_clk_oclass;
+               device->oclass[NVDEV_SUBDEV_CLK    ] = &gk104_clk_oclass;
                device->oclass[NVDEV_SUBDEV_THERM  ] = &nvd0_therm_oclass;
                device->oclass[NVDEV_SUBDEV_MXM    ] = &nv50_mxm_oclass;
                device->oclass[NVDEV_SUBDEV_DEVINIT] =  nvc0_devinit_oclass;
index 94d10a9..9c2f688 100644 (file)
@@ -2,11 +2,11 @@ nvkm-y += nvkm/subdev/clk/base.o
 nvkm-y += nvkm/subdev/clk/nv04.o
 nvkm-y += nvkm/subdev/clk/nv40.o
 nvkm-y += nvkm/subdev/clk/nv50.o
-nvkm-y += nvkm/subdev/clk/nv84.o
-nvkm-y += nvkm/subdev/clk/nva3.o
-nvkm-y += nvkm/subdev/clk/nvaa.o
-nvkm-y += nvkm/subdev/clk/nvc0.o
-nvkm-y += nvkm/subdev/clk/nve0.o
+nvkm-y += nvkm/subdev/clk/g84.o
+nvkm-y += nvkm/subdev/clk/gt215.o
+nvkm-y += nvkm/subdev/clk/mcp77.o
+nvkm-y += nvkm/subdev/clk/gf100.o
+nvkm-y += nvkm/subdev/clk/gk104.o
 nvkm-y += nvkm/subdev/clk/gk20a.o
 nvkm-y += nvkm/subdev/clk/pllnv04.o
-nvkm-y += nvkm/subdev/clk/pllnva3.o
+nvkm-y += nvkm/subdev/clk/pllgt215.o
index a0c21ec..adfd3d9 100644 (file)
  *
  * Authors: Ben Skeggs
  */
-
-#include <core/option.h>
-
 #include <subdev/clk.h>
-#include <subdev/therm.h>
-#include <subdev/volt.h>
-#include <subdev/fb.h>
-
 #include <subdev/bios.h>
 #include <subdev/bios/boost.h>
 #include <subdev/bios/cstep.h>
 #include <subdev/bios/perf.h>
+#include <subdev/fb.h>
+#include <subdev/therm.h>
+#include <subdev/volt.h>
+
+#include <core/option.h>
 
 /******************************************************************************
  * misc
  *****************************************************************************/
 static u32
-nouveau_clk_adjust(struct nouveau_clk *clk, bool adjust,
-                    u8 pstate, u8 domain, u32 input)
+nvkm_clk_adjust(struct nvkm_clk *clk, bool adjust,
+               u8 pstate, u8 domain, u32 input)
 {
-       struct nouveau_bios *bios = nouveau_bios(clk);
+       struct nvkm_bios *bios = nvkm_bios(clk);
        struct nvbios_boostE boostE;
        u8  ver, hdr, cnt, len;
        u16 data;
@@ -76,12 +74,11 @@ nouveau_clk_adjust(struct nouveau_clk *clk, bool adjust,
  * C-States
  *****************************************************************************/
 static int
-nouveau_cstate_prog(struct nouveau_clk *clk,
-                   struct nouveau_pstate *pstate, int cstatei)
+nvkm_cstate_prog(struct nvkm_clk *clk, struct nvkm_pstate *pstate, int cstatei)
 {
-       struct nouveau_therm *ptherm = nouveau_therm(clk);
-       struct nouveau_volt *volt = nouveau_volt(clk);
-       struct nouveau_cstate *cstate;
+       struct nvkm_therm *ptherm = nvkm_therm(clk);
+       struct nvkm_volt *volt = nvkm_volt(clk);
+       struct nvkm_cstate *cstate;
        int ret;
 
        if (!list_empty(&pstate->list)) {
@@ -91,7 +88,7 @@ nouveau_cstate_prog(struct nouveau_clk *clk,
        }
 
        if (ptherm) {
-               ret = nouveau_therm_cstate(ptherm, pstate->fanspeed, +1);
+               ret = nvkm_therm_cstate(ptherm, pstate->fanspeed, +1);
                if (ret && ret != -ENODEV) {
                        nv_error(clk, "failed to raise fan speed: %d\n", ret);
                        return ret;
@@ -119,7 +116,7 @@ nouveau_cstate_prog(struct nouveau_clk *clk,
        }
 
        if (ptherm) {
-               ret = nouveau_therm_cstate(ptherm, pstate->fanspeed, -1);
+               ret = nvkm_therm_cstate(ptherm, pstate->fanspeed, -1);
                if (ret && ret != -ENODEV)
                        nv_error(clk, "failed to lower fan speed: %d\n", ret);
        }
@@ -128,19 +125,18 @@ nouveau_cstate_prog(struct nouveau_clk *clk,
 }
 
 static void
-nouveau_cstate_del(struct nouveau_cstate *cstate)
+nvkm_cstate_del(struct nvkm_cstate *cstate)
 {
        list_del(&cstate->head);
        kfree(cstate);
 }
 
 static int
-nouveau_cstate_new(struct nouveau_clk *clk, int idx,
-                  struct nouveau_pstate *pstate)
+nvkm_cstate_new(struct nvkm_clk *clk, int idx, struct nvkm_pstate *pstate)
 {
-       struct nouveau_bios *bios = nouveau_bios(clk);
-       struct nouveau_domain *domain = clk->domains;
-       struct nouveau_cstate *cstate = NULL;
+       struct nvkm_bios *bios = nvkm_bios(clk);
+       struct nvkm_domain *domain = clk->domains;
+       struct nvkm_cstate *cstate = NULL;
        struct nvbios_cstepX cstepX;
        u8  ver, hdr;
        u16 data;
@@ -158,10 +154,8 @@ nouveau_cstate_new(struct nouveau_clk *clk, int idx,
 
        while (domain && domain->name != nv_clk_src_max) {
                if (domain->flags & NVKM_CLK_DOM_FLAG_CORE) {
-                       u32 freq = nouveau_clk_adjust(clk, true,
-                                                       pstate->pstate,
-                                                       domain->bios,
-                                                       cstepX.freq);
+                       u32 freq = nvkm_clk_adjust(clk, true, pstate->pstate,
+                                                  domain->bios, cstepX.freq);
                        cstate->domain[domain->name] = freq;
                }
                domain++;
@@ -175,10 +169,10 @@ nouveau_cstate_new(struct nouveau_clk *clk, int idx,
  * P-States
  *****************************************************************************/
 static int
-nouveau_pstate_prog(struct nouveau_clk *clk, int pstatei)
+nvkm_pstate_prog(struct nvkm_clk *clk, int pstatei)
 {
-       struct nouveau_fb *pfb = nouveau_fb(clk);
-       struct nouveau_pstate *pstate;
+       struct nvkm_fb *pfb = nvkm_fb(clk);
+       struct nvkm_pstate *pstate;
        int ret, idx = 0;
 
        list_for_each_entry(pstate, &clk->states, head) {
@@ -199,13 +193,13 @@ nouveau_pstate_prog(struct nouveau_clk *clk, int pstatei)
                pfb->ram->tidy(pfb);
        }
 
-       return nouveau_cstate_prog(clk, pstate, 0);
+       return nvkm_cstate_prog(clk, pstate, 0);
 }
 
 static void
-nouveau_pstate_work(struct work_struct *work)
+nvkm_pstate_work(struct work_struct *work)
 {
-       struct nouveau_clk *clk = container_of(work, typeof(*clk), work);
+       struct nvkm_clk *clk = container_of(work, typeof(*clk), work);
        int pstate;
 
        if (!atomic_xchg(&clk->waiting, 0))
@@ -227,7 +221,7 @@ nouveau_pstate_work(struct work_struct *work)
 
        nv_trace(clk, "-> %d\n", pstate);
        if (pstate != clk->pstate) {
-               int ret = nouveau_pstate_prog(clk, pstate);
+               int ret = nvkm_pstate_prog(clk, pstate);
                if (ret) {
                        nv_error(clk, "error setting pstate %d: %d\n",
                                 pstate, ret);
@@ -239,7 +233,7 @@ nouveau_pstate_work(struct work_struct *work)
 }
 
 static int
-nouveau_pstate_calc(struct nouveau_clk *clk, bool wait)
+nvkm_pstate_calc(struct nvkm_clk *clk, bool wait)
 {
        atomic_set(&clk->waiting, 1);
        schedule_work(&clk->work);
@@ -249,10 +243,10 @@ nouveau_pstate_calc(struct nouveau_clk *clk, bool wait)
 }
 
 static void
-nouveau_pstate_info(struct nouveau_clk *clk, struct nouveau_pstate *pstate)
+nvkm_pstate_info(struct nvkm_clk *clk, struct nvkm_pstate *pstate)
 {
-       struct nouveau_domain *clock = clk->domains - 1;
-       struct nouveau_cstate *cstate;
+       struct nvkm_domain *clock = clk->domains - 1;
+       struct nvkm_cstate *cstate;
        char info[3][32] = { "", "", "" };
        char name[4] = "--";
        int i = -1;
@@ -291,12 +285,12 @@ nouveau_pstate_info(struct nouveau_clk *clk, struct nouveau_pstate *pstate)
 }
 
 static void
-nouveau_pstate_del(struct nouveau_pstate *pstate)
+nvkm_pstate_del(struct nvkm_pstate *pstate)
 {
-       struct nouveau_cstate *cstate, *temp;
+       struct nvkm_cstate *cstate, *temp;
 
        list_for_each_entry_safe(cstate, temp, &pstate->list, head) {
-               nouveau_cstate_del(cstate);
+               nvkm_cstate_del(cstate);
        }
 
        list_del(&pstate->head);
@@ -304,12 +298,12 @@ nouveau_pstate_del(struct nouveau_pstate *pstate)
 }
 
 static int
-nouveau_pstate_new(struct nouveau_clk *clk, int idx)
+nvkm_pstate_new(struct nvkm_clk *clk, int idx)
 {
-       struct nouveau_bios *bios = nouveau_bios(clk);
-       struct nouveau_domain *domain = clk->domains - 1;
-       struct nouveau_pstate *pstate;
-       struct nouveau_cstate *cstate;
+       struct nvkm_bios *bios = nvkm_bios(clk);
+       struct nvkm_domain *domain = clk->domains - 1;
+       struct nvkm_pstate *pstate;
+       struct nvkm_cstate *cstate;
        struct nvbios_cstepE cstepE;
        struct nvbios_perfE perfE;
        u8  ver, hdr, cnt, len;
@@ -346,10 +340,10 @@ nouveau_pstate_new(struct nouveau_clk *clk, int idx)
                        continue;
 
                if (domain->flags & NVKM_CLK_DOM_FLAG_CORE) {
-                       perfS.v40.freq = nouveau_clk_adjust(clk, false,
-                                                             pstate->pstate,
-                                                             domain->bios,
-                                                             perfS.v40.freq);
+                       perfS.v40.freq = nvkm_clk_adjust(clk, false,
+                                                        pstate->pstate,
+                                                        domain->bios,
+                                                        perfS.v40.freq);
                }
 
                cstate->domain[domain->name] = perfS.v40.freq;
@@ -359,11 +353,11 @@ nouveau_pstate_new(struct nouveau_clk *clk, int idx)
        if (data) {
                int idx = cstepE.index;
                do {
-                       nouveau_cstate_new(clk, idx, pstate);
+                       nvkm_cstate_new(clk, idx, pstate);
                } while(idx--);
        }
 
-       nouveau_pstate_info(clk, pstate);
+       nvkm_pstate_info(clk, pstate);
        list_add_tail(&pstate->head, &clk->states);
        clk->state_nr++;
        return 0;
@@ -373,9 +367,9 @@ nouveau_pstate_new(struct nouveau_clk *clk, int idx)
  * Adjustment triggers
  *****************************************************************************/
 static int
-nouveau_clk_ustate_update(struct nouveau_clk *clk, int req)
+nvkm_clk_ustate_update(struct nvkm_clk *clk, int req)
 {
-       struct nouveau_pstate *pstate;
+       struct nvkm_pstate *pstate;
        int i = 0;
 
        if (!clk->allow_reclock)
@@ -397,7 +391,7 @@ nouveau_clk_ustate_update(struct nouveau_clk *clk, int req)
 }
 
 static int
-nouveau_clk_nstate(struct nouveau_clk *clk, const char *mode, int arglen)
+nvkm_clk_nstate(struct nvkm_clk *clk, const char *mode, int arglen)
 {
        int ret = 1;
 
@@ -410,7 +404,7 @@ nouveau_clk_nstate(struct nouveau_clk *clk, const char *mode, int arglen)
 
                ((char *)mode)[arglen] = '\0';
                if (!kstrtol(mode, 0, &v)) {
-                       ret = nouveau_clk_ustate_update(clk, v);
+                       ret = nvkm_clk_ustate_update(clk, v);
                        if (ret < 0)
                                ret = 1;
                }
@@ -421,53 +415,53 @@ nouveau_clk_nstate(struct nouveau_clk *clk, const char *mode, int arglen)
 }
 
 int
-nouveau_clk_ustate(struct nouveau_clk *clk, int req, int pwr)
+nvkm_clk_ustate(struct nvkm_clk *clk, int req, int pwr)
 {
-       int ret = nouveau_clk_ustate_update(clk, req);
+       int ret = nvkm_clk_ustate_update(clk, req);
        if (ret >= 0) {
                if (ret -= 2, pwr) clk->ustate_ac = ret;
                else               clk->ustate_dc = ret;
-               return nouveau_pstate_calc(clk, true);
+               return nvkm_pstate_calc(clk, true);
        }
        return ret;
 }
 
 int
-nouveau_clk_astate(struct nouveau_clk *clk, int req, int rel, bool wait)
+nvkm_clk_astate(struct nvkm_clk *clk, int req, int rel, bool wait)
 {
        if (!rel) clk->astate  = req;
        if ( rel) clk->astate += rel;
        clk->astate = min(clk->astate, clk->state_nr - 1);
        clk->astate = max(clk->astate, 0);
-       return nouveau_pstate_calc(clk, wait);
+       return nvkm_pstate_calc(clk, wait);
 }
 
 int
-nouveau_clk_tstate(struct nouveau_clk *clk, int req, int rel)
+nvkm_clk_tstate(struct nvkm_clk *clk, int req, int rel)
 {
        if (!rel) clk->tstate  = req;
        if ( rel) clk->tstate += rel;
        clk->tstate = min(clk->tstate, 0);
        clk->tstate = max(clk->tstate, -(clk->state_nr - 1));
-       return nouveau_pstate_calc(clk, true);
+       return nvkm_pstate_calc(clk, true);
 }
 
 int
-nouveau_clk_dstate(struct nouveau_clk *clk, int req, int rel)
+nvkm_clk_dstate(struct nvkm_clk *clk, int req, int rel)
 {
        if (!rel) clk->dstate  = req;
        if ( rel) clk->dstate += rel;
        clk->dstate = min(clk->dstate, clk->state_nr - 1);
        clk->dstate = max(clk->dstate, 0);
-       return nouveau_pstate_calc(clk, true);
+       return nvkm_pstate_calc(clk, true);
 }
 
 static int
-nouveau_clk_pwrsrc(struct nvkm_notify *notify)
+nvkm_clk_pwrsrc(struct nvkm_notify *notify)
 {
-       struct nouveau_clk *clk =
+       struct nvkm_clk *clk =
                container_of(notify, typeof(*clk), pwrsrc_ntfy);
-       nouveau_pstate_calc(clk, false);
+       nvkm_pstate_calc(clk, false);
        return NVKM_NOTIFY_DROP;
 }
 
@@ -476,21 +470,21 @@ nouveau_clk_pwrsrc(struct nvkm_notify *notify)
  *****************************************************************************/
 
 int
-_nouveau_clk_fini(struct nouveau_object *object, bool suspend)
+_nvkm_clk_fini(struct nvkm_object *object, bool suspend)
 {
-       struct nouveau_clk *clk = (void *)object;
+       struct nvkm_clk *clk = (void *)object;
        nvkm_notify_put(&clk->pwrsrc_ntfy);
-       return nouveau_subdev_fini(&clk->base, suspend);
+       return nvkm_subdev_fini(&clk->base, suspend);
 }
 
 int
-_nouveau_clk_init(struct nouveau_object *object)
+_nvkm_clk_init(struct nvkm_object *object)
 {
-       struct nouveau_clk *clk = (void *)object;
-       struct nouveau_domain *clock = clk->domains;
+       struct nvkm_clk *clk = (void *)object;
+       struct nvkm_domain *clock = clk->domains;
        int ret;
 
-       ret = nouveau_subdev_init(&clk->base);
+       ret = nvkm_subdev_init(&clk->base);
        if (ret)
                return ret;
 
@@ -508,47 +502,44 @@ _nouveau_clk_init(struct nouveau_object *object)
                clock++;
        }
 
-       nouveau_pstate_info(clk, &clk->bstate);
+       nvkm_pstate_info(clk, &clk->bstate);
 
        clk->astate = clk->state_nr - 1;
        clk->tstate = 0;
        clk->dstate = 0;
        clk->pstate = -1;
-       nouveau_pstate_calc(clk, true);
+       nvkm_pstate_calc(clk, true);
        return 0;
 }
 
 void
-_nouveau_clk_dtor(struct nouveau_object *object)
+_nvkm_clk_dtor(struct nvkm_object *object)
 {
-       struct nouveau_clk *clk = (void *)object;
-       struct nouveau_pstate *pstate, *temp;
+       struct nvkm_clk *clk = (void *)object;
+       struct nvkm_pstate *pstate, *temp;
 
        nvkm_notify_fini(&clk->pwrsrc_ntfy);
 
        list_for_each_entry_safe(pstate, temp, &clk->states, head) {
-               nouveau_pstate_del(pstate);
+               nvkm_pstate_del(pstate);
        }
 
-       nouveau_subdev_destroy(&clk->base);
+       nvkm_subdev_destroy(&clk->base);
 }
 
 int
-nouveau_clk_create_(struct nouveau_object *parent,
-                     struct nouveau_object *engine,
-                     struct nouveau_oclass *oclass,
-                     struct nouveau_domain *clocks,
-                     struct nouveau_pstate *pstates, int nb_pstates,
-                     bool allow_reclock,
-                     int length, void **object)
+nvkm_clk_create_(struct nvkm_object *parent, struct nvkm_object *engine,
+                struct nvkm_oclass *oclass, struct nvkm_domain *clocks,
+                struct nvkm_pstate *pstates, int nb_pstates,
+                bool allow_reclock, int length, void **object)
 {
-       struct nouveau_device *device = nv_device(parent);
-       struct nouveau_clk *clk;
+       struct nvkm_device *device = nv_device(parent);
+       struct nvkm_clk *clk;
        int ret, idx, arglen;
        const char *mode;
 
-       ret = nouveau_subdev_create_(parent, engine, oclass, 0, "CLK",
-                                    "clock", length, object);
+       ret = nvkm_subdev_create_(parent, engine, oclass, 0, "CLK",
+                                 "clock", length, object);
        clk = *object;
        if (ret)
                return ret;
@@ -558,7 +549,7 @@ nouveau_clk_create_(struct nouveau_object *parent,
        clk->ustate_ac = -1;
        clk->ustate_dc = -1;
 
-       INIT_WORK(&clk->work, nouveau_pstate_work);
+       INIT_WORK(&clk->work, nvkm_pstate_work);
        init_waitqueue_head(&clk->wait);
        atomic_set(&clk->waiting, 0);
 
@@ -566,7 +557,7 @@ nouveau_clk_create_(struct nouveau_object *parent,
        if (!pstates) {
                idx = 0;
                do {
-                       ret = nouveau_pstate_new(clk, idx++);
+                       ret = nvkm_pstate_new(clk, idx++);
                } while (ret == 0);
        } else {
                for (idx = 0; idx < nb_pstates; idx++)
@@ -576,25 +567,24 @@ nouveau_clk_create_(struct nouveau_object *parent,
 
        clk->allow_reclock = allow_reclock;
 
-       ret = nvkm_notify_init(NULL, &device->event, nouveau_clk_pwrsrc, true,
+       ret = nvkm_notify_init(NULL, &device->event, nvkm_clk_pwrsrc, true,
                               NULL, 0, 0, &clk->pwrsrc_ntfy);
        if (ret)
                return ret;
 
-       mode = nouveau_stropt(device->cfgopt, "NvClkMode", &arglen);
+       mode = nvkm_stropt(device->cfgopt, "NvClkMode", &arglen);
        if (mode) {
-               clk->ustate_ac = nouveau_clk_nstate(clk, mode, arglen);
-               clk->ustate_dc = nouveau_clk_nstate(clk, mode, arglen);
+               clk->ustate_ac = nvkm_clk_nstate(clk, mode, arglen);
+               clk->ustate_dc = nvkm_clk_nstate(clk, mode, arglen);
        }
 
-       mode = nouveau_stropt(device->cfgopt, "NvClkModeAC", &arglen);
+       mode = nvkm_stropt(device->cfgopt, "NvClkModeAC", &arglen);
        if (mode)
-               clk->ustate_ac = nouveau_clk_nstate(clk, mode, arglen);
+               clk->ustate_ac = nvkm_clk_nstate(clk, mode, arglen);
 
-       mode = nouveau_stropt(device->cfgopt, "NvClkModeDC", &arglen);
+       mode = nvkm_stropt(device->cfgopt, "NvClkModeDC", &arglen);
        if (mode)
-               clk->ustate_dc = nouveau_clk_nstate(clk, mode, arglen);
-
+               clk->ustate_dc = nvkm_clk_nstate(clk, mode, arglen);
 
        return 0;
 }
  *
  * Authors: Ben Skeggs <bskeggs@redhat.com>
  */
-
 #include "nv50.h"
 
-static struct nouveau_domain
-nv84_domains[] = {
+static struct nvkm_domain
+g84_domains[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
        { nv_clk_src_core   , 0xff, 0, "core", 1000 },
@@ -35,14 +34,14 @@ nv84_domains[] = {
        { nv_clk_src_max }
 };
 
-struct nouveau_oclass *
-nv84_clk_oclass = &(struct nv50_clk_oclass) {
+struct nvkm_oclass *
+g84_clk_oclass = &(struct nv50_clk_oclass) {
        .base.handle = NV_SUBDEV(CLK, 0x84),
-       .base.ofuncs = &(struct nouveau_ofuncs) {
+       .base.ofuncs = &(struct nvkm_ofuncs) {
                .ctor = nv50_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
-       .domains = nv84_domains,
+       .domains = g84_domains,
 }.base;
  *
  * Authors: Ben Skeggs
  */
-
 #include <subdev/clk.h>
+#include "pll.h"
+
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 #include <subdev/timer.h>
 
-#include "pll.h"
-
-struct nvc0_clk_info {
+struct gf100_clk_info {
        u32 freq;
        u32 ssel;
        u32 mdiv;
@@ -38,17 +37,17 @@ struct nvc0_clk_info {
        u32 coef;
 };
 
-struct nvc0_clk_priv {
-       struct nouveau_clk base;
-       struct nvc0_clk_info eng[16];
+struct gf100_clk_priv {
+       struct nvkm_clk base;
+       struct gf100_clk_info eng[16];
 };
 
-static u32 read_div(struct nvc0_clk_priv *, int, u32, u32);
+static u32 read_div(struct gf100_clk_priv *, int, u32, u32);
 
 static u32
-read_vco(struct nvc0_clk_priv *priv, u32 dsrc)
+read_vco(struct gf100_clk_priv *priv, u32 dsrc)
 {
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        u32 ssrc = nv_rd32(priv, dsrc);
        if (!(ssrc & 0x00000100))
                return clk->read(clk, nv_clk_src_sppll0);
@@ -56,9 +55,9 @@ read_vco(struct nvc0_clk_priv *priv, u32 dsrc)
 }
 
 static u32
-read_pll(struct nvc0_clk_priv *priv, u32 pll)
+read_pll(struct gf100_clk_priv *priv, u32 pll)
 {
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        u32 ctrl = nv_rd32(priv, pll + 0x00);
        u32 coef = nv_rd32(priv, pll + 0x04);
        u32 P = (coef & 0x003f0000) >> 16;
@@ -95,7 +94,7 @@ read_pll(struct nvc0_clk_priv *priv, u32 pll)
 }
 
 static u32
-read_div(struct nvc0_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
+read_div(struct gf100_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
 {
        u32 ssrc = nv_rd32(priv, dsrc + (doff * 4));
        u32 sctl = nv_rd32(priv, dctl + (doff * 4));
@@ -121,7 +120,7 @@ read_div(struct nvc0_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
 }
 
 static u32
-read_clk(struct nvc0_clk_priv *priv, int clk)
+read_clk(struct gf100_clk_priv *priv, int clk)
 {
        u32 sctl = nv_rd32(priv, 0x137250 + (clk * 4));
        u32 ssel = nv_rd32(priv, 0x137100);
@@ -145,10 +144,10 @@ read_clk(struct nvc0_clk_priv *priv, int clk)
 }
 
 static int
-nvc0_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+gf100_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
-       struct nouveau_device *device = nv_device(clk);
-       struct nvc0_clk_priv *priv = (void *)clk;
+       struct nvkm_device *device = nv_device(clk);
+       struct gf100_clk_priv *priv = (void *)clk;
 
        switch (src) {
        case nv_clk_src_crystal:
@@ -196,7 +195,7 @@ nvc0_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 }
 
 static u32
-calc_div(struct nvc0_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
+calc_div(struct gf100_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
 {
        u32 div = min((ref * 2) / freq, (u32)65);
        if (div < 2)
@@ -207,7 +206,7 @@ calc_div(struct nvc0_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
 }
 
 static u32
-calc_src(struct nvc0_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
+calc_src(struct gf100_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
 {
        u32 sclk;
 
@@ -236,9 +235,9 @@ calc_src(struct nvc0_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
 }
 
 static u32
-calc_pll(struct nvc0_clk_priv *priv, int clk, u32 freq, u32 *coef)
+calc_pll(struct gf100_clk_priv *priv, int clk, u32 freq, u32 *coef)
 {
-       struct nouveau_bios *bios = nouveau_bios(priv);
+       struct nvkm_bios *bios = nvkm_bios(priv);
        struct nvbios_pll limits;
        int N, M, P, ret;
 
@@ -250,7 +249,7 @@ calc_pll(struct nvc0_clk_priv *priv, int clk, u32 freq, u32 *coef)
        if (!limits.refclk)
                return 0;
 
-       ret = nva3_pll_calc(nv_subdev(priv), &limits, freq, &N, NULL, &M, &P);
+       ret = gt215_pll_calc(nv_subdev(priv), &limits, freq, &N, NULL, &M, &P);
        if (ret <= 0)
                return 0;
 
@@ -259,10 +258,10 @@ calc_pll(struct nvc0_clk_priv *priv, int clk, u32 freq, u32 *coef)
 }
 
 static int
-calc_clk(struct nvc0_clk_priv *priv,
-        struct nouveau_cstate *cstate, int clk, int dom)
+calc_clk(struct gf100_clk_priv *priv,
+        struct nvkm_cstate *cstate, int clk, int dom)
 {
-       struct nvc0_clk_info *info = &priv->eng[clk];
+       struct gf100_clk_info *info = &priv->eng[clk];
        u32 freq = cstate->domain[dom];
        u32 src0, div0, div1D, div1P = 0;
        u32 clk0, clk1 = 0;
@@ -311,9 +310,9 @@ calc_clk(struct nvc0_clk_priv *priv,
 }
 
 static int
-nvc0_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+gf100_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
-       struct nvc0_clk_priv *priv = (void *)clk;
+       struct gf100_clk_priv *priv = (void *)clk;
        int ret;
 
        if ((ret = calc_clk(priv, cstate, 0x00, nv_clk_src_gpc)) ||
@@ -330,9 +329,9 @@ nvc0_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static void
-nvc0_clk_prog_0(struct nvc0_clk_priv *priv, int clk)
+gf100_clk_prog_0(struct gf100_clk_priv *priv, int clk)
 {
-       struct nvc0_clk_info *info = &priv->eng[clk];
+       struct gf100_clk_info *info = &priv->eng[clk];
        if (clk < 7 && !info->ssel) {
                nv_mask(priv, 0x1371d0 + (clk * 0x04), 0x80003f3f, info->ddiv);
                nv_wr32(priv, 0x137160 + (clk * 0x04), info->dsrc);
@@ -340,16 +339,16 @@ nvc0_clk_prog_0(struct nvc0_clk_priv *priv, int clk)
 }
 
 static void
-nvc0_clk_prog_1(struct nvc0_clk_priv *priv, int clk)
+gf100_clk_prog_1(struct gf100_clk_priv *priv, int clk)
 {
        nv_mask(priv, 0x137100, (1 << clk), 0x00000000);
        nv_wait(priv, 0x137100, (1 << clk), 0x00000000);
 }
 
 static void
-nvc0_clk_prog_2(struct nvc0_clk_priv *priv, int clk)
+gf100_clk_prog_2(struct gf100_clk_priv *priv, int clk)
 {
-       struct nvc0_clk_info *info = &priv->eng[clk];
+       struct gf100_clk_info *info = &priv->eng[clk];
        const u32 addr = 0x137000 + (clk * 0x20);
        if (clk <= 7) {
                nv_mask(priv, addr + 0x00, 0x00000004, 0x00000000);
@@ -364,9 +363,9 @@ nvc0_clk_prog_2(struct nvc0_clk_priv *priv, int clk)
 }
 
 static void
-nvc0_clk_prog_3(struct nvc0_clk_priv *priv, int clk)
+gf100_clk_prog_3(struct gf100_clk_priv *priv, int clk)
 {
-       struct nvc0_clk_info *info = &priv->eng[clk];
+       struct gf100_clk_info *info = &priv->eng[clk];
        if (info->ssel) {
                nv_mask(priv, 0x137100, (1 << clk), info->ssel);
                nv_wait(priv, 0x137100, (1 << clk), info->ssel);
@@ -374,24 +373,24 @@ nvc0_clk_prog_3(struct nvc0_clk_priv *priv, int clk)
 }
 
 static void
-nvc0_clk_prog_4(struct nvc0_clk_priv *priv, int clk)
+gf100_clk_prog_4(struct gf100_clk_priv *priv, int clk)
 {
-       struct nvc0_clk_info *info = &priv->eng[clk];
+       struct gf100_clk_info *info = &priv->eng[clk];
        nv_mask(priv, 0x137250 + (clk * 0x04), 0x00003f3f, info->mdiv);
 }
 
 static int
-nvc0_clk_prog(struct nouveau_clk *clk)
+gf100_clk_prog(struct nvkm_clk *clk)
 {
-       struct nvc0_clk_priv *priv = (void *)clk;
+       struct gf100_clk_priv *priv = (void *)clk;
        struct {
-               void (*exec)(struct nvc0_clk_priv *, int);
+               void (*exec)(struct gf100_clk_priv *, int);
        } stage[] = {
-               { nvc0_clk_prog_0 }, /* div programming */
-               { nvc0_clk_prog_1 }, /* select div mode */
-               { nvc0_clk_prog_2 }, /* (maybe) program pll */
-               { nvc0_clk_prog_3 }, /* (maybe) select pll mode */
-               { nvc0_clk_prog_4 }, /* final divider */
+               { gf100_clk_prog_0 }, /* div programming */
+               { gf100_clk_prog_1 }, /* select div mode */
+               { gf100_clk_prog_2 }, /* (maybe) program pll */
+               { gf100_clk_prog_3 }, /* (maybe) select pll mode */
+               { gf100_clk_prog_4 }, /* final divider */
        };
        int i, j;
 
@@ -407,14 +406,14 @@ nvc0_clk_prog(struct nouveau_clk *clk)
 }
 
 static void
-nvc0_clk_tidy(struct nouveau_clk *clk)
+gf100_clk_tidy(struct nvkm_clk *clk)
 {
-       struct nvc0_clk_priv *priv = (void *)clk;
+       struct gf100_clk_priv *priv = (void *)clk;
        memset(priv->eng, 0x00, sizeof(priv->eng));
 }
 
-static struct nouveau_domain
-nvc0_domain[] = {
+static struct nvkm_domain
+gf100_domain[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
        { nv_clk_src_hubk06 , 0x00 },
@@ -430,33 +429,33 @@ nvc0_domain[] = {
 };
 
 static int
-nvc0_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+gf100_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+              struct nvkm_oclass *oclass, void *data, u32 size,
+              struct nvkm_object **pobject)
 {
-       struct nvc0_clk_priv *priv;
+       struct gf100_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nvc0_domain, NULL, 0,
-                                  false, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, gf100_domain,
+                             NULL, 0, false, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
 
-       priv->base.read = nvc0_clk_read;
-       priv->base.calc = nvc0_clk_calc;
-       priv->base.prog = nvc0_clk_prog;
-       priv->base.tidy = nvc0_clk_tidy;
+       priv->base.read = gf100_clk_read;
+       priv->base.calc = gf100_clk_calc;
+       priv->base.prog = gf100_clk_prog;
+       priv->base.tidy = gf100_clk_tidy;
        return 0;
 }
 
-struct nouveau_oclass
-nvc0_clk_oclass = {
+struct nvkm_oclass
+gf100_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0xc0),
-       .ofuncs = &(struct nouveau_ofuncs) {
-               .ctor = nvc0_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+       .ofuncs = &(struct nvkm_ofuncs) {
+               .ctor = gf100_clk_ctor,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
  *
  * Authors: Ben Skeggs
  */
-
 #include <subdev/clk.h>
+#include "pll.h"
+
 #include <subdev/timer.h>
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 
-#include "pll.h"
-
-struct nve0_clk_info {
+struct gk104_clk_info {
        u32 freq;
        u32 ssel;
        u32 mdiv;
@@ -38,16 +37,16 @@ struct nve0_clk_info {
        u32 coef;
 };
 
-struct nve0_clk_priv {
-       struct nouveau_clk base;
-       struct nve0_clk_info eng[16];
+struct gk104_clk_priv {
+       struct nvkm_clk base;
+       struct gk104_clk_info eng[16];
 };
 
-static u32 read_div(struct nve0_clk_priv *, int, u32, u32);
-static u32 read_pll(struct nve0_clk_priv *, u32);
+static u32 read_div(struct gk104_clk_priv *, int, u32, u32);
+static u32 read_pll(struct gk104_clk_priv *, u32);
 
 static u32
-read_vco(struct nve0_clk_priv *priv, u32 dsrc)
+read_vco(struct gk104_clk_priv *priv, u32 dsrc)
 {
        u32 ssrc = nv_rd32(priv, dsrc);
        if (!(ssrc & 0x00000100))
@@ -56,7 +55,7 @@ read_vco(struct nve0_clk_priv *priv, u32 dsrc)
 }
 
 static u32
-read_pll(struct nve0_clk_priv *priv, u32 pll)
+read_pll(struct gk104_clk_priv *priv, u32 pll)
 {
        u32 ctrl = nv_rd32(priv, pll + 0x00);
        u32 coef = nv_rd32(priv, pll + 0x04);
@@ -101,7 +100,7 @@ read_pll(struct nve0_clk_priv *priv, u32 pll)
 }
 
 static u32
-read_div(struct nve0_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
+read_div(struct gk104_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
 {
        u32 ssrc = nv_rd32(priv, dsrc + (doff * 4));
        u32 sctl = nv_rd32(priv, dctl + (doff * 4));
@@ -127,7 +126,7 @@ read_div(struct nve0_clk_priv *priv, int doff, u32 dsrc, u32 dctl)
 }
 
 static u32
-read_mem(struct nve0_clk_priv *priv)
+read_mem(struct gk104_clk_priv *priv)
 {
        switch (nv_rd32(priv, 0x1373f4) & 0x0000000f) {
        case 1: return read_pll(priv, 0x132020);
@@ -138,7 +137,7 @@ read_mem(struct nve0_clk_priv *priv)
 }
 
 static u32
-read_clk(struct nve0_clk_priv *priv, int clk)
+read_clk(struct gk104_clk_priv *priv, int clk)
 {
        u32 sctl = nv_rd32(priv, 0x137250 + (clk * 4));
        u32 sclk, sdiv;
@@ -181,10 +180,10 @@ read_clk(struct nve0_clk_priv *priv, int clk)
 }
 
 static int
-nve0_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+gk104_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
-       struct nouveau_device *device = nv_device(clk);
-       struct nve0_clk_priv *priv = (void *)clk;
+       struct nvkm_device *device = nv_device(clk);
+       struct gk104_clk_priv *priv = (void *)clk;
 
        switch (src) {
        case nv_clk_src_crystal:
@@ -214,7 +213,7 @@ nve0_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 }
 
 static u32
-calc_div(struct nve0_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
+calc_div(struct gk104_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
 {
        u32 div = min((ref * 2) / freq, (u32)65);
        if (div < 2)
@@ -225,7 +224,7 @@ calc_div(struct nve0_clk_priv *priv, int clk, u32 ref, u32 freq, u32 *ddiv)
 }
 
 static u32
-calc_src(struct nve0_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
+calc_src(struct gk104_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
 {
        u32 sclk;
 
@@ -254,9 +253,9 @@ calc_src(struct nve0_clk_priv *priv, int clk, u32 freq, u32 *dsrc, u32 *ddiv)
 }
 
 static u32
-calc_pll(struct nve0_clk_priv *priv, int clk, u32 freq, u32 *coef)
+calc_pll(struct gk104_clk_priv *priv, int clk, u32 freq, u32 *coef)
 {
-       struct nouveau_bios *bios = nouveau_bios(priv);
+       struct nvkm_bios *bios = nvkm_bios(priv);
        struct nvbios_pll limits;
        int N, M, P, ret;
 
@@ -268,7 +267,7 @@ calc_pll(struct nve0_clk_priv *priv, int clk, u32 freq, u32 *coef)
        if (!limits.refclk)
                return 0;
 
-       ret = nva3_pll_calc(nv_subdev(priv), &limits, freq, &N, NULL, &M, &P);
+       ret = gt215_pll_calc(nv_subdev(priv), &limits, freq, &N, NULL, &M, &P);
        if (ret <= 0)
                return 0;
 
@@ -277,10 +276,10 @@ calc_pll(struct nve0_clk_priv *priv, int clk, u32 freq, u32 *coef)
 }
 
 static int
-calc_clk(struct nve0_clk_priv *priv,
-        struct nouveau_cstate *cstate, int clk, int dom)
+calc_clk(struct gk104_clk_priv *priv,
+        struct nvkm_cstate *cstate, int clk, int dom)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        u32 freq = cstate->domain[dom];
        u32 src0, div0, div1D, div1P = 0;
        u32 clk0, clk1 = 0;
@@ -329,9 +328,9 @@ calc_clk(struct nve0_clk_priv *priv,
 }
 
 static int
-nve0_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+gk104_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
-       struct nve0_clk_priv *priv = (void *)clk;
+       struct gk104_clk_priv *priv = (void *)clk;
        int ret;
 
        if ((ret = calc_clk(priv, cstate, 0x00, nv_clk_src_gpc)) ||
@@ -347,9 +346,9 @@ nve0_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static void
-nve0_clk_prog_0(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_0(struct gk104_clk_priv *priv, int clk)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        if (!info->ssel) {
                nv_mask(priv, 0x1371d0 + (clk * 0x04), 0x8000003f, info->ddiv);
                nv_wr32(priv, 0x137160 + (clk * 0x04), info->dsrc);
@@ -357,22 +356,22 @@ nve0_clk_prog_0(struct nve0_clk_priv *priv, int clk)
 }
 
 static void
-nve0_clk_prog_1_0(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_1_0(struct gk104_clk_priv *priv, int clk)
 {
        nv_mask(priv, 0x137100, (1 << clk), 0x00000000);
        nv_wait(priv, 0x137100, (1 << clk), 0x00000000);
 }
 
 static void
-nve0_clk_prog_1_1(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_1_1(struct gk104_clk_priv *priv, int clk)
 {
        nv_mask(priv, 0x137160 + (clk * 0x04), 0x00000100, 0x00000000);
 }
 
 static void
-nve0_clk_prog_2(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_2(struct gk104_clk_priv *priv, int clk)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        const u32 addr = 0x137000 + (clk * 0x20);
        nv_mask(priv, addr + 0x00, 0x00000004, 0x00000000);
        nv_mask(priv, addr + 0x00, 0x00000001, 0x00000000);
@@ -385,9 +384,9 @@ nve0_clk_prog_2(struct nve0_clk_priv *priv, int clk)
 }
 
 static void
-nve0_clk_prog_3(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_3(struct gk104_clk_priv *priv, int clk)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        if (info->ssel)
                nv_mask(priv, 0x137250 + (clk * 0x04), 0x00003f00, info->mdiv);
        else
@@ -395,9 +394,9 @@ nve0_clk_prog_3(struct nve0_clk_priv *priv, int clk)
 }
 
 static void
-nve0_clk_prog_4_0(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_4_0(struct gk104_clk_priv *priv, int clk)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        if (info->ssel) {
                nv_mask(priv, 0x137100, (1 << clk), info->ssel);
                nv_wait(priv, 0x137100, (1 << clk), info->ssel);
@@ -405,9 +404,9 @@ nve0_clk_prog_4_0(struct nve0_clk_priv *priv, int clk)
 }
 
 static void
-nve0_clk_prog_4_1(struct nve0_clk_priv *priv, int clk)
+gk104_clk_prog_4_1(struct gk104_clk_priv *priv, int clk)
 {
-       struct nve0_clk_info *info = &priv->eng[clk];
+       struct gk104_clk_info *info = &priv->eng[clk];
        if (info->ssel) {
                nv_mask(priv, 0x137160 + (clk * 0x04), 0x40000000, 0x40000000);
                nv_mask(priv, 0x137160 + (clk * 0x04), 0x00000100, 0x00000100);
@@ -415,20 +414,20 @@ nve0_clk_prog_4_1(struct nve0_clk_priv *priv, int clk)
 }
 
 static int
-nve0_clk_prog(struct nouveau_clk *clk)
+gk104_clk_prog(struct nvkm_clk *clk)
 {
-       struct nve0_clk_priv *priv = (void *)clk;
+       struct gk104_clk_priv *priv = (void *)clk;
        struct {
                u32 mask;
-               void (*exec)(struct nve0_clk_priv *, int);
+               void (*exec)(struct gk104_clk_priv *, int);
        } stage[] = {
-               { 0x007f, nve0_clk_prog_0   }, /* div programming */
-               { 0x007f, nve0_clk_prog_1_0 }, /* select div mode */
-               { 0xff80, nve0_clk_prog_1_1 },
-               { 0x00ff, nve0_clk_prog_2   }, /* (maybe) program pll */
-               { 0xff80, nve0_clk_prog_3   }, /* final divider */
-               { 0x007f, nve0_clk_prog_4_0 }, /* (maybe) select pll mode */
-               { 0xff80, nve0_clk_prog_4_1 },
+               { 0x007f, gk104_clk_prog_0   }, /* div programming */
+               { 0x007f, gk104_clk_prog_1_0 }, /* select div mode */
+               { 0xff80, gk104_clk_prog_1_1 },
+               { 0x00ff, gk104_clk_prog_2   }, /* (maybe) program pll */
+               { 0xff80, gk104_clk_prog_3   }, /* final divider */
+               { 0x007f, gk104_clk_prog_4_0 }, /* (maybe) select pll mode */
+               { 0xff80, gk104_clk_prog_4_1 },
        };
        int i, j;
 
@@ -446,14 +445,14 @@ nve0_clk_prog(struct nouveau_clk *clk)
 }
 
 static void
-nve0_clk_tidy(struct nouveau_clk *clk)
+gk104_clk_tidy(struct nvkm_clk *clk)
 {
-       struct nve0_clk_priv *priv = (void *)clk;
+       struct gk104_clk_priv *priv = (void *)clk;
        memset(priv->eng, 0x00, sizeof(priv->eng));
 }
 
-static struct nouveau_domain
-nve0_domain[] = {
+static struct nvkm_domain
+gk104_domain[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
        { nv_clk_src_gpc    , 0x00, NVKM_CLK_DOM_FLAG_CORE, "core", 2000 },
@@ -468,33 +467,33 @@ nve0_domain[] = {
 };
 
 static int
-nve0_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+gk104_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+              struct nvkm_oclass *oclass, void *data, u32 size,
+              struct nvkm_object **pobject)
 {
-       struct nve0_clk_priv *priv;
+       struct gk104_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nve0_domain, NULL, 0,
-                                  true, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, gk104_domain,
+                             NULL, 0, true, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
 
-       priv->base.read = nve0_clk_read;
-       priv->base.calc = nve0_clk_calc;
-       priv->base.prog = nve0_clk_prog;
-       priv->base.tidy = nve0_clk_tidy;
+       priv->base.read = gk104_clk_read;
+       priv->base.calc = gk104_clk_calc;
+       priv->base.prog = gk104_clk_prog;
+       priv->base.tidy = gk104_clk_tidy;
        return 0;
 }
 
-struct nouveau_oclass
-nve0_clk_oclass = {
+struct nvkm_oclass
+gk104_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0xe0),
-       .ofuncs = &(struct nouveau_ofuncs) {
-               .ctor = nve0_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+       .ofuncs = &(struct nvkm_ofuncs) {
+               .ctor = gk104_clk_ctor,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
index 4529ba2..94d3839 100644 (file)
  * Shamelessly ripped off from ChromeOS's gk20a/clk_pllg.c
  *
  */
+#include <subdev/clk.h>
+#include <subdev/timer.h>
+
+#ifdef __KERNEL__
+#include <nouveau_platform.h>
+#endif
 
 #define MHZ (1000 * 1000)
 
 #define GPC_BCAST_NDIV_SLOWDOWN_DEBUG_PLL_DYNRAMP_DONE_SYNCED_MASK \
            (0x1 << GPC_BCAST_NDIV_SLOWDOWN_DEBUG_PLL_DYNRAMP_DONE_SYNCED_SHIFT)
 
-#include <subdev/clk.h>
-#include <subdev/timer.h>
-
-#ifdef __KERNEL__
-#include <nouveau_platform.h>
-#endif
-
 static const u8 pl_to_div[] = {
 /* PL:   0, 1, 2, 3, 4, 5, 6,  7,  8,  9, 10, 11, 12, 13, 14 */
 /* p: */ 1, 2, 3, 4, 5, 6, 8, 10, 12, 16, 12, 16, 20, 24, 32,
@@ -117,7 +116,7 @@ static const struct gk20a_clk_pllg_params gk20a_pllg_params = {
 };
 
 struct gk20a_clk_priv {
-       struct nouveau_clk base;
+       struct nvkm_clk base;
        const struct gk20a_clk_pllg_params *params;
        u32 m, n, pl;
        u32 parent_rate;
@@ -260,7 +259,6 @@ found_match:
 
        nv_debug(priv, "actual target freq %d MHz, M %d, N %d, PL %d(div%d)\n",
                 target_freq, priv->m, priv->n, priv->pl, pl_to_div[priv->pl]);
-
        return 0;
 }
 
@@ -402,8 +400,8 @@ _gk20a_pllg_program_mnp(struct gk20a_clk_priv *priv, bool allow_slide)
                nv_wr32(priv, GPCPLL_CFG, val);
        }
 
-       if (!nouveau_timer_wait_eq(priv, 300000, GPCPLL_CFG, GPCPLL_CFG_LOCK,
-                                  GPCPLL_CFG_LOCK)) {
+       if (!nvkm_timer_wait_eq(priv, 300000, GPCPLL_CFG, GPCPLL_CFG_LOCK,
+                               GPCPLL_CFG_LOCK)) {
                nv_error(priv, "%s: timeout waiting for pllg lock\n", __func__);
                return -ETIMEDOUT;
        }
@@ -458,14 +456,14 @@ gk20a_pllg_disable(struct gk20a_clk_priv *priv)
 
 #define GK20A_CLK_GPC_MDIV 1000
 
-static struct nouveau_domain
+static struct nvkm_domain
 gk20a_domains[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_gpc, 0xff, 0, "core", GK20A_CLK_GPC_MDIV },
        { nv_clk_src_max }
 };
 
-static struct nouveau_pstate
+static struct nvkm_pstate
 gk20a_pstates[] = {
        {
                .base = {
@@ -560,7 +558,7 @@ gk20a_pstates[] = {
 };
 
 static int
-gk20a_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+gk20a_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
        struct gk20a_clk_priv *priv = (void *)clk;
 
@@ -577,7 +575,7 @@ gk20a_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 }
 
 static int
-gk20a_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+gk20a_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
        struct gk20a_clk_priv *priv = (void *)clk;
 
@@ -586,7 +584,7 @@ gk20a_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static int
-gk20a_clk_prog(struct nouveau_clk *clk)
+gk20a_clk_prog(struct nvkm_clk *clk)
 {
        struct gk20a_clk_priv *priv = (void *)clk;
 
@@ -594,17 +592,17 @@ gk20a_clk_prog(struct nouveau_clk *clk)
 }
 
 static void
-gk20a_clk_tidy(struct nouveau_clk *clk)
+gk20a_clk_tidy(struct nvkm_clk *clk)
 {
 }
 
 static int
-gk20a_clk_fini(struct nouveau_object *object, bool suspend)
+gk20a_clk_fini(struct nvkm_object *object, bool suspend)
 {
        struct gk20a_clk_priv *priv = (void *)object;
        int ret;
 
-       ret = nouveau_clk_fini(&priv->base, false);
+       ret = nvkm_clk_fini(&priv->base, false);
 
        gk20a_pllg_disable(priv);
 
@@ -612,14 +610,14 @@ gk20a_clk_fini(struct nouveau_object *object, bool suspend)
 }
 
 static int
-gk20a_clk_init(struct nouveau_object *object)
+gk20a_clk_init(struct nvkm_object *object)
 {
        struct gk20a_clk_priv *priv = (void *)object;
        int ret;
 
        nv_mask(priv, GPC2CLK_OUT, GPC2CLK_OUT_INIT_MASK, GPC2CLK_OUT_INIT_VAL);
 
-       ret = nouveau_clk_init(&priv->base);
+       ret = nvkm_clk_init(&priv->base);
        if (ret)
                return ret;
 
@@ -633,9 +631,9 @@ gk20a_clk_init(struct nouveau_object *object)
 }
 
 static int
-gk20a_clk_ctor(struct nouveau_object *parent,  struct nouveau_object *engine,
-                struct nouveau_oclass *oclass, void *data, u32 size,
-                struct nouveau_object **pobject)
+gk20a_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+              struct nvkm_oclass *oclass, void *data, u32 size,
+              struct nvkm_object **pobject)
 {
        struct gk20a_clk_priv *priv;
        struct nouveau_platform_device *plat;
@@ -648,8 +646,9 @@ gk20a_clk_ctor(struct nouveau_object *parent,  struct nouveau_object *engine,
                gk20a_pstates[i].pstate = i + 1;
        }
 
-       ret = nouveau_clk_create(parent, engine, oclass, gk20a_domains,
-                       gk20a_pstates, ARRAY_SIZE(gk20a_pstates), true, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, gk20a_domains,
+                             gk20a_pstates, ARRAY_SIZE(gk20a_pstates),
+                             true, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
@@ -664,16 +663,15 @@ gk20a_clk_ctor(struct nouveau_object *parent,  struct nouveau_object *engine,
        priv->base.calc = gk20a_clk_calc;
        priv->base.prog = gk20a_clk_prog;
        priv->base.tidy = gk20a_clk_tidy;
-
        return 0;
 }
 
-struct nouveau_oclass
+struct nvkm_oclass
 gk20a_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0xea),
-       .ofuncs = &(struct nouveau_ofuncs) {
+       .ofuncs = &(struct nvkm_ofuncs) {
                .ctor = gk20a_clk_ctor,
-               .dtor = _nouveau_subdev_dtor,
+               .dtor = _nvkm_subdev_dtor,
                .init = gk20a_clk_init,
                .fini = gk20a_clk_fini,
        },
  * Authors: Ben Skeggs
  *          Roy Spliet
  */
+#include "gt215.h"
+#include "pll.h"
 
 #include <engine/fifo.h>
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 #include <subdev/timer.h>
 
-#include "pll.h"
-
-#include "nva3.h"
-
-struct nva3_clk_priv {
-       struct nouveau_clk base;
-       struct nva3_clk_info eng[nv_clk_src_max];
+struct gt215_clk_priv {
+       struct nvkm_clk base;
+       struct gt215_clk_info eng[nv_clk_src_max];
 };
 
-static u32 read_clk(struct nva3_clk_priv *, int, bool);
-static u32 read_pll(struct nva3_clk_priv *, int, u32);
+static u32 read_clk(struct gt215_clk_priv *, int, bool);
+static u32 read_pll(struct gt215_clk_priv *, int, u32);
 
 static u32
-read_vco(struct nva3_clk_priv *priv, int clk)
+read_vco(struct gt215_clk_priv *priv, int clk)
 {
        u32 sctl = nv_rd32(priv, 0x4120 + (clk * 4));
 
@@ -58,7 +56,7 @@ read_vco(struct nva3_clk_priv *priv, int clk)
 }
 
 static u32
-read_clk(struct nva3_clk_priv *priv, int clk, bool ignore_en)
+read_clk(struct gt215_clk_priv *priv, int clk, bool ignore_en)
 {
        u32 sctl, sdiv, sclk;
 
@@ -104,7 +102,7 @@ read_clk(struct nva3_clk_priv *priv, int clk, bool ignore_en)
 }
 
 static u32
-read_pll(struct nva3_clk_priv *priv, int clk, u32 pll)
+read_pll(struct gt215_clk_priv *priv, int clk, u32 pll)
 {
        u32 ctrl = nv_rd32(priv, pll + 0);
        u32 sclk = 0, P = 1, N = 1, M = 1;
@@ -130,13 +128,14 @@ read_pll(struct nva3_clk_priv *priv, int clk, u32 pll)
 
        if (M * P)
                return sclk * N / (M * P);
+
        return 0;
 }
 
 static int
-nva3_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+gt215_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
-       struct nva3_clk_priv *priv = (void *)clk;
+       struct gt215_clk_priv *priv = (void *)clk;
        u32 hsrc;
 
        switch (src) {
@@ -176,10 +175,10 @@ nva3_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 }
 
 int
-nva3_clk_info(struct nouveau_clk *clock, int clk, u32 khz,
-               struct nva3_clk_info *info)
+gt215_clk_info(struct nvkm_clk *clock, int clk, u32 khz,
+              struct gt215_clk_info *info)
 {
-       struct nva3_clk_priv *priv = (void *)clock;
+       struct gt215_clk_priv *priv = (void *)clock;
        u32 oclk, sclk, sdiv, diff;
 
        info->clk = 0;
@@ -223,11 +222,11 @@ nva3_clk_info(struct nouveau_clk *clock, int clk, u32 khz,
 }
 
 int
-nva3_pll_info(struct nouveau_clk *clock, int clk, u32 pll, u32 khz,
-               struct nva3_clk_info *info)
+gt215_pll_info(struct nvkm_clk *clock, int clk, u32 pll, u32 khz,
+              struct gt215_clk_info *info)
 {
-       struct nouveau_bios *bios = nouveau_bios(clock);
-       struct nva3_clk_priv *priv = (void *)clock;
+       struct nvkm_bios *bios = nvkm_bios(clock);
+       struct gt215_clk_priv *priv = (void *)clock;
        struct nvbios_pll limits;
        int P, N, M, diff;
        int ret;
@@ -236,7 +235,7 @@ nva3_pll_info(struct nouveau_clk *clock, int clk, u32 pll, u32 khz,
 
        /* If we can get a within [-2, 3) MHz of a divider, we'll disable the
         * PLL and use the divider instead. */
-       ret = nva3_clk_info(clock, clk, khz, info);
+       ret = gt215_clk_info(clock, clk, khz, info);
        diff = khz - ret;
        if (!pll || (diff >= -2000 && diff < 3000)) {
                goto out;
@@ -247,38 +246,37 @@ nva3_pll_info(struct nouveau_clk *clock, int clk, u32 pll, u32 khz,
        if (ret)
                return ret;
 
-       ret = nva3_clk_info(clock, clk - 0x10, limits.refclk, info);
+       ret = gt215_clk_info(clock, clk - 0x10, limits.refclk, info);
        if (ret != limits.refclk)
                return -EINVAL;
 
-       ret = nva3_pll_calc(nv_subdev(priv), &limits, khz, &N, NULL, &M, &P);
+       ret = gt215_pll_calc(nv_subdev(priv), &limits, khz, &N, NULL, &M, &P);
        if (ret >= 0) {
                info->pll = (P << 16) | (N << 8) | M;
        }
 
 out:
        info->fb_delay = max(((khz + 7566) / 15133), (u32) 18);
-
        return ret ? ret : -ERANGE;
 }
 
 static int
-calc_clk(struct nva3_clk_priv *priv, struct nouveau_cstate *cstate,
+calc_clk(struct gt215_clk_priv *priv, struct nvkm_cstate *cstate,
         int clk, u32 pll, int idx)
 {
-       int ret = nva3_pll_info(&priv->base, clk, pll, cstate->domain[idx],
-                                 &priv->eng[idx]);
+       int ret = gt215_pll_info(&priv->base, clk, pll, cstate->domain[idx],
+                                &priv->eng[idx]);
        if (ret >= 0)
                return 0;
        return ret;
 }
 
 static int
-calc_host(struct nva3_clk_priv *priv, struct nouveau_cstate *cstate)
+calc_host(struct gt215_clk_priv *priv, struct nvkm_cstate *cstate)
 {
        int ret = 0;
        u32 kHz = cstate->domain[nv_clk_src_host];
-       struct nva3_clk_info *info = &priv->eng[nv_clk_src_host];
+       struct gt215_clk_info *info = &priv->eng[nv_clk_src_host];
 
        if (kHz == 277000) {
                info->clk = 0;
@@ -288,16 +286,17 @@ calc_host(struct nva3_clk_priv *priv, struct nouveau_cstate *cstate)
 
        info->host_out = NVA3_HOST_CLK;
 
-       ret = nva3_clk_info(&priv->base, 0x1d, kHz, info);
+       ret = gt215_clk_info(&priv->base, 0x1d, kHz, info);
        if (ret >= 0)
                return 0;
+
        return ret;
 }
 
 int
-nva3_clk_pre(struct nouveau_clk *clk, unsigned long *flags)
+gt215_clk_pre(struct nvkm_clk *clk, unsigned long *flags)
 {
-       struct nouveau_fifo *pfifo = nouveau_fifo(clk);
+       struct nvkm_fifo *pfifo = nvkm_fifo(clk);
 
        /* halt and idle execution engines */
        nv_mask(clk, 0x020060, 0x00070000, 0x00000000);
@@ -318,9 +317,9 @@ nva3_clk_pre(struct nouveau_clk *clk, unsigned long *flags)
 }
 
 void
-nva3_clk_post(struct nouveau_clk *clk, unsigned long *flags)
+gt215_clk_post(struct nvkm_clk *clk, unsigned long *flags)
 {
-       struct nouveau_fifo *pfifo = nouveau_fifo(clk);
+       struct nvkm_fifo *pfifo = nvkm_fifo(clk);
 
        if (pfifo && flags)
                pfifo->start(pfifo, flags);
@@ -330,16 +329,16 @@ nva3_clk_post(struct nouveau_clk *clk, unsigned long *flags)
 }
 
 static void
-disable_clk_src(struct nva3_clk_priv *priv, u32 src)
+disable_clk_src(struct gt215_clk_priv *priv, u32 src)
 {
        nv_mask(priv, src, 0x00000100, 0x00000000);
        nv_mask(priv, src, 0x00000001, 0x00000000);
 }
 
 static void
-prog_pll(struct nva3_clk_priv *priv, int clk, u32 pll, int idx)
+prog_pll(struct gt215_clk_priv *priv, int clk, u32 pll, int idx)
 {
-       struct nva3_clk_info *info = &priv->eng[idx];
+       struct gt215_clk_info *info = &priv->eng[idx];
        const u32 src0 = 0x004120 + (clk * 4);
        const u32 src1 = 0x004160 + (clk * 4);
        const u32 ctrl = pll + 0;
@@ -377,16 +376,16 @@ prog_pll(struct nva3_clk_priv *priv, int clk, u32 pll, int idx)
 }
 
 static void
-prog_clk(struct nva3_clk_priv *priv, int clk, int idx)
+prog_clk(struct gt215_clk_priv *priv, int clk, int idx)
 {
-       struct nva3_clk_info *info = &priv->eng[idx];
+       struct gt215_clk_info *info = &priv->eng[idx];
        nv_mask(priv, 0x004120 + (clk * 4), 0x003f3141, 0x00000101 | info->clk);
 }
 
 static void
-prog_host(struct nva3_clk_priv *priv)
+prog_host(struct gt215_clk_priv *priv)
 {
-       struct nva3_clk_info *info = &priv->eng[nv_clk_src_host];
+       struct gt215_clk_info *info = &priv->eng[nv_clk_src_host];
        u32 hsrc = (nv_rd32(priv, 0xc040));
 
        switch (info->host_out) {
@@ -411,9 +410,9 @@ prog_host(struct nva3_clk_priv *priv)
 }
 
 static void
-prog_core(struct nva3_clk_priv *priv, int idx)
+prog_core(struct gt215_clk_priv *priv, int idx)
 {
-       struct nva3_clk_info *info = &priv->eng[idx];
+       struct gt215_clk_info *info = &priv->eng[idx];
        u32 fb_delay = nv_rd32(priv, 0x10002c);
 
        if (fb_delay < info->fb_delay)
@@ -426,10 +425,10 @@ prog_core(struct nva3_clk_priv *priv, int idx)
 }
 
 static int
-nva3_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+gt215_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
-       struct nva3_clk_priv *priv = (void *)clk;
-       struct nva3_clk_info *core = &priv->eng[nv_clk_src_core];
+       struct gt215_clk_priv *priv = (void *)clk;
+       struct gt215_clk_info *core = &priv->eng[nv_clk_src_core];
        int ret;
 
        if ((ret = calc_clk(priv, cstate, 0x10, 0x4200, nv_clk_src_core)) ||
@@ -442,9 +441,9 @@ nva3_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
        /* XXX: Should be reading the highest bit in the VBIOS clock to decide
         * whether to use a PLL or not... but using a PLL defeats the purpose */
        if (core->pll) {
-               ret = nva3_clk_info(clk, 0x10,
-                               cstate->domain[nv_clk_src_core_intm],
-                               &priv->eng[nv_clk_src_core_intm]);
+               ret = gt215_clk_info(clk, 0x10,
+                                    cstate->domain[nv_clk_src_core_intm],
+                                    &priv->eng[nv_clk_src_core_intm]);
                if (ret < 0)
                        return ret;
        }
@@ -453,15 +452,15 @@ nva3_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static int
-nva3_clk_prog(struct nouveau_clk *clk)
+gt215_clk_prog(struct nvkm_clk *clk)
 {
-       struct nva3_clk_priv *priv = (void *)clk;
-       struct nva3_clk_info *core = &priv->eng[nv_clk_src_core];
+       struct gt215_clk_priv *priv = (void *)clk;
+       struct gt215_clk_info *core = &priv->eng[nv_clk_src_core];
        int ret = 0;
        unsigned long flags;
        unsigned long *f = &flags;
 
-       ret = nva3_clk_pre(clk, f);
+       ret = gt215_clk_pre(clk, f);
        if (ret)
                goto out;
 
@@ -478,18 +477,17 @@ out:
        if (ret == -EBUSY)
                f = NULL;
 
-       nva3_clk_post(clk, f);
-
+       gt215_clk_post(clk, f);
        return ret;
 }
 
 static void
-nva3_clk_tidy(struct nouveau_clk *clk)
+gt215_clk_tidy(struct nvkm_clk *clk)
 {
 }
 
-static struct nouveau_domain
-nva3_domain[] = {
+static struct nvkm_domain
+gt215_domain[] = {
        { nv_clk_src_crystal  , 0xff },
        { nv_clk_src_core     , 0x00, 0, "core", 1000 },
        { nv_clk_src_shader   , 0x01, 0, "shader", 1000 },
@@ -502,33 +500,33 @@ nva3_domain[] = {
 };
 
 static int
-nva3_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+gt215_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+              struct nvkm_oclass *oclass, void *data, u32 size,
+              struct nvkm_object **pobject)
 {
-       struct nva3_clk_priv *priv;
+       struct gt215_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nva3_domain, NULL, 0,
-                                  true, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, gt215_domain,
+                             NULL, 0, true, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
 
-       priv->base.read = nva3_clk_read;
-       priv->base.calc = nva3_clk_calc;
-       priv->base.prog = nva3_clk_prog;
-       priv->base.tidy = nva3_clk_tidy;
+       priv->base.read = gt215_clk_read;
+       priv->base.calc = gt215_clk_calc;
+       priv->base.prog = gt215_clk_prog;
+       priv->base.tidy = gt215_clk_tidy;
        return 0;
 }
 
-struct nouveau_oclass
-nva3_clk_oclass = {
+struct nvkm_oclass
+gt215_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0xa3),
-       .ofuncs = &(struct nouveau_ofuncs) {
-               .ctor = nva3_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+       .ofuncs = &(struct nvkm_ofuncs) {
+               .ctor = gt215_clk_ctor,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
diff --git a/drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.h b/drivers/gpu/drm/nouveau/nvkm/subdev/clk/gt215.h
new file mode 100644 (file)
index 0000000..b447d9c
--- /dev/null
@@ -0,0 +1,18 @@
+#ifndef __NVKM_CLK_NVA3_H__
+#define __NVKM_CLK_NVA3_H__
+#include <subdev/clk.h>
+
+struct gt215_clk_info {
+       u32 clk;
+       u32 pll;
+       enum {
+               NVA3_HOST_277,
+               NVA3_HOST_CLK,
+       } host_out;
+       u32 fb_delay;
+};
+
+int  gt215_pll_info(struct nvkm_clk *, int, u32, u32, struct gt215_clk_info *);
+int  gt215_clk_pre(struct nvkm_clk *clk, unsigned long *flags);
+void gt215_clk_post(struct nvkm_clk *clk, unsigned long *flags);
+#endif
  *
  * Authors: Ben Skeggs
  */
+#include "gt215.h"
+#include "pll.h"
 
-#include <engine/fifo.h>
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 #include <subdev/timer.h>
-#include <subdev/clk.h>
-
-#include "nva3.h"
-#include "pll.h"
 
-struct nvaa_clk_priv {
-       struct nouveau_clk base;
+struct mcp77_clk_priv {
+       struct nvkm_clk base;
        enum nv_clk_src csrc, ssrc, vsrc;
        u32 cctrl, sctrl;
        u32 ccoef, scoef;
@@ -41,13 +38,13 @@ struct nvaa_clk_priv {
 };
 
 static u32
-read_div(struct nouveau_clk *clk)
+read_div(struct nvkm_clk *clk)
 {
        return nv_rd32(clk, 0x004600);
 }
 
 static u32
-read_pll(struct nouveau_clk *clk, u32 base)
+read_pll(struct nvkm_clk *clk, u32 base)
 {
        u32 ctrl = nv_rd32(clk, base + 0);
        u32 coef = nv_rd32(clk, base + 4);
@@ -78,9 +75,9 @@ read_pll(struct nouveau_clk *clk, u32 base)
 }
 
 static int
-nvaa_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+mcp77_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
-       struct nvaa_clk_priv *priv = (void *)clk;
+       struct mcp77_clk_priv *priv = (void *)clk;
        u32 mast = nv_rd32(clk, 0x00c054);
        u32 P = 0;
 
@@ -160,12 +157,12 @@ nvaa_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 }
 
 static u32
-calc_pll(struct nvaa_clk_priv *priv, u32 reg,
+calc_pll(struct mcp77_clk_priv *priv, u32 reg,
         u32 clock, int *N, int *M, int *P)
 {
-       struct nouveau_bios *bios = nouveau_bios(priv);
+       struct nvkm_bios *bios = nvkm_bios(priv);
        struct nvbios_pll pll;
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        int ret;
 
        ret = nvbios_pll_parse(bios, reg, &pll);
@@ -199,9 +196,9 @@ calc_P(u32 src, u32 target, int *div)
 }
 
 static int
-nvaa_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+mcp77_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
-       struct nvaa_clk_priv *priv = (void *)clk;
+       struct mcp77_clk_priv *priv = (void *)clk;
        const int shader = cstate->domain[nv_clk_src_shader];
        const int core = cstate->domain[nv_clk_src_core];
        const int vdec = cstate->domain[nv_clk_src_vdec];
@@ -216,8 +213,7 @@ nvaa_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
        /* Calculate clock * 2, so shader clock can use it too */
        clock = calc_pll(priv, 0x4028, (core << 1), &N, &M, &P1);
 
-       if (abs(core - out) <=
-           abs(core - (clock >> 1))) {
+       if (abs(core - out) <= abs(core - (clock >> 1))) {
                priv->csrc = nv_clk_src_hclkm4;
                priv->cctrl = divs << 16;
        } else {
@@ -242,9 +238,8 @@ nvaa_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
                priv->ssrc = nv_clk_src_href;
        } else {
                clock = calc_pll(priv, 0x4020, shader, &N, &M, &P1);
-               if (priv->csrc == nv_clk_src_core) {
+               if (priv->csrc == nv_clk_src_core)
                        out = calc_P((core << 1), shader, &divs);
-               }
 
                if (abs(shader - out) <=
                    abs(shader - clock) &&
@@ -261,8 +256,7 @@ nvaa_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
        /* vclk */
        out = calc_P(core, vdec, &divs);
        clock = calc_P(500000, vdec, &P1);
-       if(abs(vdec - out) <=
-          abs(vdec - clock)) {
+       if(abs(vdec - out) <= abs(vdec - clock)) {
                priv->vsrc = nv_clk_src_cclk;
                priv->vdiv = divs << 16;
        } else {
@@ -297,15 +291,15 @@ nvaa_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static int
-nvaa_clk_prog(struct nouveau_clk *clk)
+mcp77_clk_prog(struct nvkm_clk *clk)
 {
-       struct nvaa_clk_priv *priv = (void *)clk;
+       struct mcp77_clk_priv *priv = (void *)clk;
        u32 pllmask = 0, mast;
        unsigned long flags;
        unsigned long *f = &flags;
        int ret = 0;
 
-       ret = nva3_clk_pre(clk, f);
+       ret = gt215_clk_pre(clk, f);
        if (ret)
                goto out;
 
@@ -382,18 +376,17 @@ out:
        if (ret == -EBUSY)
                f = NULL;
 
-       nva3_clk_post(clk, f);
-
+       gt215_clk_post(clk, f);
        return ret;
 }
 
 static void
-nvaa_clk_tidy(struct nouveau_clk *clk)
+mcp77_clk_tidy(struct nvkm_clk *clk)
 {
 }
 
-static struct nouveau_domain
-nvaa_domains[] = {
+static struct nvkm_domain
+mcp77_domains[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
        { nv_clk_src_core   , 0xff, 0, "core", 1000 },
@@ -403,33 +396,33 @@ nvaa_domains[] = {
 };
 
 static int
-nvaa_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+mcp77_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+              struct nvkm_oclass *oclass, void *data, u32 size,
+              struct nvkm_object **pobject)
 {
-       struct nvaa_clk_priv *priv;
+       struct mcp77_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nvaa_domains, NULL,
-                                  0, true, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, mcp77_domains,
+                             NULL, 0, true, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
 
-       priv->base.read = nvaa_clk_read;
-       priv->base.calc = nvaa_clk_calc;
-       priv->base.prog = nvaa_clk_prog;
-       priv->base.tidy = nvaa_clk_tidy;
+       priv->base.read = mcp77_clk_read;
+       priv->base.calc = mcp77_clk_calc;
+       priv->base.prog = mcp77_clk_prog;
+       priv->base.tidy = mcp77_clk_tidy;
        return 0;
 }
 
-struct nouveau_oclass *
-nvaa_clk_oclass = &(struct nouveau_oclass) {
+struct nvkm_oclass *
+mcp77_clk_oclass = &(struct nvkm_oclass) {
        .handle = NV_SUBDEV(CLK, 0xaa),
-       .ofuncs = &(struct nouveau_ofuncs) {
-               .ctor = nvaa_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+       .ofuncs = &(struct nvkm_ofuncs) {
+               .ctor = mcp77_clk_ctor,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
index de68f2f..63dbbb5 100644 (file)
  *
  * Authors: Ben Skeggs
  */
+#include <subdev/clk.h>
+#include "pll.h"
 
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
-#include <subdev/clk.h>
 #include <subdev/devinit/nv04.h>
 
-#include "pll.h"
-
 struct nv04_clk_priv {
-       struct nouveau_clk base;
+       struct nvkm_clk base;
 };
 
 int
-nv04_clk_pll_calc(struct nouveau_clk *clock, struct nvbios_pll *info,
-                   int clk, struct nouveau_pll_vals *pv)
+nv04_clk_pll_calc(struct nvkm_clk *clock, struct nvbios_pll *info,
+                 int clk, struct nvkm_pll_vals *pv)
 {
        int N1, M1, N2, M2, P;
        int ret = nv04_pll_calc(nv_subdev(clock), info, clk, &N1, &M1, &N2, &M2, &P);
@@ -51,11 +50,10 @@ nv04_clk_pll_calc(struct nouveau_clk *clock, struct nvbios_pll *info,
 }
 
 int
-nv04_clk_pll_prog(struct nouveau_clk *clk, u32 reg1,
-                   struct nouveau_pll_vals *pv)
+nv04_clk_pll_prog(struct nvkm_clk *clk, u32 reg1, struct nvkm_pll_vals *pv)
 {
-       struct nouveau_devinit *devinit = nouveau_devinit(clk);
-       int cv = nouveau_bios(clk)->version.chip;
+       struct nvkm_devinit *devinit = nvkm_devinit(clk);
+       int cv = nvkm_bios(clk)->version.chip;
 
        if (cv == 0x30 || cv == 0x31 || cv == 0x35 || cv == 0x36 ||
            cv >= 0x40) {
@@ -69,21 +67,21 @@ nv04_clk_pll_prog(struct nouveau_clk *clk, u32 reg1,
        return 0;
 }
 
-static struct nouveau_domain
+static struct nvkm_domain
 nv04_domain[] = {
        { nv_clk_src_max }
 };
 
 static int
-nv04_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+nv04_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+             struct nvkm_oclass *oclass, void *data, u32 size,
+             struct nvkm_object **pobject)
 {
        struct nv04_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nv04_domain, NULL, 0,
-                                  false, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, nv04_domain,
+                             NULL, 0, false, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
@@ -93,13 +91,13 @@ nv04_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
        return 0;
 }
 
-struct nouveau_oclass
+struct nvkm_oclass
 nv04_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0x04),
-       .ofuncs = &(struct nouveau_ofuncs) {
+       .ofuncs = &(struct nvkm_ofuncs) {
                .ctor = nv04_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
index 460ca4a..ed83813 100644 (file)
  *
  * Authors: Ben Skeggs
  */
-
 #include <subdev/clk.h>
+#include "pll.h"
+
+#include <core/device.h>
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 
-#include "pll.h"
-
 struct nv40_clk_priv {
-       struct nouveau_clk base;
+       struct nvkm_clk base;
        u32 ctrl;
        u32 npll_ctrl;
        u32 npll_coef;
        u32 spll;
 };
 
-static struct nouveau_domain
+static struct nvkm_domain
 nv40_domain[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
@@ -102,7 +102,7 @@ read_clk(struct nv40_clk_priv *priv, u32 src)
 }
 
 static int
-nv40_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+nv40_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
        struct nv40_clk_priv *priv = (void *)clk;
        u32 mast = nv_rd32(priv, 0x00c040);
@@ -128,9 +128,9 @@ nv40_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 
 static int
 nv40_clk_calc_pll(struct nv40_clk_priv *priv, u32 reg, u32 clk,
-                   int *N1, int *M1, int *N2, int *M2, int *log2P)
+                 int *N1, int *M1, int *N2, int *M2, int *log2P)
 {
-       struct nouveau_bios *bios = nouveau_bios(priv);
+       struct nvkm_bios *bios = nvkm_bios(priv);
        struct nvbios_pll pll;
        int ret;
 
@@ -144,11 +144,12 @@ nv40_clk_calc_pll(struct nv40_clk_priv *priv, u32 reg, u32 clk,
        ret = nv04_pll_calc(nv_subdev(priv), &pll, clk, N1, M1, N2, M2, log2P);
        if (ret == 0)
                return -ERANGE;
+
        return ret;
 }
 
 static int
-nv40_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+nv40_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
        struct nv40_clk_priv *priv = (void *)clk;
        int gclk = cstate->domain[nv_clk_src_core];
@@ -158,7 +159,7 @@ nv40_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 
        /* core/geometric clock */
        ret = nv40_clk_calc_pll(priv, 0x004000, gclk,
-                                &N1, &M1, &N2, &M2, &log2P);
+                               &N1, &M1, &N2, &M2, &log2P);
        if (ret < 0)
                return ret;
 
@@ -173,7 +174,7 @@ nv40_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
        /* use the second pll for shader/rop clock, if it differs from core */
        if (sclk && sclk != gclk) {
                ret = nv40_clk_calc_pll(priv, 0x004008, sclk,
-                                        &N1, &M1, NULL, NULL, &log2P);
+                                       &N1, &M1, NULL, NULL, &log2P);
                if (ret < 0)
                        return ret;
 
@@ -188,7 +189,7 @@ nv40_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static int
-nv40_clk_prog(struct nouveau_clk *clk)
+nv40_clk_prog(struct nvkm_clk *clk)
 {
        struct nv40_clk_priv *priv = (void *)clk;
        nv_mask(priv, 0x00c040, 0x00000333, 0x00000000);
@@ -201,20 +202,20 @@ nv40_clk_prog(struct nouveau_clk *clk)
 }
 
 static void
-nv40_clk_tidy(struct nouveau_clk *clk)
+nv40_clk_tidy(struct nvkm_clk *clk)
 {
 }
 
 static int
-nv40_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+nv40_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+             struct nvkm_oclass *oclass, void *data, u32 size,
+             struct nvkm_object **pobject)
 {
        struct nv40_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, nv40_domain, NULL, 0,
-                                  true, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, nv40_domain,
+                             NULL, 0, true, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
@@ -228,13 +229,13 @@ nv40_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
        return 0;
 }
 
-struct nouveau_oclass
+struct nvkm_oclass
 nv40_clk_oclass = {
        .handle = NV_SUBDEV(CLK, 0x40),
-       .ofuncs = &(struct nouveau_ofuncs) {
+       .ofuncs = &(struct nvkm_ofuncs) {
                .ctor = nv40_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
 };
index 3c462a2..9b4ffd6 100644 (file)
  *
  * Authors: Ben Skeggs
  */
-
-#include <subdev/bios.h>
-#include <subdev/bios/pll.h>
-
 #include "nv50.h"
 #include "pll.h"
 #include "seq.h"
 
+#include <core/device.h>
+#include <subdev/bios.h>
+#include <subdev/bios/pll.h>
+
 static u32
 read_div(struct nv50_clk_priv *priv)
 {
@@ -51,7 +51,7 @@ read_div(struct nv50_clk_priv *priv)
 static u32
 read_pll_src(struct nv50_clk_priv *priv, u32 base)
 {
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        u32 coef, ref = clk->read(clk, nv_clk_src_crystal);
        u32 rsel = nv_rd32(priv, 0x00e18c);
        int P, N, M, id;
@@ -116,13 +116,14 @@ read_pll_src(struct nv50_clk_priv *priv, u32 base)
 
        if (M)
                return (ref * N / M) >> P;
+
        return 0;
 }
 
 static u32
 read_pll_ref(struct nv50_clk_priv *priv, u32 base)
 {
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        u32 src, mast = nv_rd32(priv, 0x00c040);
 
        switch (base) {
@@ -147,13 +148,14 @@ read_pll_ref(struct nv50_clk_priv *priv, u32 base)
 
        if (src)
                return clk->read(clk, nv_clk_src_href);
+
        return read_pll_src(priv, base);
 }
 
 static u32
 read_pll(struct nv50_clk_priv *priv, u32 base)
 {
-       struct nouveau_clk *clk = &priv->base;
+       struct nvkm_clk *clk = &priv->base;
        u32 mast = nv_rd32(priv, 0x00c040);
        u32 ctrl = nv_rd32(priv, base + 0);
        u32 coef = nv_rd32(priv, base + 4);
@@ -162,7 +164,7 @@ read_pll(struct nv50_clk_priv *priv, u32 base)
        int N1, N2, M1, M2;
 
        if (base == 0x004028 && (mast & 0x00100000)) {
-               /* wtf, appears to only disable post-divider on nva0 */
+               /* wtf, appears to only disable post-divider on gt200 */
                if (nv_device(priv)->chipset != 0xa0)
                        return clk->read(clk, nv_clk_src_dom6);
        }
@@ -185,7 +187,7 @@ read_pll(struct nv50_clk_priv *priv, u32 base)
 }
 
 static int
-nv50_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
+nv50_clk_read(struct nvkm_clk *clk, enum nv_clk_src src)
 {
        struct nv50_clk_priv *priv = (void *)clk;
        u32 mast = nv_rd32(priv, 0x00c040);
@@ -318,7 +320,7 @@ nv50_clk_read(struct nouveau_clk *clk, enum nv_clk_src src)
 static u32
 calc_pll(struct nv50_clk_priv *priv, u32 reg, u32 clk, int *N, int *M, int *P)
 {
-       struct nouveau_bios *bios = nouveau_bios(priv);
+       struct nvkm_bios *bios = nvkm_bios(priv);
        struct nvbios_pll pll;
        int ret;
 
@@ -359,7 +361,7 @@ clk_same(u32 a, u32 b)
 }
 
 static int
-nv50_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
+nv50_clk_calc(struct nvkm_clk *clk, struct nvkm_cstate *cstate)
 {
        struct nv50_clk_priv *priv = (void *)clk;
        struct nv50_clk_hwsq *hwsq = &priv->hwsq;
@@ -484,30 +486,30 @@ nv50_clk_calc(struct nouveau_clk *clk, struct nouveau_cstate *cstate)
 }
 
 static int
-nv50_clk_prog(struct nouveau_clk *clk)
+nv50_clk_prog(struct nvkm_clk *clk)
 {
        struct nv50_clk_priv *priv = (void *)clk;
        return clk_exec(&priv->hwsq, true);
 }
 
 static void
-nv50_clk_tidy(struct nouveau_clk *clk)
+nv50_clk_tidy(struct nvkm_clk *clk)
 {
        struct nv50_clk_priv *priv = (void *)clk;
        clk_exec(&priv->hwsq, false);
 }
 
 int
-nv50_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
-               struct nouveau_oclass *oclass, void *data, u32 size,
-               struct nouveau_object **pobject)
+nv50_clk_ctor(struct nvkm_object *parent, struct nvkm_object *engine,
+             struct nvkm_oclass *oclass, void *data, u32 size,
+             struct nvkm_object **pobject)
 {
        struct nv50_clk_oclass *pclass = (void *)oclass;
        struct nv50_clk_priv *priv;
        int ret;
 
-       ret = nouveau_clk_create(parent, engine, oclass, pclass->domains,
-                                  NULL, 0, false, &priv);
+       ret = nvkm_clk_create(parent, engine, oclass, pclass->domains,
+                             NULL, 0, false, &priv);
        *pobject = nv_object(priv);
        if (ret)
                return ret;
@@ -536,7 +538,7 @@ nv50_clk_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
        return 0;
 }
 
-static struct nouveau_domain
+static struct nvkm_domain
 nv50_domains[] = {
        { nv_clk_src_crystal, 0xff },
        { nv_clk_src_href   , 0xff },
@@ -546,14 +548,14 @@ nv50_domains[] = {
        { nv_clk_src_max }
 };
 
-struct nouveau_oclass *
+struct nvkm_oclass *
 nv50_clk_oclass = &(struct nv50_clk_oclass) {
        .base.handle = NV_SUBDEV(CLK, 0x50),
-       .base.ofuncs = &(struct nouveau_ofuncs) {
+       .base.ofuncs = &(struct nvkm_ofuncs) {
                .ctor = nv50_clk_ctor,
-               .dtor = _nouveau_clk_dtor,
-               .init = _nouveau_clk_init,
-               .fini = _nouveau_clk_fini,
+               .dtor = _nvkm_clk_dtor,
+               .init = _nvkm_clk_init,
+               .fini = _nvkm_clk_fini,
        },
        .domains = nv50_domains,
 }.base;
index ae6421f..0ead76a 100644 (file)
@@ -1,7 +1,5 @@
 #ifndef __NVKM_CLK_NV50_H__
 #define __NVKM_CLK_NV50_H__
-
-#include <subdev/bus.h>
 #include <subdev/bus/hwsq.h>
 #include <subdev/clk.h>
 
@@ -15,17 +13,16 @@ struct nv50_clk_hwsq {
 };
 
 struct nv50_clk_priv {
-       struct nouveau_clk base;
+       struct nvkm_clk base;
        struct nv50_clk_hwsq hwsq;
 };
 
-int  nv50_clk_ctor(struct nouveau_object *, struct nouveau_object *,
-                    struct nouveau_oclass *, void *, u32,
-                    struct nouveau_object **);
+int  nv50_clk_ctor(struct nvkm_object *, struct nvkm_object *,
+                    struct nvkm_oclass *, void *, u32,
+                    struct nvkm_object **);
 
 struct nv50_clk_oclass {
-       struct nouveau_oclass base;
-       struct nouveau_domain *domains;
+       struct nvkm_oclass base;
+       struct nvkm_domain *domains;
 };
-
 #endif
diff --git a/drivers/gpu/drm/nouveau/nvkm/subdev/clk/nva3.h b/drivers/gpu/drm/nouveau/nvkm/subdev/clk/nva3.h
deleted file mode 100644 (file)
index ce0fc83..0000000
+++ /dev/null
@@ -1,20 +0,0 @@
-#ifndef __NVKM_CLK_NVA3_H__
-#define __NVKM_CLK_NVA3_H__
-
-#include <subdev/clk.h>
-
-struct nva3_clk_info {
-       u32 clk;
-       u32 pll;
-       enum {
-               NVA3_HOST_277,
-               NVA3_HOST_CLK,
-       } host_out;
-       u32 fb_delay;
-};
-
-int nva3_pll_info(struct nouveau_clk *, int, u32, u32,
-                   struct nva3_clk_info *);
-int nva3_clk_pre(struct nouveau_clk *clk, unsigned long *flags);
-void nva3_clk_post(struct nouveau_clk *clk, unsigned long *flags);
-#endif
index 445b14c..44020a3 100644 (file)
@@ -1,9 +1,11 @@
-#ifndef __NOUVEAU_PLL_H__
-#define __NOUVEAU_PLL_H__
+#ifndef __NVKM_PLL_H__
+#define __NVKM_PLL_H__
+#include <core/os.h>
+struct nvkm_subdev;
+struct nvbios_pll;
 
-int nv04_pll_calc(struct nouveau_subdev *, struct nvbios_pll *, u32 freq,
+int nv04_pll_calc(struct nvkm_subdev *, struct nvbios_pll *, u32 freq,
                  int *N1, int *M1, int *N2, int *M2, int *P);
-int nva3_pll_calc(struct nouveau_subdev *, struct nvbios_pll *, u32 freq,
+int gt215_pll_calc(struct nvkm_subdev *, struct nvbios_pll *, u32 freq,
                  int *N, int *fN, int *M, int *P);
-
 #endif
  *
  * Authors: Ben Skeggs
  */
+#include "pll.h"
 
-#include <subdev/clk.h>
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 
-#include "pll.h"
-
 int
-nva3_pll_calc(struct nouveau_subdev *subdev, struct nvbios_pll *info,
-             u32 freq, int *pN, int *pfN, int *pM, int *P)
+gt215_pll_calc(struct nvkm_subdev *subdev, struct nvbios_pll *info,
+              u32 freq, int *pN, int *pfN, int *pM, int *P)
 {
        u32 best_err = ~0, err;
        int M, lM, hM, N, fN;
index b47d543..f229289 100644 (file)
  * OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  * SOFTWARE.
  */
+#include "pll.h"
 
 #include <subdev/bios.h>
 #include <subdev/bios/pll.h>
 
-#include "pll.h"
-
 static int
-getMNP_single(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
+getMNP_single(struct nvkm_subdev *subdev, struct nvbios_pll *info, int clk,
              int *pN, int *pM, int *pP)
 {
        /* Find M, N and P for a single stage PLL
@@ -38,7 +37,7 @@ getMNP_single(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
         * "clk" parameter in kHz
         * returns calculated clock
         */
-       struct nouveau_bios *bios = nouveau_bios(subdev);
+       struct nvkm_bios *bios = nvkm_bios(subdev);
        int minvco = info->vco1.min_freq, maxvco = info->vco1.max_freq;
        int minM = info->vco1.min_m, maxM = info->vco1.max_m;
        int minN = info->vco1.min_n, maxN = info->vco1.max_n;
@@ -126,7 +125,7 @@ getMNP_single(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
 }
 
 static int
-getMNP_double(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
+getMNP_double(struct nvkm_subdev *subdev, struct nvbios_pll *info, int clk,
              int *pN1, int *pM1, int *pN2, int *pM2, int *pP)
 {
        /* Find M, N and P for a two stage PLL
@@ -137,7 +136,7 @@ getMNP_double(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
         * "clk" parameter in kHz
         * returns calculated clock
         */
-       int chip_version = nouveau_bios(subdev)->version.chip;
+       int chip_version = nvkm_bios(subdev)->version.chip;
        int minvco1 = info->vco1.min_freq, maxvco1 = info->vco1.max_freq;
        int minvco2 = info->vco2.min_freq, maxvco2 = info->vco2.max_freq;
        int minU1 = info->vco1.min_inputfreq, minU2 = info->vco2.min_inputfreq;
@@ -225,7 +224,7 @@ getMNP_double(struct nouveau_subdev *subdev, struct nvbios_pll *info, int clk,
 }
 
 int
-nv04_pll_calc(struct nouveau_subdev *subdev, struct nvbios_pll *info, u32 freq,
+nv04_pll_calc(struct nvkm_subdev *subdev, struct nvbios_pll *info, u32 freq,
              int *N1, int *M1, int *N2, int *M2, int *P)
 {
        int ret;
index fb33f06..d717e8b 100644 (file)
@@ -1,7 +1,5 @@
 #ifndef __NVKM_CLK_SEQ_H__
 #define __NVKM_CLK_SEQ_H__
-
-#include <subdev/bus.h>
 #include <subdev/bus/hwsq.h>
 
 #define clk_init(s,p)       hwsq_init(&(s)->base, (p))
@@ -13,5 +11,4 @@
 #define clk_setf(s,f,d)     hwsq_setf(&(s)->base, (f), (d))
 #define clk_wait(s,f,d)     hwsq_wait(&(s)->base, (f), (d))
 #define clk_nsec(s,n)       hwsq_nsec(&(s)->base, (n))
-
 #endif
index 50e8dee..f3cc7a1 100644 (file)
@@ -30,7 +30,7 @@
 #include <subdev/bios/M0205.h>
 #include <subdev/bios/timing.h>
 
-#include <subdev/clk/nva3.h>
+#include <subdev/clk/gt215.h>
 #include <subdev/clk/pll.h>
 
 #include <subdev/gpio.h>