linux-kernel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: "Terje Bergström" <tbergstrom@nvidia.com>
To: Thierry Reding <thierry.reding@avionic-design.de>
Cc: "linux-tegra@vger.kernel.org" <linux-tegra@vger.kernel.org>,
	"dri-devel@lists.freedesktop.org"
	<dri-devel@lists.freedesktop.org>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [RFC v2 1/8] video: tegra: Add nvhost driver
Date: Sat, 1 Dec 2012 13:31:02 +0200	[thread overview]
Message-ID: <50B9EA76.10803@nvidia.com> (raw)
In-Reply-To: <20121130103850.GA28367@avionic-0098.adnet.avionic-design.de>

On 30.11.2012 12:38, Thierry Reding wrote:
> * PGP Signed by an unknown key
> The above implies that when you submit code it shouldn't contain pieces
> that prepare for possible future extensions which may or may not be
> submitted (the exception being if such changes are part of a series
> where subsequent patches actually use them). The outcome is that the
> amount of cruft in the mainline kernel is kept to a minimum. And that's
> a very good thing.

We're now talking about actually a separation of logical and physical
driver. I can't see why that's a bad thing. Especially considering that
it's standard practice in well written drivers. Let's try to find a
technical clean solution instead of debating politics. The latter should
never be part of Linux kernel reviews.

>> I could do that for upstream. In downstream it cannot depend on DEBUG
>> flag, as these spews are an important part of how we debug problems with
>> customer devices and the DEBUG flag is never on in customer builds.
> 
> So I've just looked through these patches once more and I can't find
> where this functionality is actually used. The host1x_syncpt_debug()
> function is assigned to the nvhost_syncpt_ops.debug member, which in
> turn is only used by nvhost_syncpt_debug(). The latter, however is
> never used (not even by the debug infrastructure introduced in patch
> 4).

I have accidentally used the syncpt_op().debug() version directly. I'll
fix that.

> Okay, so what you're sayingCan here is that a huge number of people haven't
> been wise in using the preprocessor for register definitions all these
> years. That's a pretty bold statement. Now I obviously haven't looked at
> every single line in the kernel, but I have never come across this usage
> for static inline functions used for this. So, to be honest, I don't
> think this is really up for discussion. Of course if you come up with an
> example where this is done in a similar way I could be persuaded
> otherwise.

We must've talked about a bit different things. For pure register defs,
I can accommodate changing to #defines. We'd lose the code coverage
analysis, though, but if the parentheses are a make-or-break question to
upstreaming, I can change.

I was thinking of definitions like this:

static inline u32 host1x_sync_cfpeek_ctrl_cfpeek_addr_f(u32 v)
{
	return (v & 0x1ff) << 0;
}

versus

#define host1x_sync_cfpeek_ctrl_cfpeek_addr_f(v) ((v) >> 16) & 0x3ff

Both of these produce the same machine code and have same usage, but the
latter has type checking and code coverage analysis and the former is
(in my eyes) clearer. In both of these cases the usage is like this:

writel(host1x_sync_cfpeek_ctrl_cfpeek_ena_f(1)
		| host1x_sync_cfpeek_ctrl_cfpeek_channr_f(chid)
		| host1x_sync_cfpeek_ctrl_cfpeek_addr_f(rd_ptr),
	m->sync_aperture + host1x_sync_cfpeek_ctrl_r());

> But I don't see how that's relevant here. Let me quote what you said
> originally:
> 
>> This is actually the only interface to read the max value to user space,
>> which can be useful for doing some comparisons that take wrapping into
>> account. But we could just add IOCTLs and remove the sysfs entries.
> 
> To me that sounded like it was only used for debugging purposes. If you
> actually need to access this from a userspace driver then, as opposed to
> what I said earlier, this should be handled by some IOCTL.

There's a use for production code to know both the max and min, but I
think we can just scope that use out from this patch sest.

User space can use these two for checking if one of their fences has
already passed by comparing if the current value is between min and
fence, taking wrapping into account. In these cases user space can f.ex.
leave a host1x wait out from a command stream.

Terje

  reply	other threads:[~2012-12-01 11:31 UTC|newest]

