From nobody Sun May 11 22:41:59 2025 Delivered-To: importer2@patchew.org Received-SPF: pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; envelope-from=linux-kernel-owner@vger.kernel.org; helo=vger.kernel.org; Authentication-Results: mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass(p=none dis=none) header.from=kernel.org ARC-Seal: i=1; a=rsa-sha256; t=1606216040; cv=none; d=zohomail.com; s=zohoarc; b=J2+SOUMyT3yTJRvI+Ih1oeW1PFyW1Dw+a0efii0B9sQmXKc6/k4I9ce+ycROKrD/U4WsEDxsUra8nYwC/0KR5HtfDZGpw6kJ2eAwZuwla7RsIffkvWgjCjM/cIDZB7sbUqF/0e10tEI6K3oQXversPcl6NmiHLpBvO1hCw+fVaw= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1606216040; h=Content-Transfer-Encoding:Cc:Date:From:In-Reply-To:List-Id:MIME-Version:Message-ID:References:Sender:Subject:To; bh=t+szUhyItQEnjwT3FHflo3XnPNqpVJKMQV/TZTIrqH8=; b=FcySPXUoFr6UVBktlVEVE8gYEEfyLND5ED9/7prXsOP6eoFTykTBiOi8LY7/lhvPsTFUhE970rjOPRJUAZ8P7KlGatP8yjKUMMolF16dX0WZIidM2NaATMOQwbibcD9ZVhHTiNqzeu2rzVu3UeSeNDNdZNqRD47SKal+XwJZ2A0= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=fail; spf=pass (zohomail.com: domain of vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass header.from= (p=none dis=none) header.from= Return-Path: Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mx.zohomail.com with SMTP id 1606216040840474.89868799662327; Tue, 24 Nov 2020 03:07:20 -0800 (PST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732605AbgKXLGs (ORCPT ); Tue, 24 Nov 2020 06:06:48 -0500 Received: from mail.kernel.org ([198.145.29.99]:33784 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732511AbgKXLGg (ORCPT ); Tue, 24 Nov 2020 06:06:36 -0500 Received: from mail.kernel.org (ip5f5ad5c3.dynamic.kabel-deutschland.de [95.90.213.195]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5446C22228; Tue, 24 Nov 2020 11:06:31 +0000 (UTC) Received: from mchehab by mail.kernel.org with local (Exim 4.94) (envelope-from ) id 1khW9V-000Fac-Bq; Tue, 24 Nov 2020 12:06:29 +0100 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1606215991; bh=6Dj298ztKfE+ZkBGd+9F1Ggx/oCFFgj0oxJDMUVS0rs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WKBCiph4feqYW8XQngopgq11wdjG5/vjyWKUkLkx0KNV60C1fRRQoiHEGGjBwmMVH RPHbHHCf1NL4yPjrNB2WHcaZ4F0B+DGnmupnlzGWLw/JIeGtGFhGn16hs4mvYXpXw0 7Pb7bFUaRzht1Zdd2U+XJFBNo6dT1JnkaobKDeZo= From: Mauro Carvalho Chehab Cc: Mauro Carvalho Chehab , "Daniel W. S. Almeida" , Mauro Carvalho Chehab , linux-kernel@vger.kernel.org, linux-media@vger.kernel.org Subject: [PATCH 28/31] media: vidtv: simplify EIT write function Date: Tue, 24 Nov 2020 12:06:24 +0100 Message-Id: <740356abb4b2543811d56ed23fe5dcb2282d5c70.1606215584.git.mchehab+huawei@kernel.org> X-Mailer: git-send-email 2.28.0 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable Sender: Mauro Carvalho Chehab To: unlisted-recipients:; (no To-header on input) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-ZohoMail-DKIM: fail (Header signature does not verify) Content-Type: text/plain; charset="utf-8" - pass struct vidtv_psi_eit_write_args as a pointer; - avoid initializing struct fields multiple times. Signed-off-by: Mauro Carvalho Chehab --- drivers/media/test-drivers/vidtv/vidtv_mux.c | 2 +- drivers/media/test-drivers/vidtv/vidtv_psi.c | 86 ++++++++++---------- drivers/media/test-drivers/vidtv/vidtv_psi.h | 2 +- 3 files changed, 46 insertions(+), 44 deletions(-) diff --git a/drivers/media/test-drivers/vidtv/vidtv_mux.c b/drivers/media/t= est-drivers/vidtv/vidtv_mux.c index 77d691f4ff92..b51e6a3b8cbe 100644 --- a/drivers/media/test-drivers/vidtv/vidtv_mux.c +++ b/drivers/media/test-drivers/vidtv/vidtv_mux.c @@ -209,7 +209,7 @@ static u32 vidtv_mux_push_si(struct vidtv_mux *m) eit_args.offset =3D m->mux_buf_offset; eit_args.continuity_counter =3D &eit_ctx->cc; =20 - m->mux_buf_offset +=3D vidtv_psi_eit_write_into(eit_args); + m->mux_buf_offset +=3D vidtv_psi_eit_write_into(&eit_args); =20 nbytes =3D m->mux_buf_offset - initial_offset; =20 diff --git a/drivers/media/test-drivers/vidtv/vidtv_psi.c b/drivers/media/t= est-drivers/vidtv/vidtv_psi.c index 87fe3aedc8a8..9df6bca4e0a4 100644 --- a/drivers/media/test-drivers/vidtv/vidtv_psi.c +++ b/drivers/media/test-drivers/vidtv/vidtv_psi.c @@ -1857,55 +1857,63 @@ struct vidtv_psi_table_eit return eit; } =20 -u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_write_args args) +u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_write_args *args) { - struct vidtv_psi_table_eit_event *event =3D args.eit->event; + struct header_write_args h_args =3D { + .dest_buf =3D args->buf, + .dest_offset =3D args->offset, + .h =3D &args->eit->header, + .pid =3D VIDTV_EIT_PID, + .dest_buf_sz =3D args->buf_sz, + }; + struct psi_write_args psi_args =3D { + .dest_buf =3D args->buf, + .len =3D sizeof_field(struct vidtv_psi_table_eit, transport_= id) + + sizeof_field(struct vidtv_psi_table_eit, network_id) + + sizeof_field(struct vidtv_psi_table_eit, last_segment) + + sizeof_field(struct vidtv_psi_table_eit, last_table_id), + .pid =3D VIDTV_EIT_PID, + .new_psi_section =3D false, + .is_crc =3D false, + .dest_buf_sz =3D args->buf_sz, + }; + struct desc_write_args d_args =3D { + .dest_buf =3D args->buf, + .pid =3D VIDTV_EIT_PID, + .dest_buf_sz =3D args->buf_sz, + }; + struct crc32_write_args c_args =3D { + .dest_buf =3D args->buf, + .pid =3D VIDTV_EIT_PID, + .dest_buf_sz =3D args->buf_sz, + }; + struct vidtv_psi_table_eit_event *event =3D args->eit->event; struct vidtv_psi_desc *event_descriptor; - struct header_write_args h_args =3D {}; - struct psi_write_args psi_args =3D {}; - struct desc_write_args d_args =3D {}; - struct crc32_write_args c_args =3D {}; u32 crc =3D INITIAL_CRC; u32 nbytes =3D 0; =20 - vidtv_psi_eit_table_update_sec_len(args.eit); + vidtv_psi_eit_table_update_sec_len(args->eit); =20 - h_args.dest_buf =3D args.buf; - h_args.dest_offset =3D args.offset; - h_args.h =3D &args.eit->header; - h_args.pid =3D VIDTV_EIT_PID; - h_args.continuity_counter =3D args.continuity_counter; - h_args.dest_buf_sz =3D args.buf_sz; + h_args.continuity_counter =3D args->continuity_counter; h_args.crc =3D &crc; =20 nbytes +=3D vidtv_psi_table_header_write_into(&h_args); =20 - psi_args.dest_buf =3D args.buf; - psi_args.from =3D &args.eit->transport_id; - - psi_args.len =3D sizeof_field(struct vidtv_psi_table_eit, transport_id) + - sizeof_field(struct vidtv_psi_table_eit, network_id) + - sizeof_field(struct vidtv_psi_table_eit, last_segment) + - sizeof_field(struct vidtv_psi_table_eit, last_table_id); - - psi_args.dest_offset =3D args.offset + nbytes; - psi_args.pid =3D VIDTV_EIT_PID; - psi_args.new_psi_section =3D false; - psi_args.continuity_counter =3D args.continuity_counter; - psi_args.is_crc =3D false; - psi_args.dest_buf_sz =3D args.buf_sz; + psi_args.from =3D &args->eit->transport_id; + psi_args.dest_offset =3D args->offset + nbytes; + psi_args.continuity_counter =3D args->continuity_counter; psi_args.crc =3D &crc; =20 nbytes +=3D vidtv_psi_ts_psi_write_into(&psi_args); =20 + /* skip both pointers at the end */ + psi_args.len =3D sizeof(struct vidtv_psi_table_eit_event) - + sizeof(struct vidtv_psi_desc *) - + sizeof(struct vidtv_psi_table_eit_event *); while (event) { /* copy the events, if any */ psi_args.from =3D event; - /* skip both pointers at the end */ - psi_args.len =3D sizeof(struct vidtv_psi_table_eit_event) - - sizeof(struct vidtv_psi_desc *) - - sizeof(struct vidtv_psi_table_eit_event *); - psi_args.dest_offset =3D args.offset + nbytes; + psi_args.dest_offset =3D args->offset + nbytes; =20 nbytes +=3D vidtv_psi_ts_psi_write_into(&psi_args); =20 @@ -1913,12 +1921,9 @@ u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_wr= ite_args args) =20 while (event_descriptor) { /* copy the event descriptors, if any */ - d_args.dest_buf =3D args.buf; - d_args.dest_offset =3D args.offset + nbytes; + d_args.dest_offset =3D args->offset + nbytes; d_args.desc =3D event_descriptor; - d_args.pid =3D VIDTV_EIT_PID; - d_args.continuity_counter =3D args.continuity_counter; - d_args.dest_buf_sz =3D args.buf_sz; + d_args.continuity_counter =3D args->continuity_counter; d_args.crc =3D &crc; =20 nbytes +=3D vidtv_psi_desc_write_into(&d_args); @@ -1929,12 +1934,9 @@ u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_wr= ite_args args) event =3D event->next; } =20 - c_args.dest_buf =3D args.buf; - c_args.dest_offset =3D args.offset + nbytes; + c_args.dest_offset =3D args->offset + nbytes; c_args.crc =3D cpu_to_be32(crc); - c_args.pid =3D VIDTV_EIT_PID; - c_args.continuity_counter =3D args.continuity_counter; - c_args.dest_buf_sz =3D args.buf_sz; + c_args.continuity_counter =3D args->continuity_counter; =20 /* Write the CRC at the end */ nbytes +=3D table_section_crc32_write_into(&c_args); diff --git a/drivers/media/test-drivers/vidtv/vidtv_psi.h b/drivers/media/t= est-drivers/vidtv/vidtv_psi.h index 9aa43272ecfa..6efc27996395 100644 --- a/drivers/media/test-drivers/vidtv/vidtv_psi.h +++ b/drivers/media/test-drivers/vidtv/vidtv_psi.h @@ -775,7 +775,7 @@ struct vidtv_psi_eit_write_args { * equal to the size of the EIT, since more space is needed for TS headers= during TS * encapsulation. */ -u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_write_args args); +u32 vidtv_psi_eit_write_into(struct vidtv_psi_eit_write_args *args); =20 void vidtv_psi_eit_table_destroy(struct vidtv_psi_table_eit *eit); =20 --=20 2.28.0