Commit 61a8b84f authored by Karol Herbst's avatar Karol Herbst Committed by Ben Skeggs

drm/nouveau/clk: Let nvkm_clk_tstate take a temperature value

This way other subdevs can notify the clk subdev about temperature changes
without the need of clk to poll that value.

Also make this function safe to be called from an interrupt handler.
Signed-off-by: default avatarKarol Herbst <karolherbst@gmail.com>
Signed-off-by: default avatarBen Skeggs <bskeggs@redhat.com>
parent 761c8f69
...@@ -94,8 +94,8 @@ struct nvkm_clk { ...@@ -94,8 +94,8 @@ struct nvkm_clk {
int ustate_ac; /* user-requested (-1 disabled, -2 perfmon) */ int ustate_ac; /* user-requested (-1 disabled, -2 perfmon) */
int ustate_dc; /* user-requested (-1 disabled, -2 perfmon) */ int ustate_dc; /* user-requested (-1 disabled, -2 perfmon) */
int astate; /* perfmon adjustment (base) */ int astate; /* perfmon adjustment (base) */
int tstate; /* thermal adjustment (max-) */
int dstate; /* display adjustment (min+) */ int dstate; /* display adjustment (min+) */
u8 temp;
bool allow_reclock; bool allow_reclock;
...@@ -111,7 +111,7 @@ int nvkm_clk_read(struct nvkm_clk *, enum nv_clk_src); ...@@ -111,7 +111,7 @@ int nvkm_clk_read(struct nvkm_clk *, enum nv_clk_src);
int nvkm_clk_ustate(struct nvkm_clk *, int req, int pwr); 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_astate(struct nvkm_clk *, int req, int rel, bool wait);
int nvkm_clk_dstate(struct nvkm_clk *, int req, int rel); int nvkm_clk_dstate(struct nvkm_clk *, int req, int rel);
int nvkm_clk_tstate(struct nvkm_clk *, int req, int rel); int nvkm_clk_tstate(struct nvkm_clk *, u8 temperature);
int nv04_clk_new(struct nvkm_device *, int, struct nvkm_clk **); int nv04_clk_new(struct nvkm_device *, int, struct nvkm_clk **);
int nv40_clk_new(struct nvkm_device *, int, struct nvkm_clk **); int nv40_clk_new(struct nvkm_device *, int, struct nvkm_clk **);
......
...@@ -222,14 +222,14 @@ nvkm_pstate_work(struct work_struct *work) ...@@ -222,14 +222,14 @@ nvkm_pstate_work(struct work_struct *work)
return; return;
clk->pwrsrc = power_supply_is_system_supplied(); clk->pwrsrc = power_supply_is_system_supplied();
nvkm_trace(subdev, "P %d PWR %d U(AC) %d U(DC) %d A %d T %d D %d\n", nvkm_trace(subdev, "P %d PWR %d U(AC) %d U(DC) %d A %d T %d°C D %d\n",
clk->pstate, clk->pwrsrc, clk->ustate_ac, clk->ustate_dc, clk->pstate, clk->pwrsrc, clk->ustate_ac, clk->ustate_dc,
clk->astate, clk->tstate, clk->dstate); clk->astate, clk->temp, clk->dstate);
pstate = clk->pwrsrc ? clk->ustate_ac : clk->ustate_dc; pstate = clk->pwrsrc ? clk->ustate_ac : clk->ustate_dc;
if (clk->state_nr && pstate != -1) { if (clk->state_nr && pstate != -1) {
pstate = (pstate < 0) ? clk->astate : pstate; pstate = (pstate < 0) ? clk->astate : pstate;
pstate = min(pstate, clk->state_nr - 1 + clk->tstate); pstate = min(pstate, clk->state_nr - 1);
pstate = max(pstate, clk->dstate); pstate = max(pstate, clk->dstate);
} else { } else {
pstate = clk->pstate = -1; pstate = clk->pstate = -1;
...@@ -456,13 +456,12 @@ nvkm_clk_astate(struct nvkm_clk *clk, int req, int rel, bool wait) ...@@ -456,13 +456,12 @@ nvkm_clk_astate(struct nvkm_clk *clk, int req, int rel, bool wait)
} }
int int
nvkm_clk_tstate(struct nvkm_clk *clk, int req, int rel) nvkm_clk_tstate(struct nvkm_clk *clk, u8 temp)
{ {
if (!rel) clk->tstate = req; if (clk->temp == temp)
if ( rel) clk->tstate += rel; return 0;
clk->tstate = min(clk->tstate, 0); clk->temp = temp;
clk->tstate = max(clk->tstate, -(clk->state_nr - 1)); return nvkm_pstate_calc(clk, false);
return nvkm_pstate_calc(clk, true);
} }
int int
...@@ -532,9 +531,9 @@ nvkm_clk_init(struct nvkm_subdev *subdev) ...@@ -532,9 +531,9 @@ nvkm_clk_init(struct nvkm_subdev *subdev)
return clk->func->init(clk); return clk->func->init(clk);
clk->astate = clk->state_nr - 1; clk->astate = clk->state_nr - 1;
clk->tstate = 0;
clk->dstate = 0; clk->dstate = 0;
clk->pstate = -1; clk->pstate = -1;
clk->temp = 90; /* reasonable default value */
nvkm_pstate_calc(clk, true); nvkm_pstate_calc(clk, true);
return 0; return 0;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment