From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mail-wr1-f50.google.com (mail-wr1-f50.google.com [209.85.221.50]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 49858481CD for ; Fri, 7 Nov 2025 11:36:18 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.221.50 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1762515380; cv=none; b=lcwqnOpzZxbtT16Jbi4d8ASy31o9Lp+HJUUvl9Bw1EKvqAdQhll/KBWWBQSD1GtqjBZcjXM/xskZYEHOkAAP0ZQMowKIHCMPG5Ee/KxuC6+nTinLEkXR3E/FMAc/8LDsxBg1frKv04fndQnRAcc9MCIK1MmB8tfEmovwq7ouRW4= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1762515380; c=relaxed/simple; bh=zc7EQnNjmRr1XU6lGykGKLz8scv8SLWTjQFPhZxkdgc=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=sKF+e7zJgH+wdL4kRr87WZXheuo2RMSNfo4aq7rs5MIszPROQT86gfI7dvmFeAU8bGkpM5nRMNQu/zjoimU9ni1W8xWAJ2WKN2wWi97HBRT+xc8GYxsHfNlZA1LXSceQZj5rmvdwUrXsB45Dds9xC9JWAVftrKnyCDDv441HFQU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org; spf=pass smtp.mailfrom=linaro.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b=hMK24NHU; arc=none smtp.client-ip=209.85.221.50 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=linaro.org Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=linaro.org Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=linaro.org header.i=@linaro.org header.b="hMK24NHU" Received: by mail-wr1-f50.google.com with SMTP id ffacd0b85a97d-429c7869704so517884f8f.2 for ; Fri, 07 Nov 2025 03:36:18 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; t=1762515376; x=1763120176; darn=vger.kernel.org; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :from:to:cc:subject:date:message-id:reply-to; bh=9JTGRP3Os3ULo6Z7owLq7b27T5LEh91I3qkDXn2bT8s=; b=hMK24NHU9ASeLfzpQwXI3mQ8ZPbx7MZzgknsb9/jUcllKOnHSJMpNqq1Gutemwp9DL IjTBCWNdyASJ+ZPC5Il0NrujHNNdbHBvUaI2DpY7scAH5L/GrH1H3P9mYQjocu49JrLK rfYAsKcMGleMOQVdueBwIlwybFNIwHRzKFSD381oJHW9BEOqPnCEX4V22YOkPSY8+r/o j8R932bX3JTTMvFJcbvOV72tDp/JwnhDp3ozgWthc6o81SyfIfvkdmIVc9XvoxPR6dIw CEHa5yGtkSgDYxj2TV0qoiJ+7ngzujYV5NoH9cjeZdiDCrElDZK0YSlqA0/R2qSzws7V TbLg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1762515376; x=1763120176; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-gg:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=9JTGRP3Os3ULo6Z7owLq7b27T5LEh91I3qkDXn2bT8s=; b=qd373FqalODoOi85BINvTgzKCkOrR9byk0RzHRqnDHtqdRaqnWkHSi0Dr1RmBc6VH+ saZr9JZz1podTsjTgzukzAdCZfhuR4scJk+H6Eejtr90d+uer+jH5oLxrgZMt89/5bDL tZam/Aya4UQKGaWnbkKMwGu5lxHddGQa3PDJ7It4GWmGV1nx/1kpuqIKRQDLoaozWlj8 6M3sn83Dp2KodZ5SeOT0O5CyeDcukRetPk36xMvZ47TNp1B4taVccP+bFU7E5+BFCXuT PpaJXpaGaGj6lj2Lo5aKjyTFtt85TZ+NHenM+y5vroLUUXBtf3a2C19ka3/slOyaWb6D uUew== X-Forwarded-Encrypted: i=1; AJvYcCXvWIh04KtmY2XsIavGoRzsr7PlMNfGJ6BEw7/toHa7jPPl65E8QHssbk4d2Gh0aNWbudeH5GY/x/aB@vger.kernel.org X-Gm-Message-State: AOJu0YxiRJ5RpVEE6A8XzoPLUfAEwcy4BJq1Kd8UqOteaL+p7IL1SQj2 HlWLt+JKypA5TmNwCI2DRbOHSjmF5xsPs4VBqkI9x/ebvBNHYdpn+tsX038ncg5hB3U= X-Gm-Gg: ASbGncvtO+0qATDQc8HBU++9Uk8DGaeGkZudOBy4ksh5jlyfv1HonhHK9THV3cVXxYH QaBFdtNvaJcig/+WBosEuMz6o14DHHYKo0oQBk7a3dX4lrbVQdGYUpmW0sxKG5C+9rKU6nkYkqw 3gdkk4HvaeNmHjkDxJsd9pHQhTGXYLLJXThaPCgSXAQvMS+QUf7+jNm/waoJ5whtQt11BzmsWC8 290e7YICO+bO+FQpxUJp2RqljO2rAOEitQify/hCEvY8657ajt5to9eVdwsvMHvOetU98o9zXPM HLtrZBPc5qbMyZb6SUnSk291oTmWx4HCnyflz17erzGc02KUgPwRRD4fzZV9NxYFNB99PdVHG6M tz7UGcnTuM3E78SvacwXVVZZOyJ7IYmR+DN7J70iRp8jIM4EUx3v23MGCoCnyoYkeAxDNkj35ZJ rgnxPinIrw4PA2ULDAlMY7AT+UyQCouuhvsHGS X-Google-Smtp-Source: AGHT+IG2dUCqDcfLmg6GQ5lAlXBIqxs9KWH+YNv4QsB30IZJTtg9NVCN7IdyFXcfIOHqLU7l2omYAg== X-Received: by 2002:a05:6000:184e:b0:429:f0a4:22e with SMTP id ffacd0b85a97d-42ae5ae9b17mr2326856f8f.54.1762515376522; Fri, 07 Nov 2025 03:36:16 -0800 (PST) Received: from [192.168.2.1] (146725694.box.freepro.com. [130.180.211.218]) by smtp.googlemail.com with ESMTPSA id ffacd0b85a97d-42ac679c5dcsm5661874f8f.44.2025.11.07.03.36.15 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 07 Nov 2025 03:36:16 -0800 (PST) Message-ID: Date: Fri, 7 Nov 2025 12:36:14 +0100 Precedence: bulk X-Mailing-List: devicetree@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v5 2/2] iio: adc: Add the NXP SAR ADC support for the s32g2/3 platforms To: Andy Shevchenko Cc: jic23@kernel.org, dlechner@baylibre.com, nuno.sa@analog.com, andy@kernel.org, robh@kernel.org, conor+dt@kernel.org, krzk+dt@kernel.org, linux-iio@vger.kernel.org, s32@nxp.com, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, chester62515@gmail.com, mbrugger@suse.com, ghennadi.procopciuc@oss.nxp.com References: <20251017164238.1908585-1-daniel.lezcano@linaro.org> <20251017164238.1908585-3-daniel.lezcano@linaro.org> <050f96d5-e60c-4b33-b6d2-24fb3925e378@linaro.org> Content-Language: en-US From: Daniel Lezcano In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit On 10/31/25 13:45, Andy Shevchenko wrote: > On Fri, Oct 31, 2025 at 12:32:03PM +0100, Daniel Lezcano wrote: >> On 10/30/25 10:28, Andy Shevchenko wrote: >>> On Thu, Oct 30, 2025 at 09:27:21AM +0100, Daniel Lezcano wrote: >>>> On 10/18/25 22:12, Andy Shevchenko wrote: >>>>> On Fri, Oct 17, 2025 at 06:42:38PM +0200, Daniel Lezcano wrote: > > [ ... ] > >>>>>> + dma_samples = (u32 *)dma_buf->buf; >>>>> >>>>> Is it aligned properly for this type of casting? >>>> >>>> TBH, I don't know the answer :/ >>>> >>>> How can I check that ? >>> >>> Is buf defined as a pointer to u32 / int or bigger? or is it just byte buffer? >>> If the latter, how does the address of it being formed? Does it come from a heap >>> (memory allocator)? If yes, we are fine, as this is usually the case for all >>> (k)malloc'ed memory. >> >> buf is a byte buffer allocated with dmam_alloc_coherent(..., GFP_KERNEL) > > We are fine :-) > > ... > >>>>>> + dmaengine_tx_status(info->dma_chan, info->cookie, &state); >>>>> >>>>> No return value check? >>>> >>>> The return value is not necessary here because the caller of the callback >>>> will check with dma_submit_error() in case of error which covers the >>>> DMA_ERROR case and the other cases are not useful because the residue is >>>> taken into account right after. >>> >>> In some cases it might return DMA_PAUSE (and actually this is the correct way >>> to get residue, one needs to pause the channel to read it, otherwise it will >>> give outdated / incorrect information). >> >> But if the residue is checked in the callback routine without checking >> DMA_PAUSED, the result is the same no ? > > DMA in some corner cases might have already be charged for the next transfer. > Do you have a synchronisation between DMA start and residue check? > > I.o.w. this may work for your case, but in general it's not guaranteed. The proper > read of residue is to: pause DMA --> read residue --> resume DMA. > I'll use the new callback function dma_async_tx_callback_result() which should prevent that and allows to remove the spinlock at the same time -- Linaro.org │ Open source software for ARM SoCs Follow Linaro: Facebook | Twitter | Blog