30 lines
770 B
C
30 lines
770 B
C
|
/* SPDX-License-Identifier: MIT */
|
||
|
#ifndef __NV50_CLK_H__
|
||
|
#define __NV50_CLK_H__
|
||
|
#define nv50_clk(p) container_of((p), struct nv50_clk, base)
|
||
|
#include "priv.h"
|
||
|
|
||
|
#include <subdev/bus/hwsq.h>
|
||
|
|
||
|
struct nv50_clk_hwsq {
|
||
|
struct hwsq base;
|
||
|
struct hwsq_reg r_fifo;
|
||
|
struct hwsq_reg r_spll[2];
|
||
|
struct hwsq_reg r_nvpll[2];
|
||
|
struct hwsq_reg r_divs;
|
||
|
struct hwsq_reg r_mast;
|
||
|
};
|
||
|
|
||
|
struct nv50_clk {
|
||
|
struct nvkm_clk base;
|
||
|
struct nv50_clk_hwsq hwsq;
|
||
|
};
|
||
|
|
||
|
int nv50_clk_new_(const struct nvkm_clk_func *, struct nvkm_device *, enum nvkm_subdev_type, int,
|
||
|
bool, struct nvkm_clk **);
|
||
|
int nv50_clk_read(struct nvkm_clk *, enum nv_clk_src);
|
||
|
int nv50_clk_calc(struct nvkm_clk *, struct nvkm_cstate *);
|
||
|
int nv50_clk_prog(struct nvkm_clk *);
|
||
|
void nv50_clk_tidy(struct nvkm_clk *);
|
||
|
#endif
|