Thread overview: 145+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-11-26 13:19 [RFC v2 0/8] Support for Tegra 2D hardware Terje Bergstrom
2012-11-26 13:19 ` [RFC v2 1/8] video: tegra: Add nvhost driver Terje Bergstrom
2012-11-27 10:52   ` Sivaram Nair
2012-11-28 21:23   ` Thierry Reding
2012-11-29 10:21     ` Terje Bergström
2012-11-29 11:47       ` Thierry Reding
2012-11-29 18:38         ` Stephen Warren
2012-11-30  6:52           ` Thierry Reding
2012-11-30  8:50           ` Lucas Stach
2012-12-01 11:44             ` Terje Bergström
2012-12-01 15:10               ` Thierry Reding
2012-12-01 16:55                 ` Terje Bergström
2012-12-01 17:34                   ` Lucas Stach
2012-12-01 19:29                     ` Terje Bergström
2012-12-01 21:42                       ` Dave Airlie
2012-12-01 22:39                         ` Thierry Reding
2012-12-02 11:24                         ` Terje Bergström
2012-12-02 20:55                           ` Thierry Reding
2012-12-03  6:26                             ` Terje Bergström
2012-11-30  8:56         ` Terje Bergström
2012-11-30 10:38           ` Thierry Reding
2012-12-01 11:31             ` Terje Bergström [this message]
2012-12-01 13:42               ` Daniel Vetter
2012-12-01 16:22                 ` Terje Bergström
2012-12-01 14:58               ` Thierry Reding
2012-12-01 17:13                 ` Terje Bergström
2012-12-03 19:23                 ` Stephen Warren
2012-12-04 21:31                   ` Thierry Reding
2012-12-03 19:20             ` Stephen Warren
2012-12-03 21:03               ` Thierry Reding
2012-12-04  2:08                 ` Mark Zhang
2012-12-04  2:11                 ` Mark Zhang
2012-12-04  6:17                 ` Terje Bergström
2012-11-29 18:34       ` Stephen Warren
2012-11-30  6:54         ` Terje Bergström
2012-11-30  6:53           ` Thierry Reding
2012-11-29  9:10   ` [RFC,v2,1/8] " Mark Zhang
2012-12-10 10:28     ` Terje Bergström
2012-11-26 13:19 ` [RFC v2 2/8] video: tegra: Add syncpoint wait and interrupts Terje Bergstrom
2012-11-27 11:02   ` Sivaram Nair
2012-11-29  8:44   ` Thierry Reding
2012-11-29 10:39     ` Terje Bergström
2012-11-30  7:22       ` Thierry Reding
2012-11-30  7:41         ` Terje Bergström
2012-11-29 18:41     ` Stephen Warren
2012-11-30  7:23       ` Thierry Reding
2012-11-26 13:19 ` [RFC v2 3/8] video: tegra: host: Add channel and client support Terje Bergstrom
2012-11-29 10:01   ` [RFC,v2,3/8] " Mark Zhang
2012-11-29 10:46     ` Terje Bergström
2012-11-30  6:13       ` Mark Zhang
2012-11-29 10:04   ` [RFC v2 3/8] " Thierry Reding
2012-11-29 11:00     ` Terje Bergström
2012-11-30  7:46       ` Thierry Reding
2012-11-26 13:19 ` [RFC v2 4/8] video: tegra: Add debug support Terje Bergstrom
2012-11-26 13:19 ` [RFC v2 5/8] ARM: tegra: Add auxiliary data for nvhost Terje Bergstrom
2012-11-26 23:39   ` Stephen Warren
2012-11-27  6:33     ` Terje Bergström
2012-11-27 17:17       ` Stephen Warren
2012-11-26 13:19 ` [RFC v2 6/8] gpu: drm: tegra: Remove redundant host1x Terje Bergstrom
2012-12-05  8:33   ` Thierry Reding
2012-12-05 10:10     ` Terje Bergström
2012-12-05 11:13       ` Thierry Reding
2012-12-05 11:47         ` Terje Bergström
2012-12-05 12:02           ` Lucas Stach
2012-12-05 12:03           ` Daniel Vetter
2012-12-05 12:08             ` Daniel Vetter
2012-12-05 12:22             ` Thierry Reding
2012-12-05 12:31               ` Daniel Vetter
2012-12-05 13:28                 ` Thierry Reding
2012-12-05 16:34                   ` Daniel Vetter
2012-12-05 20:44                     ` Thierry Reding
2012-12-05 12:04           ` Thierry Reding
2012-12-05 15:43             ` Terje Bergström
2012-12-10 11:42             ` Terje Bergström
2012-12-12 16:08               ` Thierry Reding
2012-12-12 16:56                 ` Terje Bergström
2012-12-13  8:48                 ` Terje Bergström
2012-12-13  8:57                   ` Thierry Reding
2012-12-13 17:58                     ` Stephen Warren
2012-12-13 20:32                       ` Thierry Reding
2012-12-14  6:09                       ` Terje Bergström
2012-12-14 16:21                         ` Stephen Warren
2012-12-14 19:59                           ` Terje Bergström
2012-12-16 12:16                             ` Thierry Reding
2012-12-16 16:37                               ` Terje Bergström
2012-12-17 20:55                                 ` Stephen Warren
2012-12-18  6:37                                   ` Terje Bergström
2012-12-20  9:17                               ` Terje Bergström
2012-12-20 17:14                                 ` Stephen Warren
2012-12-20 17:46                                   ` Terje Bergström
2012-12-20 17:55                                     ` Stephen Warren
2012-12-20 18:01                                       ` Terje Bergström
2012-12-20 20:30                                         ` Thierry Reding
2012-12-20 21:34                                           ` Terje Bergström
2012-12-20 21:50                                             ` Thierry Reding
2012-12-20 22:29                                               ` Stephen Warren
2012-12-20 22:28                                             ` Stephen Warren
2012-12-21  6:31                                               ` Terje Bergström
2012-12-21  8:57                                   ` Arto Merilainen
2012-12-21 21:19                                     ` Stephen Warren
2013-01-02  5:41                                       ` Terje Bergström
2013-01-04 10:09                                       ` Terje Bergström
2013-01-04 20:25                                         ` Stephen Warren
2013-01-07  8:20                                           ` Terje Bergström
2013-01-07 17:07                                             ` Stephen Warren
2013-01-15 11:30                                           ` Thierry Reding
2013-01-15 11:41                                             ` Terje Bergström
2012-11-26 13:19 ` [RFC v2 7/8] gpu: drm: tegra: Prime support Terje Bergstrom
2012-11-26 13:19 ` [RFC v2 8/8] drm: tegra: Add gr2d device Terje Bergstrom
2012-11-26 21:59   ` Rob Clark
2012-11-26 22:15   ` Dave Airlie
2012-11-27  6:52     ` Terje Bergström
2012-11-27  7:33       ` Dave Airlie
2012-11-27  8:16         ` Terje Bergström
2012-11-27  8:32           ` Dave Airlie
2012-11-27  8:45             ` Terje Bergström
2012-11-27 10:22               ` Lucas Stach
2012-11-27 10:37                 ` Thierry Reding
2012-11-27 11:31                   ` Terje Bergström
2012-11-27 11:47                     ` Lucas Stach
2012-11-27 12:59                       ` Terje Bergström
2012-11-27 23:00                     ` Dave Airlie
2012-11-28 13:17                       ` Terje Bergström
2012-11-28 13:33                         ` Lucas Stach
2012-11-28 13:57                           ` Terje Bergström
2012-11-28 14:06                             ` Lucas Stach
2012-11-28 14:45                               ` Terje Bergström
2012-11-28 15:13                                 ` Lucas Stach
2012-11-28 16:23                                   ` Terje Bergström
2012-11-28 18:46                                     ` Lucas Stach
2012-11-29  8:17                                       ` Terje Bergström
2012-11-29  9:09                                         ` Lucas Stach
2012-11-29 12:14                                           ` Thierry Reding
2012-11-30  7:44                                             ` Terje Bergström
2012-11-30  7:53                                               ` Lucas Stach
2012-11-29 13:36                                           ` Terje Bergström
2012-11-28 16:24                                 ` Stephen Warren
2012-11-28 20:53                           ` Thomas Hellstrom
2012-12-03  9:30     ` Mark Zhang
2012-12-03  9:40       ` Daniel Vetter
2012-12-04  1:49         ` Mark Zhang
2012-11-29  7:37   ` [RFC,v2,8/8] " Mark Zhang
2012-12-01 14:45 ` [RFC v2 0/8] Support for Tegra 2D hardware Thierry Reding
2012-12-01 17:08   ` Terje Bergström
2012-12-01 19:29     ` Thierry Reding

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=50B9EA76.10803@nvidia.com \
    --to=tbergstrom@nvidia.com \
    --cc=dri-devel@lists.freedesktop.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-tegra@vger.kernel.org \
    --cc=thierry.reding@avionic-design.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).