Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 5FF6FC433FE for ; Tue, 23 Nov 2021 05:46:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233108AbhKWFt0 (ORCPT ); Tue, 23 Nov 2021 00:49:26 -0500 Received: from alexa-out-sd-01.qualcomm.com ([199.106.114.38]:52330 "EHLO alexa-out-sd-01.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229471AbhKWFtV (ORCPT ); Tue, 23 Nov 2021 00:49:21 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1637646374; x=1669182374; h=subject:to:cc:references:from:message-id:date: mime-version:in-reply-to:content-transfer-encoding; bh=G2Q/3baeBbeHHtOoLTWKwde73C9ZgthJ6rJb3pEIynw=; b=tQk34Zna6cWEwr3/GLHag9uplLYIYi3+ySUvKYR8CcnaR5wpUKqpCklO waVCJwG28LOwVoS3uezfl7aDQV7C+jEowJuJjRwbueoBudz9Tsqtbk23I YdQMTaiPewSe5q1PUyFtvGqrPn2FdNSVBrWf4ihqbYzYCbzXcGRErRr4b w=; Received: from unknown (HELO ironmsg01-sd.qualcomm.com) ([10.53.140.141]) by alexa-out-sd-01.qualcomm.com with ESMTP; 22 Nov 2021 21:46:14 -0800 X-QCInternal: smtphost Received: from nasanex01c.na.qualcomm.com ([10.47.97.222]) by ironmsg01-sd.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 22 Nov 2021 21:46:13 -0800 Received: from nalasex01a.na.qualcomm.com (10.47.209.196) by nasanex01c.na.qualcomm.com (10.47.97.222) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.922.19; Mon, 22 Nov 2021 21:46:12 -0800 Received: from [10.216.52.57] (10.80.80.8) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.922.19; Mon, 22 Nov 2021 21:46:03 -0800 Subject: Re: [PATCH V2 3/3] thermal: qcom: add support for PMIC5 Gen2 ADCTM To: Jonathan Cameron CC: , , , , , , , , , , , , , , , , , , Thara Gopinath , "Rafael J. Wysocki" , , , , , References: <1635264275-12530-1-git-send-email-quic_jprakash@quicinc.com> <1635264275-12530-4-git-send-email-quic_jprakash@quicinc.com> <20211027190511.23f271e7@jic23-huawei> From: Jishnu Prakash Message-ID: <3e5ea9c4-9d6c-29bb-ea8c-a7c5c287419c@quicinc.com> Date: Tue, 23 Nov 2021 11:15:59 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.6.1 MIME-Version: 1.0 In-Reply-To: <20211027190511.23f271e7@jic23-huawei> Content-Type: text/plain; charset="utf-8"; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01a.na.qualcomm.com (10.47.209.196) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Jonathan, On 10/27/2021 11:35 PM, Jonathan Cameron wrote: > On Tue, 26 Oct 2021 21:34:35 +0530 > Jishnu Prakash wrote: > >> Add support for PMIC5 Gen2 ADC_TM, used on PMIC7 chips. It is a >> close counterpart of PMIC7 ADC and has the same functionality as >> PMIC5 ADC_TM, for threshold monitoring and interrupt generation. >> It is present on PMK8350 alone, like PMIC7 ADC and can be used >> to monitor up to 8 ADC channels, from any of the PMIC7 PMICs >> having ADC on a target, through PBS(Programmable Boot Sequence). >> >> Signed-off-by: Jishnu Prakash > Drive be review as I was looking at the other bits of the series. > Personally I'd prefer to see this as 2 patches, 1st one does > the refactoring and 2nd adds the gen2 specific parts. > > Jonathan > > >> >> struct adc_tm5_chip; >> +struct adc_tm5_channel; >> + >> +struct adc_tm5_data { >> + const u32 full_scale_code_volt; >> + unsigned int *decimation; >> + unsigned int *hw_settle; > Indenting in here is inconsistent. > Personally I'd just stop bothering with the lining everything up. Will fix this in the next post. > >> + int (*disable_channel)(struct adc_tm5_channel *channel); >> + int (*configure)(struct adc_tm5_channel *channel, int low, >> + int high); > Why the line break? It's under 80 chars without it. Will fix this in the next post. > >> + irqreturn_t (*isr)(int irq, void *data); >> + char *irq_name; >> + int gen; >> +}; >> >> /** >> * struct adc_tm5_channel - ADC Thermal Monitoring channel data. >> @@ -100,6 +167,12 @@ struct adc_tm5_chip; >> * @prescale: channel scaling performed on the input signal. >> * @hw_settle_time: the time between AMUX being configured and the >> * start of conversion. >> + * @decimation: sampling rate supported for the channel. >> + * @avg_samples: ability to provide single result from the ADC >> + * that is an average of multiple measurements. >> + * @high_thr_en: channel upper voltage threshold enable state. >> + * @low_thr_en: channel lower voltage threshold enable state. >> + * @meas_en: recurring measurement enable state >> * @iio: IIO channel instance used by this channel. >> * @chip: ADC TM chip instance. >> * @tzd: thermal zone device used by this channel. >> @@ -110,6 +183,11 @@ struct adc_tm5_channel { >> enum adc_tm5_cal_method cal_method; >> unsigned int prescale; >> unsigned int hw_settle_time; >> + unsigned int decimation; /* For Gen2 ADC_TM */ >> + unsigned int avg_samples; /* For Gen2 ADC_TM */ >> + bool high_thr_en; /* For Gen2 ADC_TM */ >> + bool low_thr_en; /* For Gen2 ADC_TM */ >> + bool meas_en; /* For Gen2 ADC_TM */ >> struct iio_channel *iio; >> struct adc_tm5_chip *chip; >> struct thermal_zone_device *tzd; >> @@ -123,9 +201,12 @@ struct adc_tm5_channel { >> * @channels: array of ADC TM channel data. >> * @nchannels: amount of channels defined/allocated >> * @decimation: sampling rate supported for the channel. >> + * Applies to all channels, used only on Gen1 ADC_TM. >> * @avg_samples: ability to provide single result from the ADC >> - * that is an average of multiple measurements. >> + * that is an average of multiple measurements. Applies to all >> + * channels, used only on Gen1 ADC_TM. >> * @base: base address of TM registers. >> + * @adc_mutex_lock: ADC_TM mutex lock. > Not very informative. What is it protecting access to? > Ah. I see this one has already been commented on by Dmitry Will expand this desciption in the next post. > >> */ >> struct adc_tm5_chip { >> struct regmap *regmap; >> @@ -136,14 +217,15 @@ struct adc_tm5_chip { >> unsigned int decimation; >> unsigned int avg_samples; >> u16 base; >> + struct mutex adc_mutex_lock; >> }; >> > ... > >> + >> +static int32_t adc_tm5_gen2_conv_req(struct adc_tm5_chip *chip) >> +{ >> + int ret = 0; > No need to initialise as set in all paths. Will fix this in the next post. > >> + u8 data = 0; >> + unsigned int count; >> + >> + data = ADC_TM_GEN2_EN; >> + ret = adc_tm5_write(chip, ADC_TM_GEN2_EN_CTL1, &data, 1); >> + if (ret < 0) { >> + pr_err("adc-tm enable failed with %d\n", ret); > General mix of pr_err and dev_err. Should all be dev_err unless > they aren't associated with a particular device for some reason. I'll change them all to dev_err in the next post. > >> + return ret; >> + } >> + >> + data = ADC_TM_GEN2_CFG_HS_FLAG; >> + ret = adc_tm5_write(chip, ADC_TM_GEN2_CFG_HS_SET, &data, 1); >> + if (ret < 0) { >> + pr_err("adc-tm handshake failed with %d\n", ret); >> + return ret; >> + } >> + >> + data = ADC_TM_GEN2_CONV_REQ_EN; >> + ret = adc_tm5_write(chip, ADC_TM_GEN2_CONV_REQ, &data, 1); >> + if (ret < 0) { >> + pr_err("adc-tm request conversion failed with %d\n", ret); >> + return ret; >> + } >> + >> + /* >> + * SW sets a handshake bit and waits for PBS to clear it >> + * before the next conversion request can be queued. >> + */ >> + >> + for (count = 0; count < ADC_TM_GEN2_POLL_RETRY_COUNT; count++) { >> + ret = adc_tm5_read(chip, ADC_TM_GEN2_CFG_HS_SET, &data, sizeof(data)); >> + if (ret < 0) { >> + pr_err("adc-tm read failed with %d\n", ret); >> + return ret; >> + } >> + >> + if (!(data & ADC_TM_GEN2_CFG_HS_FLAG)) >> + return ret; >> + usleep_range(ADC_TM_GEN2_POLL_DELAY_MIN_US, >> + ADC_TM_GEN2_POLL_DELAY_MAX_US); >> + } >> + >> + pr_err("adc-tm conversion request handshake timed out\n"); >> + >> + return -ETIMEDOUT; >> +} >> + >> +static int adc_tm5_gen2_disable_channel(struct adc_tm5_channel *channel) >> +{ >> + struct adc_tm5_chip *chip = channel->chip; >> + int ret; >> + u8 val; >> + >> + mutex_lock(&chip->adc_mutex_lock); >> + >> + channel->meas_en = false; >> + channel->high_thr_en = false; >> + channel->low_thr_en = false; >> + >> + ret = adc_tm5_read(chip, ADC_TM_GEN2_CH_CTL, &val, sizeof(val)); >> + if (ret < 0) { >> + pr_err("adc-tm block read failed with %d\n", ret); > Why pr_err rather then dev_err? Will fix this in the next post. > >> + goto disable_fail; >> + } >> + >> + val &= ~ADC_TM_GEN2_TM_CH_SEL; >> + val |= FIELD_PREP(ADC_TM_GEN2_TM_CH_SEL, channel->channel); >> + >> + ret = adc_tm5_write(chip, ADC_TM_GEN2_CH_CTL, &val, 1); >> + if (ret < 0) { >> + dev_err(chip->dev, "adc-tm channel disable failed with %d\n", ret); >> + goto disable_fail; >> + } >> + >> + val = 0; >> + ret = adc_tm5_write(chip, ADC_TM_GEN2_MEAS_IRQ_EN, &val, 1); >> + if (ret < 0) { >> + dev_err(chip->dev, "adc-tm interrupt disable failed with %d\n", ret); >> + goto disable_fail; >> + } >> + >> + >> + ret = adc_tm5_gen2_conv_req(channel->chip); >> + if (ret < 0) >> + dev_err(chip->dev, "adc-tm channel configure failed with %d\n", ret); >> + >> +disable_fail: >> + mutex_unlock(&chip->adc_mutex_lock); >> + return ret; >> +} >> + > ... > >> >> +static const struct adc_tm5_data adc_tm5_data_pmic = { >> + .full_scale_code_volt = 0x70e4, >> + .decimation = (unsigned int []) { 250, 420, 840 }, >> + .hw_settle = (unsigned int []) { 15, 100, 200, 300, 400, 500, 600, 700, >> + 1000, 2000, 4000, 8000, 16000, 32000, >> + 64000, 128000 }, >> + .disable_channel = adc_tm5_disable_channel, >> + .configure = adc_tm5_configure, > This might all look nicer if split into two patches. > 1st of which does the various structure moves and addes the callbacks for the > TM5. 2nd of which introduces the gen2 version of everything. > > Patch 1 would be a noop which is usually easy to tell, and patch 2 would be > clean addition of new code. Yes, I'll split this patch as you recommended in the next post. > >> + .isr = adc_tm5_isr, >> + .irq_name = "pm-adc-tm5", >> + .gen = ADC_TM5, >> +}; >> + Thanks, Jishnu