Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp388376pxj; Wed, 2 Jun 2021 01:29:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzirA9kGtbg8BuazbFVEIsq7LSsQN+GCXO01O4LsJsbW1MZ++ZPq1Q6Uv3SC0Qf3qgVhfNE X-Received: by 2002:aa7:cb02:: with SMTP id s2mr36960861edt.67.1622622568670; Wed, 02 Jun 2021 01:29:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1622622568; cv=none; d=google.com; s=arc-20160816; b=LAkaEmVko80Ajp/ZhCLDcCFbbUjB95qL8RCDAVOpQp465NrkXm/0CzTWufI5joIiUd PcdqxFG+rXnV5/ad2hgP/5wA2WerxqxaKy+InVMJDJJuQuLhASSx9hVPzqhgqx0vxeMl 1mI/vLVM8ISWh3/hiabKkqSW9MrC0x+2RRbOogiHiHlXX8aHyj5QCmF/MTai+Dq8cUHt ETpDbTtcl/FTZF6El/C+xlmCwprtkSLuQ5dbXqp80ke9kJNUf7asIUU41TZpE6njYbAl HOIyko7Dm9J7+FJDA0caAWnnqhcyn2Uf7aAArLQf3sGDofzxngV+0IpYxs6fFPUvee/j X9hQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:content-transfer-encoding :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=R9/y5IYzZfRPi/Fhac+yR1YulSNV9LadEvMh90LaCeo=; b=NAFl6b/sChT64Ff96XwrpbBP4oLuj+OJIGCWfaYdhDLmwvI1DqJwTDwseymTPmMx9q qbIYHqGaCws53lWUD2tlT8s+4VnXQTkO5WKYNgpyWiRK19XOCT20y1XTIQb2g+Li+jVv YC9xokj1ikGnUIB1WqSXGp1qyXXb+Dm0asyNSLFx6aK4/aKya5SLUc6q6KuCH8rm4O4g cvEIG72IJFU88wXI0yxU95FAqGMjaAnjFI1rGGixAaEpyGV7XyuGFz0lDBc36dW8wXLd n+DgUsoqw9qEKRDENiafFBFgq1EPayrMJF2Akl5cAma5HbNc4sWeExsWcIdEijS1kWoE z/UQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=fNktISO3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y13si1725195edp.239.2021.06.02.01.29.04; Wed, 02 Jun 2021 01:29:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=fNktISO3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229571AbhFBGnl (ORCPT + 99 others); Wed, 2 Jun 2021 02:43:41 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44572 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231538AbhFBGnb (ORCPT ); Wed, 2 Jun 2021 02:43:31 -0400 Received: from mail-lj1-x234.google.com (mail-lj1-x234.google.com [IPv6:2a00:1450:4864:20::234]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8B8F8C061756 for ; Tue, 1 Jun 2021 23:41:35 -0700 (PDT) Received: by mail-lj1-x234.google.com with SMTP id e11so1148966ljn.13 for ; Tue, 01 Jun 2021 23:41:35 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-transfer-encoding:content-language; bh=R9/y5IYzZfRPi/Fhac+yR1YulSNV9LadEvMh90LaCeo=; b=fNktISO3ADDDsqDFNCHQNvS3oGdIRn90B+HEZhYWQIOATUmuiqRmBFT/MYEXvpeILU 4C+xjCwTKEj9/is8jhqvBxyfJtuRVUEvzhRGsilHbsXkyaGn8Lu9EuCxobg+OhaqOpGX lWhUWqJo/fubku/juKeHOhh/KbKp8HBlRYJcaj8QzvCC3SFQcvkGSBmMyt/KEBu+ulaP ggV4lU2XPaz1kzNDBxYkfIYRtiZLbvC8G1Am5Q2YHOU+pB9g9LTdC5Ht8nYAxrP9QFXk Nt6dHOjNKPseUN/43FwZag3PUV8JuU8QfTxiNZEdmhWh/M6Ogz/dswY4Z5dgsl6Zh93G R84w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-transfer-encoding :content-language; bh=R9/y5IYzZfRPi/Fhac+yR1YulSNV9LadEvMh90LaCeo=; b=Wk5FN+/VfObk/meJtb/ZJm8eMeWnWSRClu0sVixRczeI6zgQWJnlgZeT7pfxYmE9l3 4NbEKc40A7iGdldCOeki39pO9BFymLxDPHPiiBtTAMvLcRrbdioBno4VijhgWzgnA6YQ pqx+dP/huXSWPGugNGiZBSZ9xon8+YFSjpzyemBZzMBw99jO0GsKeT627Jn+Q+qISM9H V+Zxc80C1GgvQps9ODCapFhUGhSt9y5WeKnDCVp6cWUDHSKQlPkCITRuKQnz8nwVy6jI lrNzaNuq48QExIIC5PryhUcxVeO+/DU7nJ2TEYjDVbmrwhnTtiV3XayyJyvNj2jlCh5K dWlg== X-Gm-Message-State: AOAM533p/vsTpNzpjGp0Gmk+2x/7EBI49GavDt4gq3VCK0dmJJEQsCdB xqYhAca53C7xNJ/MQc3gMYQ= X-Received: by 2002:a2e:9182:: with SMTP id f2mr12972872ljg.223.1622616093901; Tue, 01 Jun 2021 23:41:33 -0700 (PDT) Received: from ?IPv6:2a02:908:1252:fb60:cd07:2759:3eec:1d00? ([2a02:908:1252:fb60:cd07:2759:3eec:1d00]) by smtp.gmail.com with ESMTPSA id q7sm581480ljm.109.2021.06.01.23.41.32 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 01 Jun 2021 23:41:33 -0700 (PDT) Subject: Re: [PATCH -next] drm/radeon/radeon_pm: use DEVICE_ATTR_RW macro To: Alex Deucher , YueHaibing Cc: Dave Airlie , xinhui pan , LKML , Maling list - DRI developers , amd-gfx list , Daniel Vetter , "Deucher, Alexander" , Christian Koenig References: <20210528070217.9204-1-yuehaibing@huawei.com> From: =?UTF-8?Q?Christian_K=c3=b6nig?= Message-ID: <39b4c939-9f40-3e44-13d8-f98b01808d05@gmail.com> Date: Wed, 2 Jun 2021 08:41:31 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.8.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Am 02.06.21 um 03:53 schrieb Alex Deucher: > On Fri, May 28, 2021 at 3:18 AM YueHaibing wrote: >> Use DEVICE_ATTR_RW() helper instead of plain DEVICE_ATTR(), >> which makes the code a bit shorter and easier to read. >> >> Signed-off-by: YueHaibing > I'm not convinced this really buys us anything other than code churn, > but I don't have a particularly strong opinion of others feel > differently. I agree, especially dropping the amdgpu prefix from the functions doesn't sound like something we want. Christian. > > Alex > > >> --- >> drivers/gpu/drm/radeon/radeon_pm.c | 56 ++++++++++++------------------ >> 1 file changed, 23 insertions(+), 33 deletions(-) >> >> diff --git a/drivers/gpu/drm/radeon/radeon_pm.c b/drivers/gpu/drm/radeon/radeon_pm.c >> index 3861c0b98fcf..edf10cc3947e 100644 >> --- a/drivers/gpu/drm/radeon/radeon_pm.c >> +++ b/drivers/gpu/drm/radeon/radeon_pm.c >> @@ -352,9 +352,8 @@ static void radeon_pm_print_states(struct radeon_device *rdev) >> } >> } >> >> -static ssize_t radeon_get_pm_profile(struct device *dev, >> - struct device_attribute *attr, >> - char *buf) >> +static ssize_t power_profile_show(struct device *dev, >> + struct device_attribute *attr, char *buf) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -366,10 +365,8 @@ static ssize_t radeon_get_pm_profile(struct device *dev, >> (cp == PM_PROFILE_HIGH) ? "high" : "default"); >> } >> >> -static ssize_t radeon_set_pm_profile(struct device *dev, >> - struct device_attribute *attr, >> - const char *buf, >> - size_t count) >> +static ssize_t power_profile_store(struct device *dev, struct device_attribute *attr, >> + const char *buf, size_t count) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -406,9 +403,8 @@ static ssize_t radeon_set_pm_profile(struct device *dev, >> return count; >> } >> >> -static ssize_t radeon_get_pm_method(struct device *dev, >> - struct device_attribute *attr, >> - char *buf) >> +static ssize_t power_method_show(struct device *dev, >> + struct device_attribute *attr, char *buf) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -418,10 +414,9 @@ static ssize_t radeon_get_pm_method(struct device *dev, >> (pm == PM_METHOD_PROFILE) ? "profile" : "dpm"); >> } >> >> -static ssize_t radeon_set_pm_method(struct device *dev, >> - struct device_attribute *attr, >> - const char *buf, >> - size_t count) >> +static ssize_t power_method_store(struct device *dev, >> + struct device_attribute *attr, >> + const char *buf, size_t count) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -462,9 +457,8 @@ static ssize_t radeon_set_pm_method(struct device *dev, >> return count; >> } >> >> -static ssize_t radeon_get_dpm_state(struct device *dev, >> - struct device_attribute *attr, >> - char *buf) >> +static ssize_t power_dpm_state_show(struct device *dev, >> + struct device_attribute *attr, char *buf) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -475,10 +469,9 @@ static ssize_t radeon_get_dpm_state(struct device *dev, >> (pm == POWER_STATE_TYPE_BALANCED) ? "balanced" : "performance"); >> } >> >> -static ssize_t radeon_set_dpm_state(struct device *dev, >> - struct device_attribute *attr, >> - const char *buf, >> - size_t count) >> +static ssize_t power_dpm_state_store(struct device *dev, >> + struct device_attribute *attr, >> + const char *buf, size_t count) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -506,9 +499,9 @@ static ssize_t radeon_set_dpm_state(struct device *dev, >> return count; >> } >> >> -static ssize_t radeon_get_dpm_forced_performance_level(struct device *dev, >> - struct device_attribute *attr, >> - char *buf) >> +static ssize_t power_dpm_force_performance_level_show(struct device *dev, >> + struct device_attribute *attr, >> + char *buf) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -523,10 +516,9 @@ static ssize_t radeon_get_dpm_forced_performance_level(struct device *dev, >> (level == RADEON_DPM_FORCED_LEVEL_LOW) ? "low" : "high"); >> } >> >> -static ssize_t radeon_set_dpm_forced_performance_level(struct device *dev, >> +static ssize_t power_dpm_force_performance_level_store(struct device *dev, >> struct device_attribute *attr, >> - const char *buf, >> - size_t count) >> + const char *buf, size_t count) >> { >> struct drm_device *ddev = dev_get_drvdata(dev); >> struct radeon_device *rdev = ddev->dev_private; >> @@ -658,12 +650,10 @@ static ssize_t radeon_hwmon_get_pwm1(struct device *dev, >> return sprintf(buf, "%i\n", speed); >> } >> >> -static DEVICE_ATTR(power_profile, S_IRUGO | S_IWUSR, radeon_get_pm_profile, radeon_set_pm_profile); >> -static DEVICE_ATTR(power_method, S_IRUGO | S_IWUSR, radeon_get_pm_method, radeon_set_pm_method); >> -static DEVICE_ATTR(power_dpm_state, S_IRUGO | S_IWUSR, radeon_get_dpm_state, radeon_set_dpm_state); >> -static DEVICE_ATTR(power_dpm_force_performance_level, S_IRUGO | S_IWUSR, >> - radeon_get_dpm_forced_performance_level, >> - radeon_set_dpm_forced_performance_level); >> +static DEVICE_ATTR_RW(power_profile); >> +static DEVICE_ATTR_RW(power_method); >> +static DEVICE_ATTR_RW(power_dpm_state); >> +static DEVICE_ATTR_RW(power_dpm_force_performance_level); >> >> static ssize_t radeon_hwmon_show_temp(struct device *dev, >> struct device_attribute *attr, >> -- >> 2.17.1 >> > _______________________________________________ > amd-gfx mailing list > amd-gfx@lists.freedesktop.org > https://lists.freedesktop.org/mailman/listinfo/amd-gfx