Received: by 2002:ab2:69cc:0:b0:1f4:be93:e15a with SMTP id n12csp2061993lqp; Tue, 16 Apr 2024 06:29:14 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWbYv+AWkDBo+b5EUJKH82yuWf2fshzfiMYJoDwzGJBqJmINAMDJ11E6V+9CH3xFh2nNoNDihpqG7jFV/8EJHhUSj4naaKqv/qX9dtMDw== X-Google-Smtp-Source: AGHT+IEoHIsnKv1NI8S+bFCw4spSOe5YoukmCPgOeuXopvG4Gov1czEz0SXy2SQjgMyxwXTt1xqQ X-Received: by 2002:a05:6512:2247:b0:515:d176:dfd1 with SMTP id i7-20020a056512224700b00515d176dfd1mr12618051lfu.56.1713274154562; Tue, 16 Apr 2024 06:29:14 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713274154; cv=pass; d=google.com; s=arc-20160816; b=S7ffFzCvfQV+6ErAJ23wKMfG/If3YwfE0453prJdyub3GeXQ1swsxdyGfgRg7vciS3 I7nQmlBKHqHmK9K4lz5mJaz2QCuFduKVxuZGn9PnKxpc8SPiUbzSRmWg7TNXiTSzqkXl fX//MBr+jMvYTzH8fRcyKXr0MsW8w4qIBNuSv3yZNAm006/GYxxyKWg9BTCVP7ltb5DR ewD25tZpi09yB7+G8br6Zf5HfwdMnpgi9yu+bx8okS9SvSQNFDc1i0765mKNNCVq6S8D YHIp/HRx1y8zoVGxoboNN8f6MBzG2LPvVyvrgOLuHR8uYyL/lnh3Q9PYzpPpNhy60WRC dP0Q== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=815UYUdUs3atWZanjdCr3vlcusZKtTdRMshCHcrqZwg=; fh=zgRMIYdrAUWa6zQBMBN7zPZwx2MXbBAmoVyUIlQbEzc=; b=igendLmXtP3yErRE2Yyjq1HxRrLoogRis5mFW6sZeu6Rk7H5XokW9YhK23HueQc+9O 8lhotYqDXHcUt62B68hMoOKBMz8DNkutOfEDFral0q3D0+EdvLzuUK8hluEMMJhCzaN3 TysUjzJfA5Et2/fryIVJP/Ttl1/YJf+AptNwuZYHaGiu6eQo4DeYNiZ5qPSJmGkdDGXv I6H6uCP/nXQUWPoHV1TgUkP6HPQPjFbKbn6FWJ5asp0nZXoxps3BXQwH/6RRAmsa2LlZ OVpzxNmjG72calKFyru6IQQS1QpbOnTMlboTlEJ8OgwUeKwqREmwkIjiD4AVk2lROFhz fhYg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=TSaeTHjp; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-146878-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-146878-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from am.mirrors.kernel.org (am.mirrors.kernel.org. [147.75.80.249]) by mx.google.com with ESMTPS id m26-20020a17090607da00b00a5536f22479si1105556ejc.201.2024.04.16.06.29.14 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 16 Apr 2024 06:29:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-146878-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) client-ip=147.75.80.249; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=TSaeTHjp; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-146878-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.80.249 as permitted sender) smtp.mailfrom="linux-kernel+bounces-146878-linux.lists.archive=gmail.com@vger.kernel.org" Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by am.mirrors.kernel.org (Postfix) with ESMTPS id 498321F21B73 for ; Tue, 16 Apr 2024 13:29:14 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 8689D12C49D; Tue, 16 Apr 2024 13:29:03 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="TSaeTHjp" Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [213.167.242.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 09F8312AADC; Tue, 16 Apr 2024 13:29:00 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=213.167.242.64 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713274142; cv=none; b=L3nsMkn6oQ5uvc9aRuZo7/HhoYLekq6nkL2HNuT5v0yGu6dREpybRrwAIumWTXNz7Y4Urqf9kDLE7KDnen4oXJ5xivOv0UxHmnRJ53eRDXQdri7OnKU7Tk4uwz72/jl83wplffiJDBsoG5bMeB49NF9CisAFG1zKANpjyrqfOVk= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713274142; c=relaxed/simple; bh=n8uAzu0fhjDkoEFhJa32or/1KBqUpuWXqGojl6rSobU=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=Y+gIzNxALy90nCVeFo7MkaM/4JewBaq5Ph2WbXosTrYq4hBYc9t/07WKK6ZZocY1+zfZZ7uUcitkmPdsFTWDNZQwul9u0mvUlKku0diJTu5za3/UxOkhWnkRthtRimPVwyl1lmLjmtA6LlrrwtIXK0vYZ1DazST50z9IYIXpfzI= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com; spf=pass smtp.mailfrom=ideasonboard.com; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b=TSaeTHjp; arc=none smtp.client-ip=213.167.242.64 Authentication-Results: smtp.subspace.kernel.org; dmarc=none (p=none dis=none) header.from=ideasonboard.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=ideasonboard.com Received: from [192.168.1.105] (unknown [103.251.226.7]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 45190DFB; Tue, 16 Apr 2024 15:28:09 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1713274092; bh=n8uAzu0fhjDkoEFhJa32or/1KBqUpuWXqGojl6rSobU=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=TSaeTHjp78FW/oI1sULfK4N2T4YxjndlfP4ZpCABqls7bpYSegOKqEvui7ZgbyQqi AxLmi6Fby0iSq2SwxqCDe0iwezbAVdB/S9BmuKGTR/Q/LzURQmFQgcRaGx3NCt7jqP EtfkTi5Ee2n3Ub8npzfE0cMr+cuTQhW1bTtJlYh8= Message-ID: <92279ce6-e410-40f2-bc6d-ad842aa9e106@ideasonboard.com> Date: Tue, 16 Apr 2024 18:58:51 +0530 Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v4 10/10] media: subdev: Support non-routing subdevs in v4l2_subdev_s_stream_helper() To: Tomi Valkeinen Cc: linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, Mauro Carvalho Chehab , Hans Verkuil , Laurent Pinchart , Sakari Ailus References: <20240416-enable-streams-impro-v4-0-1d370c9c2b6d@ideasonboard.com> <20240416-enable-streams-impro-v4-10-1d370c9c2b6d@ideasonboard.com> <271933b0-7ac1-4fdf-b66a-0ed860a1ec8f@ideasonboard.com> Content-Language: en-US From: Umang Jain In-Reply-To: <271933b0-7ac1-4fdf-b66a-0ed860a1ec8f@ideasonboard.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Hi Tomi On 16/04/24 4:13 pm, Tomi Valkeinen wrote: > Hi, > > On 16/04/2024 13:40, Tomi Valkeinen wrote: >> At the moment v4l2_subdev_s_stream_helper() only works for subdevices >> that support routing. As enable/disable_streams now also works for >> subdevices without routing, improve v4l2_subdev_s_stream_helper() to do >> the same. > > I forgot to mention, I have not tested this patch as I don't have a HW > setup. And, of course, I now see that it has a bug. The BIT_ULL(1) > should be BIT_ULL(0). > > Umang, can you try a fixed one on your side? If it works, I'll send a v5. This doesn't work. Streaming fails as : [  132.108845] rkisp1 32e10000.isp: streams 0xffff8000801fef88 already enabled on imx283 1-001a:0 [  133.140906] rkisp1 32e10000.isp: streams 0xffff8000801fef88 already enabled on imx283 1-001a:0 With locally applied: diff --git a/drivers/media/v4l2-core/v4l2-subdev.c b/drivers/media/v4l2-core/v4l2-subdev.c index 04d85b5f23f5..4684e4e1984c 100644 --- a/drivers/media/v4l2-core/v4l2-subdev.c +++ b/drivers/media/v4l2-core/v4l2-subdev.c @@ -2203,7 +2203,7 @@ int v4l2_subdev_enable_streams(struct v4l2_subdev *sd, u32 pad,         }         if (enabled_streams) { -               dev_dbg(dev, "streams 0x%llx already enabled on %s:%u\n", +               dev_err(dev, "streams 0x%llx already enabled on %s:%u\n",                         enabled_streams, sd->entity.name, pad);                 ret = -EINVAL;                 goto done; @@ -2376,7 +2376,7 @@ int v4l2_subdev_s_stream_helper(struct v4l2_subdev *sd, int enable)                  * For non-streams subdevices, there's a single implicit stream                  * per pad.                  */ -               source_mask = BIT_ULL(1); +               source_mask = BIT_ULL(0);         } > >  Tomi > >> Signed-off-by: Tomi Valkeinen >> --- >>   drivers/media/v4l2-core/v4l2-subdev.c | 23 ++++++++++++++++------- >>   1 file changed, 16 insertions(+), 7 deletions(-) >> >> diff --git a/drivers/media/v4l2-core/v4l2-subdev.c >> b/drivers/media/v4l2-core/v4l2-subdev.c >> index 1c6b305839a1..83ebcde54a34 100644 >> --- a/drivers/media/v4l2-core/v4l2-subdev.c >> +++ b/drivers/media/v4l2-core/v4l2-subdev.c >> @@ -2360,15 +2360,24 @@ int v4l2_subdev_s_stream_helper(struct >> v4l2_subdev *sd, int enable) >>       if (WARN_ON(pad_index == -1)) >>           return -EINVAL; >>   -    /* >> -     * As there's a single source pad, just collect all the source >> streams. >> -     */ >> -    state = v4l2_subdev_lock_and_get_active_state(sd); >> +    if (sd->flags & V4L2_SUBDEV_FL_STREAMS) { >> +        /* >> +         * As there's a single source pad, just collect all the source >> +         * streams. >> +         */ >> +        state = v4l2_subdev_lock_and_get_active_state(sd); >>   -    for_each_active_route(&state->routing, route) >> -        source_mask |= BIT_ULL(route->source_stream); >> +        for_each_active_route(&state->routing, route) >> +            source_mask |= BIT_ULL(route->source_stream); >>   -    v4l2_subdev_unlock_state(state); >> +        v4l2_subdev_unlock_state(state); >> +    } else { >> +        /* >> +         * For non-streams subdevices, there's a single implicit stream >> +         * per pad. >> +         */ >> +        source_mask = BIT_ULL(1); >> +    } >>         if (enable) >>           return v4l2_subdev_enable_streams(sd, pad_index, source_mask); >> >