Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp1076365pxb; Fri, 3 Sep 2021 22:55:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwe1g+pX/hUJiuq8c0lQv82RqZ2v18IwoY84kWl8en+nuP/lugRLSP6tDfpCy7pdhCFqlo4 X-Received: by 2002:a17:906:7256:: with SMTP id n22mr2657312ejk.173.1630734920404; Fri, 03 Sep 2021 22:55:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1630734920; cv=none; d=google.com; s=arc-20160816; b=HaWEY8bc0CN/bcctlEMhqkqkmuRdWoIm7sA2hgjgAZ6jtAz9XDY3Qj24bz/Rt7Gkwh OeAjgYAzIccaSszrHWkZzpmSnYfUp99kqP8vZoa7/Wewf7D4zQ9odHjoo9s4tFZo7pz1 GEyL2ivNRxB+FCKKoMcCP56If0dn9ryuMZjMwHREk3YlRTGmuYrDC4rJKCHpNfhbTUQF ugePKP9a5dY9nCppxYd1EQNAnmKhFV8wW3slUjgVJdSz21ORkwpFHaAmAgqhecUH0v8w MDBZuJEiOXCWSwHOgH4rpwbRrhPrC+rNVxBZBwZNBCsFI4AUfriByxVA4cUeaWkvAMaI 3s2A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=TnrHS55J1/CCmhhmNN0Xsgpg2WaTq3zIYJ0S2vGDUm8=; b=pHxyaWJnPh7G2NVmiVALulwl11DU2sqZD9DWZ+Lj8eULcSHJLVSF9+ko9bMNKERvkw IAZWuyVzDKXn5zbTZ5jshmYrcqwdsrKKGae50Z6K4UEskvCn+nfTGXC/yR/m3GNljjsI NzTYTiCiV8RKeJg7u313FCo63OmQDe5fHzIFzil+RoQZW8Y10XtFD7zBGgZcQ/kgzSlc pu3y1SSlqkdqdIc2mGJlAO62gXaDGa8LDEDMaw7LgS8Otx43kab2ww+XWlRPL8exe/TN hgJCXQ3/nAbQ3y4ZjXkTi2VPlBYUf1cFFHHbWAXi69Og9rTP7upxPRJvYCR0cOihuTHc XCsQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ndzyo0kL; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i17si1430322ejd.15.2021.09.03.22.54.43; Fri, 03 Sep 2021 22:55:20 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=ndzyo0kL; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230248AbhIDFyF (ORCPT + 99 others); Sat, 4 Sep 2021 01:54:05 -0400 Received: from mail.kernel.org ([198.145.29.99]:56358 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229741AbhIDFyE (ORCPT ); Sat, 4 Sep 2021 01:54:04 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id BDBA960F90; Sat, 4 Sep 2021 05:53:02 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1630734783; bh=qpOBAvDkDu13hb8ihotJ6B5GQ43H7dVCqgu92ZbgssU=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=ndzyo0kLml9lgVZDXvNlZX+vzt4QXmPQ7+BNSvOVHfTm0nomUhDRy6PDuJG2tuZD3 ELl2PD8Ip3r2wpTq/UGUvZKU8cHDJ49kLCy1L65JJ3kJqLcMDwIuf6ZyJdr7CkqbjB vj2vjdkS95DrO9+aEbvnxTJ2+1+3vqjYTBKVxvkI= Date: Sat, 4 Sep 2021 07:53:00 +0200 From: Greg KH To: Corentin Labbe Cc: mchehab@kernel.org, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-staging@lists.linux.dev, mjpeg-users@lists.sourceforge.net Subject: Re: [PATCH 4/8] staging: media: zoran: add debugfs Message-ID: References: <20210903191540.3052775-1-clabbe@baylibre.com> <20210903191540.3052775-5-clabbe@baylibre.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210903191540.3052775-5-clabbe@baylibre.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Sep 03, 2021 at 07:15:36PM +0000, Corentin Labbe wrote: > Add debugfs for displaying zoran debug and stats information. > > Signed-off-by: Corentin Labbe > --- > drivers/staging/media/zoran/Kconfig | 10 ++++++ > drivers/staging/media/zoran/zoran.h | 5 +++ > drivers/staging/media/zoran/zoran_card.c | 39 ++++++++++++++++++++++++ > 3 files changed, 54 insertions(+) > > diff --git a/drivers/staging/media/zoran/Kconfig b/drivers/staging/media/zoran/Kconfig > index 7874842033ca..7d2d3c2431b1 100644 > --- a/drivers/staging/media/zoran/Kconfig > +++ b/drivers/staging/media/zoran/Kconfig > @@ -74,3 +74,13 @@ config VIDEO_ZORAN_AVS6EYES > select VIDEO_KS0127 if MEDIA_SUBDRV_AUTOSELECT > help > Support for the AverMedia 6 Eyes video surveillance card. > + > +config VIDEO_ZORAN_DEBUG > + bool "Enable zoran debugfs" > + depends on VIDEO_ZORAN > + depends on DEBUG_FS > + help > + Say y to enable zoran debug file. > + This will create /sys/kernel/debug/CARD_NAME/debug for displaying > + stats and debug information. > + > diff --git a/drivers/staging/media/zoran/zoran.h b/drivers/staging/media/zoran/zoran.h > index b1ad2a2b914c..8c271005f14d 100644 > --- a/drivers/staging/media/zoran/zoran.h > +++ b/drivers/staging/media/zoran/zoran.h > @@ -18,6 +18,7 @@ > #ifndef _BUZ_H_ > #define _BUZ_H_ > > +#include > #include > #include > #include > @@ -295,6 +296,10 @@ struct zoran { > struct list_head queued_bufs; > spinlock_t queued_bufs_lock; /* Protects queued_bufs */ > struct zr_buffer *inuse[BUZ_NUM_STAT_COM * 2]; > +#ifdef CONFIG_VIDEO_ZORAN_DEBUG > + struct dentry *dbgfs_dir; > + struct dentry *dbgfs_file; No need for these, the file is never referenced and the directory can be looked up when you want to remove it. > +#endif > }; > > static inline struct zoran *to_zoran(struct v4l2_device *v4l2_dev) > diff --git a/drivers/staging/media/zoran/zoran_card.c b/drivers/staging/media/zoran/zoran_card.c > index f1465fbf98af..1ed8ed2f4f7f 100644 > --- a/drivers/staging/media/zoran/zoran_card.c > +++ b/drivers/staging/media/zoran/zoran_card.c > @@ -1051,6 +1051,39 @@ static const struct v4l2_ctrl_ops zoran_video_ctrl_ops = { > .s_ctrl = zoran_video_set_ctrl, > }; > > +#ifdef CONFIG_VIDEO_ZORAN_DEBUG > +static int zoran_debugfs_show(struct seq_file *seq, void *v) > +{ > + struct zoran *zr = seq->private; > + > + seq_printf(seq, "Running mode %x\n", zr->running); > + seq_printf(seq, "Codec mode %x\n", zr->codec_mode); > + seq_printf(seq, "Norm %x\n", zr->norm); > + seq_printf(seq, "Input %d\n", zr->input); > + seq_printf(seq, "Buffersize %d\n", zr->buffer_size); > + > + seq_printf(seq, "V4L width %dx%d\n", zr->v4l_settings.width, zr->v4l_settings.height); > + seq_printf(seq, "V4L bytesperline %d\n", zr->v4l_settings.bytesperline); > + > + seq_printf(seq, "JPG decimation %u\n", zr->jpg_settings.decimation); > + seq_printf(seq, "JPG hor_dcm %u\n", zr->jpg_settings.hor_dcm); > + seq_printf(seq, "JPG ver_dcm %u\n", zr->jpg_settings.ver_dcm); > + seq_printf(seq, "JPG tmp_dcm %u\n", zr->jpg_settings.tmp_dcm); > + seq_printf(seq, "JPG odd_even %u\n", zr->jpg_settings.odd_even); > + seq_printf(seq, "JPG crop %dx%d %d %d\n", > + zr->jpg_settings.img_x, > + zr->jpg_settings.img_y, > + zr->jpg_settings.img_width, > + zr->jpg_settings.img_height); > + > + seq_printf(seq, "Prepared %u\n", zr->prepared); > + seq_printf(seq, "Queued %u\n", zr->queued); > + return 0; > +} > + > +DEFINE_SHOW_ATTRIBUTE(zoran_debugfs); > +#endif > + > /* > * Scan for a Buz card (actually for the PCI controller ZR36057), > * request the irq and map the io memory > @@ -1286,6 +1319,12 @@ static int zoran_probe(struct pci_dev *pdev, const struct pci_device_id *ent) > > zr->map_mode = ZORAN_MAP_MODE_RAW; > > +#ifdef CONFIG_VIDEO_ZORAN_DEBUG > + zr->dbgfs_dir = debugfs_create_dir(ZR_DEVNAME(zr), NULL); > + zr->dbgfs_file = debugfs_create_file("debug", 0444, > + zr->dbgfs_dir, zr, > + &zoran_debugfs_fops); > +#endif Wait, when are you removing the files when the device is removed? That needs to be fixed no matter what before this patch is accepted. thanks, greg k-h