From: Vince Hsu <vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
To: Thierry Reding <thierry.reding-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
Cc: swarren-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org,
nouveau-PD4FTy7X32lNgt0PjOBp9y5qC8QIuHrW@public.gmane.org,
linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
bskeggs-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org,
linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
seven-FA6nBp6kBxZzu6KWmfFNGwC/G2K4zDHf@public.gmane.org
Subject: Re: [PATCH 3/11] memory: tegra: add flush operation for Tegra124 memory clients
Date: Tue, 6 Jan 2015 23:53:13 +0800 [thread overview]
Message-ID: <20150106155312.GA20547@nvidia.com> (raw)
In-Reply-To: <20150106152750.GR31830-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
On 04:27:52PM Jan 06, Thierry Reding wrote:
> * PGP Signed by an unknown key
>
> On Tue, Jan 06, 2015 at 11:07:45PM +0800, Vince Hsu wrote:
> > On 03:30:00PM Jan 06, Thierry Reding wrote:
> > > > Old Signed by an unknown key
> > >
> > > On Tue, Dec 23, 2014 at 06:39:56PM +0800, Vince Hsu wrote:
> > > > Signed-off-by: Vince Hsu <vinceh@nvidia.com>
> > > > ---
> > > > drivers/memory/tegra/tegra124.c | 82 +++++++++++++++++++++++++++++++++++++++++
> > > > 1 file changed, 82 insertions(+)
> > > >
> > > > diff --git a/drivers/memory/tegra/tegra124.c b/drivers/memory/tegra/tegra124.c
> > > > index 278d40b854c1..036935743a0a 100644
> > > > --- a/drivers/memory/tegra/tegra124.c
> > > > +++ b/drivers/memory/tegra/tegra124.c
> > > > @@ -6,6 +6,7 @@
> > > > * published by the Free Software Foundation.
> > > > */
> > > >
> > > > +#include <linux/delay.h>
> > > > #include <linux/of.h>
> > > > #include <linux/mm.h>
> > > >
> > > > @@ -959,7 +960,85 @@ static const struct tegra_smmu_swgroup tegra124_swgroups[] = {
> > > > { .swgroup = TEGRA_SWGROUP_VI, .reg = 0x280 },
> > > > };
> > > >
> > > > +static const struct tegra_mc_hr tegra124_mc_hr[] = {
> > > > + {TEGRA_SWGROUP_AFI, 0x200, 0x200, 0},
> > > > + {TEGRA_SWGROUP_AVPC, 0x200, 0x200, 1},
> > > > + {TEGRA_SWGROUP_DC, 0x200, 0x200, 2},
> > > > + {TEGRA_SWGROUP_DCB, 0x200, 0x200, 3},
> > > > + {TEGRA_SWGROUP_HC, 0x200, 0x200, 6},
> > > > + {TEGRA_SWGROUP_HDA, 0x200, 0x200, 7},
> > > > + {TEGRA_SWGROUP_ISP2, 0x200, 0x200, 8},
> > > > + {TEGRA_SWGROUP_MPCORE, 0x200, 0x200, 9},
> > > > + {TEGRA_SWGROUP_MPCORELP, 0x200, 0x200, 10},
> > > > + {TEGRA_SWGROUP_MSENC, 0x200, 0x200, 11},
> > > > + {TEGRA_SWGROUP_PPCS, 0x200, 0x200, 14},
> > > > + {TEGRA_SWGROUP_SATA, 0x200, 0x200, 15},
> > > > + {TEGRA_SWGROUP_VDE, 0x200, 0x200, 16},
> > > > + {TEGRA_SWGROUP_VI, 0x200, 0x200, 17},
> > > > + {TEGRA_SWGROUP_VIC, 0x200, 0x200, 18},
> > > > + {TEGRA_SWGROUP_XUSB_HOST, 0x200, 0x200, 19},
> > > > + {TEGRA_SWGROUP_XUSB_DEV, 0x200, 0x200, 20},
> > > > + {TEGRA_SWGROUP_TSEC, 0x200, 0x200, 22},
> > > > + {TEGRA_SWGROUP_SDMMC1A, 0x200, 0x200, 29},
> > > > + {TEGRA_SWGROUP_SDMMC2A, 0x200, 0x200, 30},
> > > > + {TEGRA_SWGROUP_SDMMC3A, 0x200, 0x200, 31},
> > >
> > > The documentation that I have says that the status register for these is
> > > 0x204.
> > Oops. Thanks for catching this. Will fix.
> >
> > >
> > > > + {TEGRA_SWGROUP_SDMMC4A, 0x970, 0x974, 0},
> > > > + {TEGRA_SWGROUP_ISP2B, 0x970, 0x974, 1},
> > > > + {TEGRA_SWGROUP_GPU, 0x970, 0x974, 2},
> > > > +};
> > > > +
> > > > #ifdef CONFIG_ARCH_TEGRA_124_SOC
> > > > +
> > > > +static bool tegra124_stable_hotreset_check(struct tegra_mc *mc,
> > > > + u32 reg, u32 *stat)
> > > > +{
> > > > + int i;
> > > > + u32 cur_stat;
> > > > + u32 prv_stat;
> > > > +
> > > > + prv_stat = mc_readl(mc, reg);
> > > > + for (i = 0; i < 5; i++) {
> > > > + cur_stat = mc_readl(mc, reg);
> > > > + if (cur_stat != prv_stat)
> > > > + return false;
> > > > + }
> > >
> > > Why this loop? The function is already called in a polling loop below.
> > > Also why compare to the previous value of the register? Isn't the only
> > > thing we're interested in the value of the specific bit?
> > I recall it's due to a HW bug that there might be a gitch if we program
> > the ctrl reg and then read the status reg in a short window. This function
> > is to make sure we have a stable status.
>
> This warrants a comment, then.
Okay.
>
> > > > + *stat = cur_stat;
> > > > + return true;
> > > > +}
> > > > +
> > > > +static int tegra124_mc_flush(struct tegra_mc *mc,
> > > > + const struct tegra_mc_hr *hr_client, bool enable)
> > > > +{
> > > > + u32 val;
> > > > +
> > > > + if (!mc || !hr_client)
> > > > + return -EINVAL;
> > > > +
> > > > + val = mc_readl(mc, hr_client->ctrl);
> > > > + if (enable)
> > > > + val |= BIT(hr_client->bit);
> > > > + else
> > > > + val &= ~BIT(hr_client->bit);
> > > > + mc_writel(mc, val, hr_client->ctrl);
> > > > + mc_readl(mc, hr_client->ctrl);
> > > > +
> > > > + /* poll till the flush is done */
> > > > + if (enable) {
> > > > + do {
> > > > + udelay(10);
> > >
> > > This should probably be usleep_range(10, 20) or something.
> > Maybe no. We might need some spin lock here to ensure only one flushing
> > operation requested and no race could happen.
>
> We should use a mutex, then. There's no saying how long this will take
> and busy-looping indefinitely is a bad idea. Though it seems to me like
> we don't need to lock around the polling loop here since we're merely
> reading a status register. We would only need to lock around accesses to
> the control register to make sure two processes can't step on each
> others's toes.
We can use metux definitely. If two processes touch the ctrl registers
sequentially and poll the status register in parallel, we dont' know whether
the glitch is caused by the HW bug or the concurrent ctrl register programming?
We should lock the status checking as well.
>
> > > Would it be difficult to implement this for Tegra30 and Tegra114?
> > No. But I have to check the detail in Tegra30 and Tegra114. And the biggest
> > problem is I don't have the boards to test.
>
> I can help with testing. Though that raises the question of how this can
> be tested. It seems like this feature is used to make sure that all
> outstanding memory requests from clients are flushed before resetting a
> module. Typically Linux assumes that devices do that anyway, so if a
> device is suspended or shut down, the corresponding function should
> ensure that all outstanding transfers have been cancelled and are
> flushed.
The flushing operation can be requested by runtime PM if the device supports
it.
>
> Also we've managed just fine so far, so I'm beginning to wonder whether
> we actually need this feature on Linux. If not, how do we test that this
> is indeed doing what it should? How to trigger a condition that requires
> flushing and how do we determine that flushing actually fixes things?
Sorry that I can't answer how to test it because I'm not a mc expert.
What I can do is testing the power up/off sequence a lot of time and check if
the device can still work normally. We need this feature because the TRM
requires so?
Thanks,
Vince
_______________________________________________
Nouveau mailing list
Nouveau@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/nouveau
WARNING: multiple messages have this Message-ID (diff)
From: Vince Hsu <vinceh@nvidia.com>
To: Thierry Reding <thierry.reding@gmail.com>
Cc: <swarren@wwwdotorg.org>, <gnurou@gmail.com>, <bskeggs@redhat.com>,
<martin.peres@free.fr>, <seven@nimrod-online.com>,
<samuel.pitoiset@gmail.com>, <nouveau@lists.freedesktop.org>,
<linux-tegra@vger.kernel.org>, <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH 3/11] memory: tegra: add flush operation for Tegra124 memory clients
Date: Tue, 6 Jan 2015 23:53:13 +0800 [thread overview]
Message-ID: <20150106155312.GA20547@nvidia.com> (raw)
In-Reply-To: <20150106152750.GR31830@ulmo.nvidia.com>
On 04:27:52PM Jan 06, Thierry Reding wrote:
> * PGP Signed by an unknown key
>
> On Tue, Jan 06, 2015 at 11:07:45PM +0800, Vince Hsu wrote:
> > On 03:30:00PM Jan 06, Thierry Reding wrote:
> > > > Old Signed by an unknown key
> > >
> > > On Tue, Dec 23, 2014 at 06:39:56PM +0800, Vince Hsu wrote:
> > > > Signed-off-by: Vince Hsu <vinceh@nvidia.com>
> > > > ---
> > > > drivers/memory/tegra/tegra124.c | 82 +++++++++++++++++++++++++++++++++++++++++
> > > > 1 file changed, 82 insertions(+)
> > > >
> > > > diff --git a/drivers/memory/tegra/tegra124.c b/drivers/memory/tegra/tegra124.c
> > > > index 278d40b854c1..036935743a0a 100644
> > > > --- a/drivers/memory/tegra/tegra124.c
> > > > +++ b/drivers/memory/tegra/tegra124.c
> > > > @@ -6,6 +6,7 @@
> > > > * published by the Free Software Foundation.
> > > > */
> > > >
> > > > +#include <linux/delay.h>
> > > > #include <linux/of.h>
> > > > #include <linux/mm.h>
> > > >
> > > > @@ -959,7 +960,85 @@ static const struct tegra_smmu_swgroup tegra124_swgroups[] = {
> > > > { .swgroup = TEGRA_SWGROUP_VI, .reg = 0x280 },
> > > > };
> > > >
> > > > +static const struct tegra_mc_hr tegra124_mc_hr[] = {
> > > > + {TEGRA_SWGROUP_AFI, 0x200, 0x200, 0},
> > > > + {TEGRA_SWGROUP_AVPC, 0x200, 0x200, 1},
> > > > + {TEGRA_SWGROUP_DC, 0x200, 0x200, 2},
> > > > + {TEGRA_SWGROUP_DCB, 0x200, 0x200, 3},
> > > > + {TEGRA_SWGROUP_HC, 0x200, 0x200, 6},
> > > > + {TEGRA_SWGROUP_HDA, 0x200, 0x200, 7},
> > > > + {TEGRA_SWGROUP_ISP2, 0x200, 0x200, 8},
> > > > + {TEGRA_SWGROUP_MPCORE, 0x200, 0x200, 9},
> > > > + {TEGRA_SWGROUP_MPCORELP, 0x200, 0x200, 10},
> > > > + {TEGRA_SWGROUP_MSENC, 0x200, 0x200, 11},
> > > > + {TEGRA_SWGROUP_PPCS, 0x200, 0x200, 14},
> > > > + {TEGRA_SWGROUP_SATA, 0x200, 0x200, 15},
> > > > + {TEGRA_SWGROUP_VDE, 0x200, 0x200, 16},
> > > > + {TEGRA_SWGROUP_VI, 0x200, 0x200, 17},
> > > > + {TEGRA_SWGROUP_VIC, 0x200, 0x200, 18},
> > > > + {TEGRA_SWGROUP_XUSB_HOST, 0x200, 0x200, 19},
> > > > + {TEGRA_SWGROUP_XUSB_DEV, 0x200, 0x200, 20},
> > > > + {TEGRA_SWGROUP_TSEC, 0x200, 0x200, 22},
> > > > + {TEGRA_SWGROUP_SDMMC1A, 0x200, 0x200, 29},
> > > > + {TEGRA_SWGROUP_SDMMC2A, 0x200, 0x200, 30},
> > > > + {TEGRA_SWGROUP_SDMMC3A, 0x200, 0x200, 31},
> > >
> > > The documentation that I have says that the status register for these is
> > > 0x204.
> > Oops. Thanks for catching this. Will fix.
> >
> > >
> > > > + {TEGRA_SWGROUP_SDMMC4A, 0x970, 0x974, 0},
> > > > + {TEGRA_SWGROUP_ISP2B, 0x970, 0x974, 1},
> > > > + {TEGRA_SWGROUP_GPU, 0x970, 0x974, 2},
> > > > +};
> > > > +
> > > > #ifdef CONFIG_ARCH_TEGRA_124_SOC
> > > > +
> > > > +static bool tegra124_stable_hotreset_check(struct tegra_mc *mc,
> > > > + u32 reg, u32 *stat)
> > > > +{
> > > > + int i;
> > > > + u32 cur_stat;
> > > > + u32 prv_stat;
> > > > +
> > > > + prv_stat = mc_readl(mc, reg);
> > > > + for (i = 0; i < 5; i++) {
> > > > + cur_stat = mc_readl(mc, reg);
> > > > + if (cur_stat != prv_stat)
> > > > + return false;
> > > > + }
> > >
> > > Why this loop? The function is already called in a polling loop below.
> > > Also why compare to the previous value of the register? Isn't the only
> > > thing we're interested in the value of the specific bit?
> > I recall it's due to a HW bug that there might be a gitch if we program
> > the ctrl reg and then read the status reg in a short window. This function
> > is to make sure we have a stable status.
>
> This warrants a comment, then.
Okay.
>
> > > > + *stat = cur_stat;
> > > > + return true;
> > > > +}
> > > > +
> > > > +static int tegra124_mc_flush(struct tegra_mc *mc,
> > > > + const struct tegra_mc_hr *hr_client, bool enable)
> > > > +{
> > > > + u32 val;
> > > > +
> > > > + if (!mc || !hr_client)
> > > > + return -EINVAL;
> > > > +
> > > > + val = mc_readl(mc, hr_client->ctrl);
> > > > + if (enable)
> > > > + val |= BIT(hr_client->bit);
> > > > + else
> > > > + val &= ~BIT(hr_client->bit);
> > > > + mc_writel(mc, val, hr_client->ctrl);
> > > > + mc_readl(mc, hr_client->ctrl);
> > > > +
> > > > + /* poll till the flush is done */
> > > > + if (enable) {
> > > > + do {
> > > > + udelay(10);
> > >
> > > This should probably be usleep_range(10, 20) or something.
> > Maybe no. We might need some spin lock here to ensure only one flushing
> > operation requested and no race could happen.
>
> We should use a mutex, then. There's no saying how long this will take
> and busy-looping indefinitely is a bad idea. Though it seems to me like
> we don't need to lock around the polling loop here since we're merely
> reading a status register. We would only need to lock around accesses to
> the control register to make sure two processes can't step on each
> others's toes.
We can use metux definitely. If two processes touch the ctrl registers
sequentially and poll the status register in parallel, we dont' know whether
the glitch is caused by the HW bug or the concurrent ctrl register programming?
We should lock the status checking as well.
>
> > > Would it be difficult to implement this for Tegra30 and Tegra114?
> > No. But I have to check the detail in Tegra30 and Tegra114. And the biggest
> > problem is I don't have the boards to test.
>
> I can help with testing. Though that raises the question of how this can
> be tested. It seems like this feature is used to make sure that all
> outstanding memory requests from clients are flushed before resetting a
> module. Typically Linux assumes that devices do that anyway, so if a
> device is suspended or shut down, the corresponding function should
> ensure that all outstanding transfers have been cancelled and are
> flushed.
The flushing operation can be requested by runtime PM if the device supports
it.
>
> Also we've managed just fine so far, so I'm beginning to wonder whether
> we actually need this feature on Linux. If not, how do we test that this
> is indeed doing what it should? How to trigger a condition that requires
> flushing and how do we determine that flushing actually fixes things?
Sorry that I can't answer how to test it because I'm not a mc expert.
What I can do is testing the power up/off sequence a lot of time and check if
the device can still work normally. We need this feature because the TRM
requires so?
Thanks,
Vince
next prev parent reply other threads:[~2015-01-06 15:53 UTC|newest]
Thread overview: 139+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-12-23 10:39 [PATCH 0/11] Add suspend/resume support for GK20A Vince Hsu
2014-12-23 10:39 ` Vince Hsu
[not found] ` <1419331204-26679-1-git-send-email-vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-23 10:39 ` [PATCH 1/11] ARM: tegra: add function to control the GPU rail clamp Vince Hsu
2014-12-23 10:39 ` Vince Hsu
[not found] ` <1419331204-26679-2-git-send-email-vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-24 13:16 ` Lucas Stach
2014-12-24 13:16 ` Lucas Stach
[not found] ` <1419426990.2179.7.camel-8ppwABl0HbeELgA04lAiVw@public.gmane.org>
2014-12-25 2:28 ` Vince Hsu
2014-12-25 2:28 ` Vince Hsu
[not found] ` <549B7638.2010405-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-25 20:34 ` Lucas Stach
2014-12-25 20:34 ` Lucas Stach
[not found] ` <1419539683.2165.6.camel-8ppwABl0HbeELgA04lAiVw@public.gmane.org>
2014-12-29 2:49 ` Vince Hsu
2014-12-29 2:49 ` Vince Hsu
[not found] ` <54A0C148.6030400-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-30 16:42 ` Lucas Stach
2014-12-30 16:42 ` Lucas Stach
[not found] ` <1419957752.4082.2.camel-8ppwABl0HbeELgA04lAiVw@public.gmane.org>
2015-01-05 6:55 ` Vince Hsu
2015-01-05 6:55 ` Vince Hsu
2015-01-05 15:09 ` Thierry Reding
2015-01-05 15:09 ` Thierry Reding
[not found] ` <20150105150932.GG12010-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-06 2:11 ` Vince Hsu
2015-01-06 2:11 ` Vince Hsu
[not found] ` <54AB445D.7010303-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-06 11:15 ` Thierry Reding
2015-01-06 11:15 ` Thierry Reding
[not found] ` <20150106111538.GB31830-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-06 12:03 ` Vince Hsu
2015-01-06 12:03 ` Vince Hsu
2015-01-06 13:29 ` Thierry Reding
2015-01-06 13:51 ` Vince Hsu
2015-01-06 13:51 ` Vince Hsu
[not found] ` <20150106135110.GA18076-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-06 14:23 ` Thierry Reding
2015-01-06 14:23 ` Thierry Reding
2015-01-07 10:19 ` Peter De Schrijver
2015-01-07 10:19 ` Peter De Schrijver
[not found] ` <20150107101900.GP10073-Rysk9IDjsxmJz7etNGeUX8VPkgjIgRvpAL8bYrjMMd8@public.gmane.org>
2015-01-07 10:49 ` Vince Hsu
2015-01-07 10:49 ` Vince Hsu
2015-01-07 13:27 ` Thierry Reding
2015-01-07 14:08 ` Peter De Schrijver
2015-01-07 14:08 ` Peter De Schrijver
2015-01-07 14:28 ` Vince Hsu
2015-01-07 14:28 ` Vince Hsu
[not found] ` <20150107142828.GB7392-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-07 14:48 ` Thierry Reding
2015-01-07 14:48 ` Thierry Reding
2015-01-08 4:25 ` Vince Hsu
2015-01-08 4:25 ` Vince Hsu
[not found] ` <54AE06AE.8080603-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-08 8:03 ` Thierry Reding
2015-01-08 8:03 ` Thierry Reding
2015-01-07 14:12 ` Peter De Schrijver
2015-01-07 14:12 ` Peter De Schrijver
2015-01-07 14:19 ` Vince Hsu
2015-01-07 14:19 ` Vince Hsu
2015-01-07 15:12 ` Thierry Reding
2015-01-08 4:23 ` Vince Hsu
2015-01-08 4:23 ` Vince Hsu
2015-01-08 9:32 ` Peter De Schrijver
2015-01-08 9:32 ` Peter De Schrijver
[not found] ` <20150108093205.GV10073-Rysk9IDjsxmJz7etNGeUX8VPkgjIgRvpAL8bYrjMMd8@public.gmane.org>
2015-01-08 11:41 ` Thierry Reding
2015-01-08 11:41 ` Thierry Reding
[not found] ` <20150108114153.GL1987-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-08 12:41 ` Peter De Schrijver
2015-01-08 12:41 ` Peter De Schrijver
2015-01-08 9:39 ` Peter De Schrijver
2015-01-08 9:39 ` Peter De Schrijver
[not found] ` <20150108093957.GW10073-Rysk9IDjsxmJz7etNGeUX8VPkgjIgRvpAL8bYrjMMd8@public.gmane.org>
2015-01-08 11:44 ` Thierry Reding
2015-01-08 11:44 ` Thierry Reding
2014-12-24 13:52 ` Dmitry Osipenko
2014-12-24 13:52 ` Dmitry Osipenko
[not found] ` <549AC511.5040507-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2014-12-25 2:05 ` Vince Hsu
2014-12-25 2:05 ` Vince Hsu
2014-12-23 10:39 ` [PATCH 2/11] memory: tegra: add mc flush support Vince Hsu
2014-12-23 10:39 ` Vince Hsu
2015-01-06 14:18 ` Thierry Reding
[not found] ` <20150106141821.GJ31830-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-07 10:08 ` Peter De Schrijver
2015-01-07 10:08 ` Peter De Schrijver
[not found] ` <20150107100804.GO10073-Rysk9IDjsxmJz7etNGeUX8VPkgjIgRvpAL8bYrjMMd8@public.gmane.org>
2015-01-07 13:34 ` Thierry Reding
2015-01-07 13:34 ` Thierry Reding
2014-12-23 10:39 ` [PATCH 3/11] memory: tegra: add flush operation for Tegra124 memory clients Vince Hsu
2014-12-23 10:39 ` Vince Hsu
2015-01-06 14:30 ` Thierry Reding
2015-01-06 15:07 ` Vince Hsu
2015-01-06 15:07 ` Vince Hsu
2015-01-06 15:27 ` Thierry Reding
[not found] ` <20150106152750.GR31830-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-06 15:53 ` Vince Hsu [this message]
2015-01-06 15:53 ` Vince Hsu
2014-12-23 10:39 ` [PATCH 4/11] ARM: tegra: add mc node for Tegra124 GPU Vince Hsu
2014-12-23 10:39 ` Vince Hsu
2014-12-23 10:39 ` [PATCH nouveau 05/11] platform: switch to the new gpu rail clamping function Vince Hsu
2014-12-23 10:39 ` Vince Hsu
2014-12-23 10:39 ` [PATCH nouveau 06/11] platform: complete the power up/down sequence Vince Hsu
2014-12-23 10:39 ` Vince Hsu
[not found] ` <1419331204-26679-7-git-send-email-vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-24 13:23 ` Lucas Stach
2014-12-24 13:23 ` Lucas Stach
[not found] ` <1419427385.2179.13.camel-8ppwABl0HbeELgA04lAiVw@public.gmane.org>
2014-12-25 2:42 ` Vince Hsu
2014-12-25 2:42 ` Vince Hsu
[not found] ` <549B79B2.6010301-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-05 15:25 ` Thierry Reding
2015-01-05 15:25 ` Thierry Reding
[not found] ` <20150105152552.GH12010-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-06 9:34 ` Vince Hsu
2015-01-06 9:34 ` Vince Hsu
2015-01-06 11:36 ` Thierry Reding
2015-01-06 12:13 ` Vince Hsu
2015-01-06 12:13 ` Vince Hsu
[not found] ` <54ABD14D.30003-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-06 13:55 ` Thierry Reding
2015-01-06 13:55 ` Thierry Reding
2015-01-06 14:19 ` Vince Hsu
2015-01-06 14:19 ` Vince Hsu
[not found] ` <20150106141948.GA18598-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-06 14:24 ` Thierry Reding
2015-01-06 14:24 ` Thierry Reding
2014-12-23 10:40 ` [PATCH nouveau 07/11] instmem: make nv50_instmem_priv public Vince Hsu
2014-12-23 10:40 ` Vince Hsu
2014-12-23 10:40 ` [PATCH nouveau 08/11] instmem: add dummy support for GK20A Vince Hsu
2014-12-23 10:40 ` Vince Hsu
[not found] ` <1419331204-26679-9-git-send-email-vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-23 16:39 ` Ilia Mirkin
2014-12-23 16:39 ` [Nouveau] " Ilia Mirkin
[not found] ` <CAKb7UvgCizkaK2aZeWp=mgH34Ur3hi0hSFghopkpkkBeuqzsoQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-12-24 2:44 ` Vince Hsu
2014-12-24 2:44 ` [Nouveau] " Vince Hsu
2014-12-23 10:40 ` [PATCH nouveau 09/11] drm: export some variable and functions to resue the PM functions Vince Hsu
2014-12-23 10:40 ` Vince Hsu
[not found] ` <1419331204-26679-10-git-send-email-vinceh-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2014-12-30 2:34 ` Emil Velikov
2014-12-30 2:34 ` [Nouveau] " Emil Velikov
[not found] ` <54A20F4D.4040100-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>
2014-12-30 3:18 ` Vince Hsu
2014-12-30 3:18 ` [Nouveau] " Vince Hsu
[not found] ` <54A2198A.4000707-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-05 15:32 ` Thierry Reding
2015-01-05 15:32 ` [Nouveau] " Thierry Reding
[not found] ` <20150105153252.GI12010-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-05 19:50 ` Alexandre Courbot
2015-01-05 19:50 ` [Nouveau] " Alexandre Courbot
[not found] ` <CAAVeFuK-SgUbtHADX4-pXN5_ayzvEd+1KxJOBcRe2tmDfHaLEA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-01-06 9:36 ` Vince Hsu
2015-01-06 9:36 ` [Nouveau] " Vince Hsu
2015-01-06 11:49 ` Thierry Reding
2015-01-06 11:49 ` [Nouveau] " Thierry Reding
2015-01-06 12:27 ` Vince Hsu
2015-01-06 12:27 ` Vince Hsu
[not found] ` <54ABD49A.6080501-DDmLM1+adcrQT0dZR+AlfA@public.gmane.org>
2015-01-06 14:37 ` Thierry Reding
2015-01-06 14:37 ` [Nouveau] " Thierry Reding
2015-01-06 14:44 ` Ilia Mirkin
[not found] ` <CAKb7UvgomyQkiwfGTdyuU-muE-_pPxOSmeXh9uQ6-ri0HHxLrQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2015-01-06 14:50 ` Thierry Reding
2015-01-06 14:50 ` Thierry Reding
[not found] ` <20150106145054.GO31830-AwZRO8vwLAwmlAP/+Wk3EA@public.gmane.org>
2015-01-06 15:03 ` Ilia Mirkin
2015-01-06 15:03 ` [Nouveau] " Ilia Mirkin
2015-01-06 15:35 ` Thierry Reding
2014-12-23 10:40 ` [PATCH nouveau 10/11] platform: add suspend/resume support Vince Hsu
2014-12-23 10:40 ` Vince Hsu
2014-12-23 10:40 ` [PATCH nouveau 11/11] platform: add PM runtime " Vince Hsu
2014-12-23 10:40 ` Vince Hsu
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=20150106155312.GA20547@nvidia.com \
--to=vinceh-ddmlm1+adcrqt0dzr+alfa@public.gmane.org \
--cc=bskeggs-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
--cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=linux-tegra-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=nouveau-PD4FTy7X32lNgt0PjOBp9y5qC8QIuHrW@public.gmane.org \
--cc=seven-FA6nBp6kBxZzu6KWmfFNGwC/G2K4zDHf@public.gmane.org \
--cc=swarren-3lzwWm7+Weoh9ZMKESR00Q@public.gmane.org \
--cc=thierry.reding-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.