All of lore.kernel.org
 help / color / mirror / Atom feed
From: Ben Dooks <ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org>
To: Bryan Wu <cooloney-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
Cc: Michael Hennerich
	<michael.hennerich-OyLXuOCK7orQT0dZR+AlfA@public.gmane.org>,
	i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org,
	Ben Dooks <ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org>
Subject: Re: [PATCH 1/1] Blackfin I2C Driver: Functional power management support
Date: Mon, 28 Jul 2008 12:08:45 +0100	[thread overview]
Message-ID: <20080728110845.GX26938@trinity.fluff.org> (raw)
In-Reply-To: <386072610807280307k7bed8922t396be43b28fa749a-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>

On Mon, Jul 28, 2008 at 06:07:28PM +0800, Bryan Wu wrote:
> On Mon, Jul 28, 2008 at 5:23 PM, Ben Dooks <ben-linux-elnMNo+KYs3YtjvyW6yDsg@public.gmane.org> wrote:
> > On Sun, Jul 27, 2008 at 02:41:54PM +0800, Bryan Wu wrote:
> >> From: Michael Hennerich <michael.hennerich-OyLXuOCK7orQT0dZR+AlfA@public.gmane.org>
> >>
> >> PM_SUSPEND_MEM: Blackfin does not maintain register state through
> >> Hibernate. Save and restore peripheral base initialization during
> >> PM transitions.
> >>
> >> Signed-off-by: Michael Hennerich <michael.hennerich-OyLXuOCK7orQT0dZR+AlfA@public.gmane.org>
> >> Signed-off-by: Bryan Wu <cooloney-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
> >> ---
> >>  drivers/i2c/busses/i2c-bfin-twi.c |   35 ++++++++++++++++++++++++-----------
> >>  1 files changed, 24 insertions(+), 11 deletions(-)
> >>
> >> diff --git a/drivers/i2c/busses/i2c-bfin-twi.c b/drivers/i2c/busses/i2c-bfin-twi.c
> >> index 48d084b..3c855ff 100644
> >> --- a/drivers/i2c/busses/i2c-bfin-twi.c
> >> +++ b/drivers/i2c/busses/i2c-bfin-twi.c
> >> @@ -49,6 +49,8 @@ struct bfin_twi_iface {
> >>       struct i2c_msg          *pmsg;
> >>       int                     msg_num;
> >>       int                     cur_msg;
> >> +     u16                     saved_clkdiv;
> >> +     u16                     saved_control;
> >>       void __iomem            *regs_base;
> >>  };
> >>
> >> @@ -565,32 +567,43 @@ static u32 bfin_twi_functionality(struct i2c_adapter *adap)
> >>              I2C_FUNC_I2C;
> >>  }
> >>
> >> -
> >>  static struct i2c_algorithm bfin_twi_algorithm = {
> >>       .master_xfer   = bfin_twi_master_xfer,
> >>       .smbus_xfer    = bfin_twi_smbus_xfer,
> >>       .functionality = bfin_twi_functionality,
> >>  };
> >>
> >> -
> >> -static int i2c_bfin_twi_suspend(struct platform_device *dev, pm_message_t state)
> >> +static int i2c_bfin_twi_suspend(struct platform_device *pdev, pm_message_t state)
> >>  {
> >> -     struct bfin_twi_iface *iface = platform_get_drvdata(dev);
> >> +     struct bfin_twi_iface *iface = platform_get_drvdata(pdev);
> >> +
> >> +     iface->saved_clkdiv = read_CLKDIV(iface);
> >> +     iface->saved_control = read_CONTROL(iface);
> >> +
> >> +     free_irq(iface->irq, iface);
> >>
> >>       /* Disable TWI */
> >> -     write_CONTROL(iface, read_CONTROL(iface) & ~TWI_ENA);
> >> -     SSYNC();
> >> +     write_CONTROL(iface, iface->saved_control & ~TWI_ENA);
> >
> > I assume removing the SSYNC() call is valid?
> >
> 
> Yes, I think it is OK for that. We tested on our platform.
> Actually, keeping the SSYNC() is not a big deal for this driver.
> How do you think Michael?
> 
> >>       return 0;
> >>  }
> >>
> >> -static int i2c_bfin_twi_resume(struct platform_device *dev)
> >> +static int i2c_bfin_twi_resume(struct platform_device *pdev)
> >>  {
> >> -     struct bfin_twi_iface *iface = platform_get_drvdata(dev);
> >> +     struct bfin_twi_iface *iface = platform_get_drvdata(pdev);
> >>
> >> -     /* Enable TWI */
> >> -     write_CONTROL(iface, read_CONTROL(iface) | TWI_ENA);
> >> -     SSYNC();
> >> +     int rc = request_irq(iface->irq, bfin_twi_interrupt_entry,
> >> +             IRQF_DISABLED, pdev->name, iface);
> >> +     if (rc) {
> >> +             dev_err(&pdev->dev, "Can't get IRQ %d !\n", iface->irq);
> >> +             return -ENODEV;
> >> +     }
> >> +
> >> +     /* Resume TWI interface clock as specified */
> >> +     write_CLKDIV(iface, iface->saved_clkdiv);
> >> +
> >> +     /* Resume TWI */
> >> +     write_CONTROL(iface, iface->saved_control);
> >>
> >>       return 0;
> >>  }
> >> --
> >> 1.5.6
> >
> > if removing the SSYNC() call is ok, then I'll queue this into
> > my tree which I will be requesting a pull asap.

ok, this is in my queue, unless anyone objects then it'll be pushed
out later today.

-- 
Ben

Q:      What's a light-year?
A:      One-third less calories than a regular year.


_______________________________________________
i2c mailing list
i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org
http://lists.lm-sensors.org/mailman/listinfo/i2c

  parent reply	other threads:[~2008-07-28 11:08 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2008-07-27  6:41 [PATCH 1/1] Blackfin I2C Driver: Functional power management support Bryan Wu
     [not found] ` <1217140914-21718-1-git-send-email-cooloney-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>
2008-07-28  9:23   ` Ben Dooks
     [not found]     ` <20080728092317.GB2716-elnMNo+KYs3pIgCt6eIbzw@public.gmane.org>
2008-07-28 10:07       ` Bryan Wu
     [not found]         ` <386072610807280307k7bed8922t396be43b28fa749a-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2008-07-28 11:08           ` Ben Dooks [this message]
     [not found]             ` <20080728110845.GX26938-SMNkleLxa3Z6Wcw2j4pizdi2O/JbrIOy@public.gmane.org>
2008-07-28 12:16               ` Hennerich, Michael
     [not found]                 ` <8A42379416420646B9BFAC9682273B6D035F0772-pcKY8lWzTjquVPpjEGsWsTcYPEmu4y7e@public.gmane.org>
2008-07-28 13:18                   ` Ben Dooks

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=20080728110845.GX26938@trinity.fluff.org \
    --to=ben-linux-elnmno+kys3ytjvyw6ydsg@public.gmane.org \
    --cc=cooloney-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org \
    --cc=i2c-GZX6beZjE8VD60Wz+7aTrA@public.gmane.org \
    --cc=michael.hennerich-OyLXuOCK7orQT0dZR+AlfA@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.