Received: by 2002:ab2:69cc:0:b0:1f4:be93:e15a with SMTP id n12csp2078333lqp; Tue, 16 Apr 2024 06:55:05 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCUPFiifVMVOuM1k53NMrpy/XqDZJJY5sTbdt7K6B+J5cgIftZ0PQ+AcCt3SAMvh5DGOpIMvaGM5lqGSc1zQdleXEwBNBJ5tJhfY3Qc3Lg== X-Google-Smtp-Source: AGHT+IFzqOlIBVbWFwS7cgDxLCHVKMKRqbOMoAqyG+KczJsvmITpZwfN/lKYkVmyUzYPYZRNlQe/ X-Received: by 2002:a05:6870:4408:b0:22e:a451:57d1 with SMTP id u8-20020a056870440800b0022ea45157d1mr8017197oah.52.1713275705007; Tue, 16 Apr 2024 06:55:05 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1713275704; cv=pass; d=google.com; s=arc-20160816; b=Ea5cl4b6V8SbrRxQg7b/c1Fy2fp6KcqLDrUIN25vbwbeEv9CNgV9HS0Qth6v313IyS uGxfWtmc6O2ScKH8rjHburG5iabHdkM98omcrPV2MC4Y2366ocvOTzPVKlIero7ArvJI Bh/hsUVlWf5kcg7EHC4Nd9l335k3UH1bhw/2H7CnXlKdmIkhn1fGPDgG34bV/metaKeJ 5U74hvPZ0eF0UNVVUFavGeumnYtMeV80b21CmCFSlR7zRFnj3O911WJefVlaB0fmBipA DfFRTdAmNXhF3s/35i5wuFtsv7A/QtTq8OavnIIUdGkL2ThgmZUxZVEB+1sUsx989jzt VyrQ== 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:references:cc:to :content-language:subject:user-agent:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:date:message-id:dkim-signature; bh=hcSSfkJIuSHLEMkZ4GE7W6lhOdDPE03QWgMsi7ExVtc=; fh=zgRMIYdrAUWa6zQBMBN7zPZwx2MXbBAmoVyUIlQbEzc=; b=nICW8tbxDJ5g8EGhWwQ4tWrIf1aYceZIaXR0oVo6AaOr1opQw9Z+Lu6BIlK/tYi8S5 gPFT+2wE9FIhOxz75Au/9bPnktPxbzwwA9XQRgyuVilPLXGK/5voVdphJPTsQNK1oi4F 30YTnwkD57j+RaWMX3kU/QVYrWZWQPs6n23IHXVEKAPfmCOJDrh6FT6gi2Prq3O7f8sz ECSJ1f5JxJTLN3eD9zE04e6LNbGg25OztR5A9DPteM1z4eoZoO9F34X8ja6Ngao6hed1 uuN+Bl6Pvju+26wzbmyPh9vjrRnw4iex1Cx4cUTDntSIif+G4U1q/dV8t7JNQqWOD514 /qZQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=Cve7WFws; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-146913-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-146913-linux.lists.archive=gmail.com@vger.kernel.org" Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id l9-20020a63ba49000000b005f073cdbc73si9761706pgu.473.2024.04.16.06.55.04 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 16 Apr 2024 06:55:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-146913-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=Cve7WFws; arc=pass (i=1 spf=pass spfdomain=ideasonboard.com dkim=pass dkdomain=ideasonboard.com); spf=pass (google.com: domain of linux-kernel+bounces-146913-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-146913-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 sv.mirrors.kernel.org (Postfix) with ESMTPS id 7881D284A2D for ; Tue, 16 Apr 2024 13:52:15 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 7DDE0129A72; Tue, 16 Apr 2024 13:51:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (1024-bit key) header.d=ideasonboard.com header.i=@ideasonboard.com header.b="Cve7WFws" 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 EC53712CD8B; Tue, 16 Apr 2024 13:51:49 +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=1713275511; cv=none; b=NWMmUl4SPVj35PE0XlO6TyJl3HPtHxGUN2gp13bFGpIyrRoZ8BP+JJIcjQ2SvK1KluGYnr4riXVp4maj6CEbBpMGsZ/zCNyyN3bEFMp2XrnoC+n/g+Vi/oVWocQ5osHNrY8UX7cMm6eJIoLn2T5CagyGrfMXSmyhtPww4ifwWvM= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1713275511; c=relaxed/simple; bh=V8DvUts8+fVL/4ImWpzh5z7jBIet9GW4KGTbqdDcYUU=; h=Message-ID:Date:MIME-Version:Subject:To:Cc:References:From: In-Reply-To:Content-Type; b=Lhl6Y+Md2Sh3dJ7ZPan+GgBW4q/7Nd/JAL0jV/VxWJCMF1vuVpMug5rHG6VE+/iL/5WMsdr2ftcBxCzhbv5UHd191nL8rCClM7wD5KgUyIvl4djocv5jzAxLzi4q7f9zdUWXvvV4bhOYk4WhmyC4pTPajzcVrxzIEkvImBxWEds= 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=Cve7WFws; 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 E64B1DFB; Tue, 16 Apr 2024 15:50:59 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1713275462; bh=V8DvUts8+fVL/4ImWpzh5z7jBIet9GW4KGTbqdDcYUU=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=Cve7WFwsD3By9GF0K34xz1PxzH8oi4lwOot3//vjZ5mnjW7m/SfEfkhYIhf7jBxPV aInL8uapii8m5v1Gw8uNxnRVczJIoOO0wVPrYEwJOvBTOfVihTBwBb9HK9DCqgcUoo /oYkNGoJRmbEX4k2ZlXX+tlQ0AzUytct7LhlISHA= Message-ID: Date: Tue, 16 Apr 2024 19:21:41 +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() Content-Language: en-US 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> <92279ce6-e410-40f2-bc6d-ad842aa9e106@ideasonboard.com> <7b9be1a1-3775-4299-88f0-640be53a1acf@ideasonboard.com> From: Umang Jain In-Reply-To: <7b9be1a1-3775-4299-88f0-640be53a1acf@ideasonboard.com> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit Hi Tomi, On 16/04/24 7:14 pm, Tomi Valkeinen wrote: > On 16/04/2024 16:28, Umang Jain wrote: >> 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 > > Indeed, there's a bug in v4l2_subdev_collect_streams() too: > > @@ -2108,8 +2108,8 @@ static void v4l2_subdev_collect_streams(struct > v4l2_subdev *sd, >  { >         if (!(sd->flags & V4L2_SUBDEV_FL_STREAMS)) { >                 *found_streams = BIT_ULL(0); > -               if (sd->enabled_pads & BIT_ULL(pad)) > -                       *enabled_streams = BIT_ULL(0); > +               *enabled_streams = > +                       (sd->enabled_pads & BIT_ULL(pad)) ? BIT_ULL(0) > : 0; >                 return; >         } > >  Tomi Yep, works now \o/ Locally applied: diff --git a/drivers/media/v4l2-core/v4l2-subdev.c b/drivers/media/v4l2-core/v4l2-subdev.c index 04d85b5f23f5..8c591309df24 100644 --- a/drivers/media/v4l2-core/v4l2-subdev.c +++ b/drivers/media/v4l2-core/v4l2-subdev.c @@ -2108,6 +2108,8 @@ static void v4l2_subdev_collect_streams(struct v4l2_subdev *sd,  {         if (!(sd->flags & V4L2_SUBDEV_FL_STREAMS)) {                 *found_streams = BIT_ULL(0); +               *enabled_streams = +                       (sd->enabled_pads & BIT_ULL(pad)) ? BIT_ULL(0) : 0;                 if (sd->enabled_pads & BIT_ULL(pad))                         *enabled_streams = BIT_ULL(0);                 return; @@ -2203,7 +2205,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 +2378,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);         } I will provide a Tested-by in v5. > >> >> 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); >>>> >>> >> >