Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp504401pxj; Thu, 17 Jun 2021 07:36:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzj3XwMNjCRMVThdbzF6LlBtcTh1gkYv1yHNoR2o5QBFGogBxY2cKGOYu3yYYXoFgCqWSeS X-Received: by 2002:a05:6402:c92:: with SMTP id cm18mr6957585edb.29.1623940615361; Thu, 17 Jun 2021 07:36:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623940615; cv=none; d=google.com; s=arc-20160816; b=p/1iMkjA+5q/3fkCSXYVn9QGQHMmNi+0wgbI+KifMiZsQ7CPBaeFm1eh69VuwPIajA nI7zv8e+dXG1VOWawTMlWaCM18QD7PFRn4Rtya9s8R0renxtAGfbzW8OQTkMgrYo8cDa OKtr85ZTcAHigqXmRXvf8SspjU096oWKCTKCI5EwS3/vuanaueiKxJ2yn0AsRPWf+Sj7 PFcBZAQzUtT4yKjNEtR0DvoNt4KJ7FVrA2T9Ml1B5LDs8+4qt3xMDirOnIOo678z/a+/ FlwOeLy/dgo2mI7YUmF2Lf6KK4bqf60wK5eYrq7Zou5m5PkLjeV/hEozMwqFA8bCLdzv 5SlQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from; bh=wej1ONJkqdJY0q2YnNFsSmXV/Zph8fRKOt8xjdNh/d0=; b=aBvMkYWe7m4mHXeIwrCvAoODELpSt0g60TSk7PdNMUh56Zke37OqDGovsOKrjsX3tG yzHyEbIjSdmdihh+pk90Xzd7c0ecZZwEG2HUVnzUVkcIbUemNj1Wb8/GMns/6p1FOipy mmjcUjQL1Ky8Y/mL5cP9HSroRNvUQCgsvqLwo/IVYPGPf63Q8webTIMWXaMjga1zl1BP tiUWN56NZycTa6mQnO/zB6UXVKynMNmAAeMnT9ov1JtLj65Jmfgw4UGWanR9xYgmHVkf SUKPMsbEnlV0nFnaTmnWJRtYL02ahq3zioLT2ZkExOvRipr3t1oxWxQrl4BL2freljE+ G6ow== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v7si6389409edj.318.2021.06.17.07.36.32; Thu, 17 Jun 2021 07:36:55 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231917AbhFQOCu (ORCPT + 99 others); Thu, 17 Jun 2021 10:02:50 -0400 Received: from szxga03-in.huawei.com ([45.249.212.189]:7357 "EHLO szxga03-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229915AbhFQOCs (ORCPT ); Thu, 17 Jun 2021 10:02:48 -0400 Received: from dggemv711-chm.china.huawei.com (unknown [172.30.72.54]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4G5Nrj5bfZz6yTd; Thu, 17 Jun 2021 21:56:37 +0800 (CST) Received: from dggpeml500020.china.huawei.com (7.185.36.88) by dggemv711-chm.china.huawei.com (10.1.198.66) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Thu, 17 Jun 2021 22:00:30 +0800 Received: from huawei.com (10.175.127.227) by dggpeml500020.china.huawei.com (7.185.36.88) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2176.2; Thu, 17 Jun 2021 22:00:29 +0800 From: Baokun Li To: , , , , , , , , , CC: , , , , Hulk Robot Subject: [PATCH -next v6] media: staging: atomisp: use list_splice_init in atomisp_compat_css20.c Date: Thu, 17 Jun 2021 22:09:26 +0800 Message-ID: <20210617140926.887680-1-libaokun1@huawei.com> X-Mailer: git-send-email 2.31.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.127.227] X-ClientProxiedBy: dggems706-chm.china.huawei.com (10.3.19.183) To dggpeml500020.china.huawei.com (7.185.36.88) X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Using list_splice_init() instead of entire while-loops in atomisp_compat_css20.c. Reported-by: Hulk Robot Signed-off-by: Baokun Li --- V1->V2: CC mailist V2->V3: Using list_move_tail() -> Using list_splice_init() V3->V4: Remove redundant 'asd->' V4->V5: Add the version information for 'V3->V4:' V5->V6: Remove unused variable 'md_buf','dis_buf','s3a_buf' .../media/atomisp/pci/atomisp_compat_css20.c | 38 +++---------------- 1 file changed, 5 insertions(+), 33 deletions(-) diff --git a/drivers/staging/media/atomisp/pci/atomisp_compat_css20.c b/drivers/staging/media/atomisp/pci/atomisp_compat_css20.c index f60198bb8a1a..99a632f33d2d 100644 --- a/drivers/staging/media/atomisp/pci/atomisp_compat_css20.c +++ b/drivers/staging/media/atomisp/pci/atomisp_compat_css20.c @@ -2102,9 +2102,6 @@ void atomisp_css_stop(struct atomisp_sub_device *asd, enum ia_css_pipe_id pipe_id, bool in_reset) { struct atomisp_device *isp = asd->isp; - struct atomisp_s3a_buf *s3a_buf; - struct atomisp_dis_buf *dis_buf; - struct atomisp_metadata_buf *md_buf; unsigned long irqflags; unsigned int i; @@ -2144,42 +2141,17 @@ void atomisp_css_stop(struct atomisp_sub_device *asd, } /* move stats buffers to free queue list */ - while (!list_empty(&asd->s3a_stats_in_css)) { - s3a_buf = list_entry(asd->s3a_stats_in_css.next, - struct atomisp_s3a_buf, list); - list_del(&s3a_buf->list); - list_add_tail(&s3a_buf->list, &asd->s3a_stats); - } - while (!list_empty(&asd->s3a_stats_ready)) { - s3a_buf = list_entry(asd->s3a_stats_ready.next, - struct atomisp_s3a_buf, list); - list_del(&s3a_buf->list); - list_add_tail(&s3a_buf->list, &asd->s3a_stats); - } + list_splice_init(&asd->s3a_stats_in_css, &asd->s3a_stats); + list_splice_init(&asd->s3a_stats_ready, &asd->s3a_stats); spin_lock_irqsave(&asd->dis_stats_lock, irqflags); - while (!list_empty(&asd->dis_stats_in_css)) { - dis_buf = list_entry(asd->dis_stats_in_css.next, - struct atomisp_dis_buf, list); - list_del(&dis_buf->list); - list_add_tail(&dis_buf->list, &asd->dis_stats); - } + list_splice_init(&asd->dis_stats_in_css, &asd->dis_stats); asd->params.dis_proj_data_valid = false; spin_unlock_irqrestore(&asd->dis_stats_lock, irqflags); for (i = 0; i < ATOMISP_METADATA_TYPE_NUM; i++) { - while (!list_empty(&asd->metadata_in_css[i])) { - md_buf = list_entry(asd->metadata_in_css[i].next, - struct atomisp_metadata_buf, list); - list_del(&md_buf->list); - list_add_tail(&md_buf->list, &asd->metadata[i]); - } - while (!list_empty(&asd->metadata_ready[i])) { - md_buf = list_entry(asd->metadata_ready[i].next, - struct atomisp_metadata_buf, list); - list_del(&md_buf->list); - list_add_tail(&md_buf->list, &asd->metadata[i]); - } + list_splice_init(&asd->metadata_in_css[i], &asd->metadata[i]); + list_splice_init(&asd->metadata_ready[i], &asd->metadata[i]); } atomisp_flush_params_queue(&asd->video_out_capture); -- 2.31.1