[PATCH 2/4] Add adreno430 power control
Emil Velikov
emil.l.velikov at gmail.com
Mon Feb 22 15:28:37 UTC 2016
On 22 February 2016 at 14:51, Rob Clark <robdclark at gmail.com> wrote:
> On Mon, Feb 22, 2016 at 8:46 AM, Emil Velikov <emil.l.velikov at gmail.com> wrote:
>> On 19 February 2016 at 00:50, C Stout <cstout at chromium.org> wrote:
>>> Change-Id: Ife53627e9985e1204cc319da0221338e5272eb81
>>> ---
>>> drivers/gpu/drm/msm/adreno/a4xx_gpu.c | 39 +++++++++++++++++++++++++++++++++--
>>> 1 file changed, 37 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/msm/adreno/a4xx_gpu.c b/drivers/gpu/drm/msm/adreno/a4xx_gpu.c
>>> index 9a1ffec..9aab904 100644
>>> --- a/drivers/gpu/drm/msm/adreno/a4xx_gpu.c
>>> +++ b/drivers/gpu/drm/msm/adreno/a4xx_gpu.c
>>> @@ -552,12 +552,47 @@ static void a4xx_dump(struct msm_gpu *gpu)
>>> adreno_dump(gpu);
>>> }
>>>
>>> +static int a4xx_pm_resume(struct msm_gpu *gpu) {
>>> + struct adreno_gpu *adreno_gpu = to_adreno_gpu(gpu);
>>> + int ret;
>>> +
>>> + ret = msm_gpu_pm_resume(gpu);
>>> + if (ret)
>>> + return ret;
>>> +
>>> + if (adreno_is_a430(adreno_gpu)) {
>>> + unsigned int reg;
>>> + /* Set the default register values; set SW_COLLAPSE to 0 */
>>> + gpu_write(gpu, REG_A4XX_RBBM_POWER_CNTL_IP, 0x778000);
>>> + do {
>>> + udelay(5);
>>> + reg = gpu_read(gpu, REG_A4XX_RBBM_POWER_STATUS);
>>> + } while (!(reg & SP_TP_PWR_ON));
>>> + }
>> Imho wrapping things the opposite way -> include the 430 specifics in
>> msm_gpu_pm_resume/suspend. If needed.
>
> fyi, the reason for the three level "class" hierarchy
> (msm_gpu/adreno/aXYZ) was originally so that we could perhaps some day
> add support for the 2d cores present on some older snapdragons (back
> in the a2xx days). Not sure if we'll ever do this (upstream kernel
> support on those older gen's isn't so much there). But at least right
> now putting that in msm_gpu_pm_resume() isn't really the right thing.
>
Nice one.
>> Hmm is it me or the above register definitions are missing in
>> linux/master and linux/next ? What did you use as a base for the
>> series ?
>
> They are in msm-next:
>
> https://cgit.freedesktop.org/~robclark/linux/log/?h=msm-next
>
> (basically for register definitions, they just need to end up in the
> envytools register database, and then I just regenerate the headers to
> pull in the latest.. that is easier than dealing with merge conflicts
> if everyone just adds the needed regs as part of their patch)
>
For some strange reason git grep did not list them even though
msm-next is part of linux/next.
Thanks for setting me straight Rob, apologies for the noise.
Regards,
Emil
More information about the dri-devel
mailing list