* [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
@ 2009-11-10 19:43 Albrecht Dreß
  2009-11-10 19:59 ` Grant Likely
  0 siblings, 1 reply; 10+ messages in thread
From: Albrecht Dreß @ 2009-11-10 19:43 UTC (permalink / raw)
  To: Linux PPC Development, Grant Likely, devicetree-discuss,
	Wim Van Sebroeck
Use the MPC5200 GPT api for the WDT which drastically simplifies this file.
Signed-off-by: Albrecht Dre=DF <albrecht.dress@arcor.de>
---
 drivers/watchdog/mpc5200_wdt.c |  246 +++++++++++-------------------------=
----
 1 files changed, 65 insertions(+), 181 deletions(-)
diff --git a/drivers/watchdog/mpc5200_wdt.c b/drivers/watchdog/mpc5200_wdt.=
c
index fa9c47c..5bb553c 100644
--- a/drivers/watchdog/mpc5200_wdt.c
+++ b/drivers/watchdog/mpc5200_wdt.c
@@ -2,25 +2,16 @@
 #include <linux/module.h>
 #include <linux/miscdevice.h>
 #include <linux/watchdog.h>
-#include <linux/io.h>
-#include <linux/spinlock.h>
 #include <linux/of_platform.h>
 #include <linux/uaccess.h>
 #include <asm/mpc52xx.h>
=20
=20
-#define GPT_MODE_WDT		(1 << 15)
-#define GPT_MODE_CE		(1 << 12)
-#define GPT_MODE_MS_TIMER	(0x4)
-
+#define WDT_IDENTITY        "mpc5200 watchdog on GPT0"
=20
 struct mpc5200_wdt {
-	unsigned count;	/* timer ticks before watchdog kicks in */
-	long ipb_freq;
-	struct miscdevice miscdev;
-	struct resource mem;
-	struct mpc52xx_gpt __iomem *regs;
-	spinlock_t io_lock;
+	int timeout;
+	struct mpc52xx_gpt_priv *timer;
 };
=20
 /* is_active stores wether or not the /dev/watchdog device is opened */
@@ -32,80 +23,33 @@ static unsigned long is_active;
 static struct mpc5200_wdt *wdt_global;
=20
=20
-/* helper to calculate timeout in timer counts */
-static void mpc5200_wdt_set_timeout(struct mpc5200_wdt *wdt, int timeout)
-{
-	/* use biggest prescaler of 64k */
-	wdt->count =3D (wdt->ipb_freq + 0xffff) / 0x10000 * timeout;
-
-	if (wdt->count > 0xffff)
-		wdt->count =3D 0xffff;
-}
-/* return timeout in seconds (calculated from timer count) */
-static int mpc5200_wdt_get_timeout(struct mpc5200_wdt *wdt)
-{
-	return wdt->count * 0x10000 / wdt->ipb_freq;
-}
-
-
-/* watchdog operations */
-static int mpc5200_wdt_start(struct mpc5200_wdt *wdt)
-{
-	spin_lock(&wdt->io_lock);
-	/* disable */
-	out_be32(&wdt->regs->mode, 0);
-	/* set timeout, with maximum prescaler */
-	out_be32(&wdt->regs->count, 0x0 | wdt->count);
-	/* enable watchdog */
-	out_be32(&wdt->regs->mode, GPT_MODE_CE | GPT_MODE_WDT |
-						GPT_MODE_MS_TIMER);
-	spin_unlock(&wdt->io_lock);
-
-	return 0;
-}
-static int mpc5200_wdt_ping(struct mpc5200_wdt *wdt)
-{
-	spin_lock(&wdt->io_lock);
-	/* writing A5 to OCPW resets the watchdog */
-	out_be32(&wdt->regs->mode, 0xA5000000 |
-				(0xffffff & in_be32(&wdt->regs->mode)));
-	spin_unlock(&wdt->io_lock);
-	return 0;
-}
-static int mpc5200_wdt_stop(struct mpc5200_wdt *wdt)
-{
-	spin_lock(&wdt->io_lock);
-	/* disable */
-	out_be32(&wdt->regs->mode, 0);
-	spin_unlock(&wdt->io_lock);
-	return 0;
-}
-
-
 /* file operations */
 static ssize_t mpc5200_wdt_write(struct file *file, const char __user *dat=
a,
-		size_t len, loff_t *ppos)
+				 size_t len, loff_t *ppos)
 {
 	struct mpc5200_wdt *wdt =3D file->private_data;
-	mpc5200_wdt_ping(wdt);
+	mpc52xx_gpt_wdt_ping(wdt->timer);
 	return 0;
 }
+
 static struct watchdog_info mpc5200_wdt_info =3D {
 	.options	=3D WDIOF_SETTIMEOUT | WDIOF_KEEPALIVEPING,
-	.identity	=3D "mpc5200 watchdog on GPT0",
+	.identity	=3D WDT_IDENTITY,
 };
+
 static long mpc5200_wdt_ioctl(struct file *file, unsigned int cmd,
-							unsigned long arg)
+			      unsigned long arg)
 {
 	struct mpc5200_wdt *wdt =3D file->private_data;
 	int __user *data =3D (int __user *)arg;
 	int timeout;
+	u64 real_timeout;
 	int ret =3D 0;
=20
 	switch (cmd) {
 	case WDIOC_GETSUPPORT:
 		ret =3D copy_to_user(data, &mpc5200_wdt_info,
-						sizeof(mpc5200_wdt_info));
+				   sizeof(mpc5200_wdt_info));
 		if (ret)
 			ret =3D -EFAULT;
 		break;
@@ -116,19 +60,23 @@ static long mpc5200_wdt_ioctl(struct file *file, unsig=
ned int cmd,
 		break;
=20
 	case WDIOC_KEEPALIVE:
-		mpc5200_wdt_ping(wdt);
+		mpc52xx_gpt_wdt_ping(wdt->timer);
 		break;
=20
 	case WDIOC_SETTIMEOUT:
 		ret =3D get_user(timeout, data);
 		if (ret)
 			break;
-		mpc5200_wdt_set_timeout(wdt, timeout);
-		mpc5200_wdt_start(wdt);
+		ret =3D mpc52xx_gpt_wdt_start(wdt->timer, timeout);
+		if (ret)
+			break;
+		wdt->timeout =3D timeout;
 		/* fall through and return the timeout */
=20
 	case WDIOC_GETTIMEOUT:
-		timeout =3D mpc5200_wdt_get_timeout(wdt);
+		real_timeout =3D mpc52xx_gpt_timer_period(wdt->timer);
+		do_div(real_timeout, 1000000000);
+		timeout =3D (int) real_timeout;
 		ret =3D put_user(timeout, data);
 		break;
=20
@@ -140,154 +88,90 @@ static long mpc5200_wdt_ioctl(struct file *file, unsi=
gned int cmd,
=20
 static int mpc5200_wdt_open(struct inode *inode, struct file *file)
 {
+	int ret;
+
 	/* /dev/watchdog can only be opened once */
 	if (test_and_set_bit(0, &is_active))
 		return -EBUSY;
=20
 	/* Set and activate the watchdog */
-	mpc5200_wdt_set_timeout(wdt_global, 30);
-	mpc5200_wdt_start(wdt_global);
+	ret =3D mpc52xx_gpt_wdt_start(wdt_global->timer, 30);
+	if (ret) {
+		clear_bit(0, &is_active);
+		return ret;
+	}
+	wdt_global->timeout =3D 30;
+
 	file->private_data =3D wdt_global;
 	return nonseekable_open(inode, file);
 }
+
 static int mpc5200_wdt_release(struct inode *inode, struct file *file)
 {
-#if WATCHDOG_NOWAYOUT =3D=3D 0
+#if !defined(CONFIG_WATCHDOG_NOWAYOUT)
 	struct mpc5200_wdt *wdt =3D file->private_data;
-	mpc5200_wdt_stop(wdt);
-	wdt->count =3D 0;		/* =3D=3D disabled */
+	mpc52xx_gpt_wdt_stop(wdt->timer);
+	wdt->timeout =3D 0;		/* =3D=3D disabled */
 #endif
 	clear_bit(0, &is_active);
 	return 0;
 }
=20
 static const struct file_operations mpc5200_wdt_fops =3D {
-	.owner	=3D THIS_MODULE,
-	.write	=3D mpc5200_wdt_write,
+	.owner		=3D THIS_MODULE,
+	.llseek		=3D no_llseek,
+	.write		=3D mpc5200_wdt_write,
 	.unlocked_ioctl	=3D mpc5200_wdt_ioctl,
-	.open	=3D mpc5200_wdt_open,
-	.release =3D mpc5200_wdt_release,
+	.open		=3D mpc5200_wdt_open,
+	.release	=3D mpc5200_wdt_release,
+};
+
+static struct miscdevice mpc5200_wdt_miscdev =3D {
+	.minor		=3D WATCHDOG_MINOR,
+	.name		=3D "watchdog",
+	.fops		=3D &mpc5200_wdt_fops,
 };
=20
 /* module operations */
-static int mpc5200_wdt_probe(struct of_device *op,
-					const struct of_device_id *match)
+static int __init mpc5200_wdt_init(void)
 {
-	struct mpc5200_wdt *wdt;
 	int err;
-	const void *has_wdt;
-	int size;
+	struct mpc52xx_gpt_priv *timer;
=20
-	has_wdt =3D of_get_property(op->node, "has-wdt", NULL);
-	if (!has_wdt)
-		has_wdt =3D of_get_property(op->node, "fsl,has-wdt", NULL);
-	if (!has_wdt)
+	/* grab the watchdog-capable gpt */
+	timer =3D mpc52xx_gpt_wdt_probe();
+	if (!timer) {
+		pr_err(WDT_IDENTITY ": probing failed\n");
 		return -ENODEV;
+	}
=20
-	wdt =3D kzalloc(sizeof(*wdt), GFP_KERNEL);
-	if (!wdt)
+	wdt_global =3D kzalloc(sizeof(struct mpc5200_wdt), GFP_KERNEL);
+	if (!wdt_global) {
+		mpc52xx_gpt_wdt_release(timer);
 		return -ENOMEM;
-
-	wdt->ipb_freq =3D mpc5xxx_get_bus_frequency(op->node);
-
-	err =3D of_address_to_resource(op->node, 0, &wdt->mem);
-	if (err)
-		goto out_free;
-	size =3D wdt->mem.end - wdt->mem.start + 1;
-	if (!request_mem_region(wdt->mem.start, size, "mpc5200_wdt")) {
-		err =3D -ENODEV;
-		goto out_free;
-	}
-	wdt->regs =3D ioremap(wdt->mem.start, size);
-	if (!wdt->regs) {
-		err =3D -ENODEV;
-		goto out_release;
 	}
-
-	dev_set_drvdata(&op->dev, wdt);
-	spin_lock_init(&wdt->io_lock);
-
-	wdt->miscdev =3D (struct miscdevice) {
-		.minor	=3D WATCHDOG_MINOR,
-		.name	=3D "watchdog",
-		.fops	=3D &mpc5200_wdt_fops,
-		.parent =3D &op->dev,
-	};
-	wdt_global =3D wdt;
-	err =3D misc_register(&wdt->miscdev);
+	wdt_global->timer =3D timer;
+	err =3D misc_register(&mpc5200_wdt_miscdev);
 	if (!err)
-		return 0;
-
-	iounmap(wdt->regs);
-out_release:
-	release_mem_region(wdt->mem.start, size);
-out_free:
-	kfree(wdt);
+		pr_info(WDT_IDENTITY ": registered\n");
+	else {
+		mpc52xx_gpt_wdt_release(timer);
+		kfree(wdt_global);
+	}
 	return err;
 }
=20
-static int mpc5200_wdt_remove(struct of_device *op)
-{
-	struct mpc5200_wdt *wdt =3D dev_get_drvdata(&op->dev);
-
-	mpc5200_wdt_stop(wdt);
-	misc_deregister(&wdt->miscdev);
-	iounmap(wdt->regs);
-	release_mem_region(wdt->mem.start, wdt->mem.end - wdt->mem.start + 1);
-	kfree(wdt);
-
-	return 0;
-}
-static int mpc5200_wdt_suspend(struct of_device *op, pm_message_t state)
-{
-	struct mpc5200_wdt *wdt =3D dev_get_drvdata(&op->dev);
-	mpc5200_wdt_stop(wdt);
-	return 0;
-}
-static int mpc5200_wdt_resume(struct of_device *op)
-{
-	struct mpc5200_wdt *wdt =3D dev_get_drvdata(&op->dev);
-	if (wdt->count)
-		mpc5200_wdt_start(wdt);
-	return 0;
-}
-static int mpc5200_wdt_shutdown(struct of_device *op)
-{
-	struct mpc5200_wdt *wdt =3D dev_get_drvdata(&op->dev);
-	mpc5200_wdt_stop(wdt);
-	return 0;
-}
-
-static struct of_device_id mpc5200_wdt_match[] =3D {
-	{ .compatible =3D "mpc5200-gpt", },
-	{ .compatible =3D "fsl,mpc5200-gpt", },
-	{},
-};
-static struct of_platform_driver mpc5200_wdt_driver =3D {
-	.owner		=3D THIS_MODULE,
-	.name		=3D "mpc5200-gpt-wdt",
-	.match_table	=3D mpc5200_wdt_match,
-	.probe		=3D mpc5200_wdt_probe,
-	.remove		=3D mpc5200_wdt_remove,
-	.suspend	=3D mpc5200_wdt_suspend,
-	.resume		=3D mpc5200_wdt_resume,
-	.shutdown	=3D mpc5200_wdt_shutdown,
-};
-
-
-static int __init mpc5200_wdt_init(void)
-{
-	return of_register_platform_driver(&mpc5200_wdt_driver);
-}
-
 static void __exit mpc5200_wdt_exit(void)
 {
-	of_unregister_platform_driver(&mpc5200_wdt_driver);
+	mpc52xx_gpt_wdt_release(wdt_global->timer);
+	misc_deregister(&mpc5200_wdt_miscdev);
+	kfree(wdt_global);
 }
=20
 module_init(mpc5200_wdt_init);
 module_exit(mpc5200_wdt_exit);
=20
-MODULE_AUTHOR("Domen Puncer <domen.puncer@telargo.com>");
+MODULE_AUTHOR("Domen Puncer <domen.puncer@telargo.com>, "
+	      "Albrecht Dre=DF <albrecht.dress@arcor.de>");
 MODULE_LICENSE("Dual BSD/GPL");
 MODULE_ALIAS_MISCDEV(WATCHDOG_MINOR);
^ permalink raw reply related	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-10 19:43 [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api Albrecht Dreß
@ 2009-11-10 19:59 ` Grant Likely
  2009-11-10 20:26   ` Albrecht Dreß
  0 siblings, 1 reply; 10+ messages in thread
From: Grant Likely @ 2009-11-10 19:59 UTC (permalink / raw)
  To: Albrecht Dreß
  Cc: Linux PPC Development, devicetree-discuss, Wim Van Sebroeck
On Tue, Nov 10, 2009 at 12:43 PM, Albrecht Dre=DF <albrecht.dress@arcor.de>=
 wrote:
> Use the MPC5200 GPT api for the WDT which drastically simplifies this fil=
e.
>
> Signed-off-by: Albrecht Dre=DF <albrecht.dress@arcor.de>
> ---
>
> =A0drivers/watchdog/mpc5200_wdt.c | =A0246 +++++++++++-------------------=
----------
> =A01 files changed, 65 insertions(+), 181 deletions(-)
Can the WDT functionality just be merged entirely into
arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
this file entirely?  I think I'd rather have all the GPT "built in"
behaviour handled by a single driver.
g.
--=20
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-10 19:59 ` Grant Likely
@ 2009-11-10 20:26   ` Albrecht Dreß
  2009-11-10 21:07     ` Grant Likely
                       ` (2 more replies)
  0 siblings, 3 replies; 10+ messages in thread
From: Albrecht Dreß @ 2009-11-10 20:26 UTC (permalink / raw)
  To: Grant Likely; +Cc: Linux PPC Development, devicetree-discuss, Wim Van Sebroeck
[-- Attachment #1: Type: text/plain, Size: 1472 bytes --]
Hi Grant:
Am 10.11.09 20:59 schrieb(en) Grant Likely:
> On Tue, Nov 10, 2009 at 12:43 PM, Albrecht Dreß <albrecht.dress@arcor.de> wrote:
> > Use the MPC5200 GPT api for the WDT which drastically simplifies this file.
> >
> > Signed-off-by: Albrecht Dreß <albrecht.dress@arcor.de>
> > ---
> >
> >  drivers/watchdog/mpc5200_wdt.c |  246 +++++++++++-----------------------------
> >  1 files changed, 65 insertions(+), 181 deletions(-)
> 
> 
> Can the WDT functionality just be merged entirely into
> arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
> this file entirely?  I think I'd rather have all the GPT "built in"
> behaviour handled by a single driver.
I also thought about it, as it has IMHO the cleaner code, and it would have the extra benefit that the gpt-wdt api doesn't need to be public.
However, the reasons I hesitated to do so are:
- I don't want to remove a file someone else wrote (even it doesn't work);
- WDT code is shifted from drivers/watchdog to arch/powerpc/platforms/52xx which might not be the "logical" place from the directory layout's pov;
- a file living in arch/powerpc/platforms/52xx depends upon config options set from drivers/watchdog/Kconfig which may be confusing.
You see these are more political/cosmetical questions, so I would prefer to leave the decision to the maintainers (i.e. you and Wim).  Preparing a fully merged driver is actually a matter of minutes!
Thanks,
Albrecht.
[-- Attachment #2: Type: application/pgp-signature, Size: 190 bytes --]
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-10 20:26   ` Albrecht Dreß
@ 2009-11-10 21:07     ` Grant Likely
  2009-11-11  8:32     ` Aw: " Albrecht Dreß
  2009-11-12 21:36     ` Wim Van Sebroeck
  2 siblings, 0 replies; 10+ messages in thread
From: Grant Likely @ 2009-11-10 21:07 UTC (permalink / raw)
  To: Albrecht Dreß
  Cc: Linux PPC Development, devicetree-discuss, Wim Van Sebroeck
On Tue, Nov 10, 2009 at 1:26 PM, Albrecht Dre=DF <albrecht.dress@arcor.de> =
wrote:
> Hi Grant:
>
> Am 10.11.09 20:59 schrieb(en) Grant Likely:
>>
>> On Tue, Nov 10, 2009 at 12:43 PM, Albrecht Dre=DF <albrecht.dress@arcor.=
de>
>> wrote:
>> > Use the MPC5200 GPT api for the WDT which drastically simplifies this
>> > file.
>> >
>> > Signed-off-by: Albrecht Dre=DF <albrecht.dress@arcor.de>
>> > ---
>> >
>> > =A0drivers/watchdog/mpc5200_wdt.c | =A0246
>> > +++++++++++-----------------------------
>> > =A01 files changed, 65 insertions(+), 181 deletions(-)
>>
>>
>> Can the WDT functionality just be merged entirely into
>> arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
>> this file entirely? =A0I think I'd rather have all the GPT "built in"
>> behaviour handled by a single driver.
>
> I also thought about it, as it has IMHO the cleaner code, and it would ha=
ve
> the extra benefit that the gpt-wdt api doesn't need to be public.
>
> However, the reasons I hesitated to do so are:
> - I don't want to remove a file someone else wrote (even it doesn't work)=
;
Shouldn't be a problem, and I'll handle the fallout if it is.
> - WDT code is shifted from drivers/watchdog to arch/powerpc/platforms/52x=
x
> which might not be the "logical" place from the directory layout's pov;
There is precedence of this in the past, particularly on arch or
platform specific hardware drivers and multifunction devices.  (Heck,
that's almost entirely what arch/powerpc/sysdev is).  I'm not
concerned.
> - a file living in arch/powerpc/platforms/52xx depends upon config option=
s
> set from drivers/watchdog/Kconfig which may be confusing.
I'm not concerned about this either.
> You see these are more political/cosmetical questions, so I would prefer =
to
> leave the decision to the maintainers (i.e. you and Wim). =A0Preparing a =
fully
> merged driver is actually a matter of minutes!
Do it.  I'll champion getting it in.  Wim, do you have any issues with this=
?
g.
--=20
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Aw: Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-10 20:26   ` Albrecht Dreß
  2009-11-10 21:07     ` Grant Likely
@ 2009-11-11  8:32     ` Albrecht Dreß
  2009-11-11 20:18       ` Grant Likely
  2009-11-12 21:36     ` Wim Van Sebroeck
  2 siblings, 1 reply; 10+ messages in thread
From: Albrecht Dreß @ 2009-11-11  8:32 UTC (permalink / raw)
  To: grant.likely; +Cc: linuxppc-dev, devicetree-discuss, wim
Hi Grant:
O.k., thanks for your comments.  If Wim doesn't have any objections to it, =
I will provide a merged patch.  One consequence I forgot to mention is that=
 we loose the ability to build the wdt support as module, but I don't think=
 it's a real problem.
I think we still should keep the kernel config option enable/disable the wd=
t support, which would mask out the wdt code if disabled.  Is that ok for y=
ou?
Thanks, Albrecht.
----- Original Nachricht ----
Von:     Grant Likely <grant.likely@secretlab.ca>
An:      Albrecht Dre=DF <albrecht.dress@arcor.de>
Datum:   10.11.2009 22:07
Betreff: Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
> On Tue, Nov 10, 2009 at 1:26 PM, Albrecht Dre=DF <albrecht.dress@arcor.de=
>
> wrote:
> > Hi Grant:
> >
> > Am 10.11.09 20:59 schrieb(en) Grant Likely:
> >>
> >> On Tue, Nov 10, 2009 at 12:43 PM, Albrecht Dre=DF
> <albrecht.dress@arcor.de>
> >> wrote:
> >> > Use the MPC5200 GPT api for the WDT which drastically simplifies thi=
s
> >> > file.
> >> >
> >> > Signed-off-by: Albrecht Dre=DF <albrecht.dress@arcor.de>
> >> > ---
> >> >
> >> > =A0drivers/watchdog/mpc5200_wdt.c | =A0246
> >> > +++++++++++-----------------------------
> >> > =A01 files changed, 65 insertions(+), 181 deletions(-)
> >>
> >>
> >> Can the WDT functionality just be merged entirely into
> >> arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
> >> this file entirely? =A0I think I'd rather have all the GPT "built in"
> >> behaviour handled by a single driver.
> >
> > I also thought about it, as it has IMHO the cleaner code, and it would
> have
> > the extra benefit that the gpt-wdt api doesn't need to be public.
> >
> > However, the reasons I hesitated to do so are:
> > - I don't want to remove a file someone else wrote (even it doesn't
> work);
>=20
> Shouldn't be a problem, and I'll handle the fallout if it is.
>=20
> > - WDT code is shifted from drivers/watchdog to
> arch/powerpc/platforms/52xx
> > which might not be the "logical" place from the directory layout's pov;
>=20
> There is precedence of this in the past, particularly on arch or
> platform specific hardware drivers and multifunction devices.  (Heck,
> that's almost entirely what arch/powerpc/sysdev is).  I'm not
> concerned.
>=20
> > - a file living in arch/powerpc/platforms/52xx depends upon config
> options
> > set from drivers/watchdog/Kconfig which may be confusing.
>=20
> I'm not concerned about this either.
>=20
> > You see these are more political/cosmetical questions, so I would prefe=
r
> to
> > leave the decision to the maintainers (i.e. you and Wim). =A0Preparing =
a
> fully
> > merged driver is actually a matter of minutes!
>=20
> Do it.  I'll champion getting it in.  Wim, do you have any issues with
> this?
>=20
> g.
>=20
> --=20
> Grant Likely, B.Sc., P.Eng.
> Secret Lab Technologies Ltd.
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev
>=20
Jetzt NEU: Do it youself E-Cards bei Arcor.de!
Stellen Sie Ihr eigenes Unikat zusammen und machen Sie dem Empf=E4nger eine=
 ganz pers=F6nliche Freude!
E-Card Marke Eigenbau: HIER KLICKEN: http://www.arcor.de/rd/footer.ecard
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-11  8:32     ` Aw: " Albrecht Dreß
@ 2009-11-11 20:18       ` Grant Likely
  0 siblings, 0 replies; 10+ messages in thread
From: Grant Likely @ 2009-11-11 20:18 UTC (permalink / raw)
  To: Albrecht Dreß; +Cc: linuxppc-dev, devicetree-discuss, wim
On Wed, Nov 11, 2009 at 1:32 AM, Albrecht Dre=DF <albrecht.dress@arcor.de> =
wrote:
> Hi Grant:
>
> O.k., thanks for your comments. =A0If Wim doesn't have any objections to =
it, I will provide a merged patch. =A0One consequence I forgot to mention i=
s that we loose the ability to build the wdt support as module, but I don't=
 think it's a real problem.
I'm not too worried about this.  It is also potentially possible to
rework the entire GPT driver as a module.  But there are non-trivial
architecture fiddly bits needed to make it safe to load IRQ
controllers in a module.
> I think we still should keep the kernel config option enable/disable the =
wdt support, which would mask out the wdt code if disabled. =A0Is that ok f=
or you?
Yup.
g.
--=20
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-10 20:26   ` Albrecht Dreß
  2009-11-10 21:07     ` Grant Likely
  2009-11-11  8:32     ` Aw: " Albrecht Dreß
@ 2009-11-12 21:36     ` Wim Van Sebroeck
  2009-11-13  6:21       ` Grant Likely
  2 siblings, 1 reply; 10+ messages in thread
From: Wim Van Sebroeck @ 2009-11-12 21:36 UTC (permalink / raw)
  To: Albrecht Dreß
  Cc: Linux PPC Development, devicetree-discuss, Wim Van Sebroeck
Hi All,
>> Can the WDT functionality just be merged entirely into
>> arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
>> this file entirely?  I think I'd rather have all the GPT "built in"
>> behaviour handled by a single driver.
>
> I also thought about it, as it has IMHO the cleaner code, and it would have the extra benefit that the gpt-wdt api doesn't need to be public.
>
> However, the reasons I hesitated to do so are:
> - I don't want to remove a file someone else wrote (even it doesn't work);
> - WDT code is shifted from drivers/watchdog to arch/powerpc/platforms/52xx which might not be the "logical" place from the directory layout's pov;
> - a file living in arch/powerpc/platforms/52xx depends upon config options set from drivers/watchdog/Kconfig which may be confusing.
>
> You see these are more political/cosmetical questions, so I would prefer to leave the decision to the maintainers (i.e. you and Wim).  Preparing a fully merged driver is actually a matter of minutes!
My opinion: it is harder to maintain the watchdog code if it is being moved away from drivers/watchdog.
I need to check the code before I comment any further on this, but my first thought is: why don't you do it with platform resources like other devices are doing? This way you can keep the platform code under arch and the watchdog itself under drivers/watchdog/. You can look at the following drivers as an example: adx_wdt.c ar7_wdt.c at32ap700x_wdt.c coh901327_wdt.c davinci_wdt.c mpcore_wdt.c mv64x60_wdt.c nuc900_wdt.c omap_wdt.c pnx4008_wdt.c rc32434_wdt.c s3c2410_wdt.c txx9wdt.c .
Kind regards,
Wim.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-12 21:36     ` Wim Van Sebroeck
@ 2009-11-13  6:21       ` Grant Likely
  2009-12-08 20:48         ` Wim Van Sebroeck
  0 siblings, 1 reply; 10+ messages in thread
From: Grant Likely @ 2009-11-13  6:21 UTC (permalink / raw)
  To: Wim Van Sebroeck
  Cc: Albrecht Dreß, devicetree-discuss, Linux PPC Development
On Thu, Nov 12, 2009 at 2:36 PM, Wim Van Sebroeck <wim@iguana.be> wrote:
> Hi All,
>
>>> Can the WDT functionality just be merged entirely into
>>> arch/powerpc/platforms/52xx/mpc52xx_gpt.c, eliminating the need for
>>> this file entirely? =A0I think I'd rather have all the GPT "built in"
>>> behaviour handled by a single driver.
>>
>> I also thought about it, as it has IMHO the cleaner code, and it would h=
ave the extra benefit that the gpt-wdt api doesn't need to be public.
>>
>> However, the reasons I hesitated to do so are:
>> - I don't want to remove a file someone else wrote (even it doesn't work=
);
>> - WDT code is shifted from drivers/watchdog to arch/powerpc/platforms/52=
xx which might not be the "logical" place from the directory layout's pov;
>> - a file living in arch/powerpc/platforms/52xx depends upon config optio=
ns set from drivers/watchdog/Kconfig which may be confusing.
>>
>> You see these are more political/cosmetical questions, so I would prefer=
 to leave the decision to the maintainers (i.e. you and Wim). =A0Preparing =
a fully merged driver is actually a matter of minutes!
>
> My opinion: it is harder to maintain the watchdog code if it is being mov=
ed away from drivers/watchdog.
> I need to check the code before I comment any further on this, but my fir=
st thought is: why don't you do it with platform resources like other devic=
es are doing? This way you can keep the platform code under arch and the wa=
tchdog itself under drivers/watchdog/. You can look at the following driver=
s as an example: adx_wdt.c ar7_wdt.c at32ap700x_wdt.c coh901327_wdt.c davin=
ci_wdt.c mpcore_wdt.c mv64x60_wdt.c nuc900_wdt.c omap_wdt.c pnx4008_wdt.c r=
c32434_wdt.c s3c2410_wdt.c txx9wdt.c .
In actual fact, it is a single device with multiple functions, some of
which can be used at the same time.  The driver for the device
determines what the device instance supports and registers the
appropriate interfaces.  There is a GPIO controller, a PWM controller,
a general purpose timer, and the watchdog.  Because of the
multifunction nature of the device, there are subtle interactions
between the functions that the driver needs to maintain.  I don't want
to export functions from the driver which will only be used by a
watchdog instance.  I also don't want the added code and complexity of
a secondary probe path.  It is simpler and less code to roll all the
behaviour up into the one driver single driver that gets probed once.
>From the maintenance perspective, having the main driver in
arch/powerpc and the watchdog bit in drivers/watchdog doesn't really
help much anyway because anything that changes the internal driver API
(between the core and watchdog bits) will require cross-maintainer
changes.  ie. do changes go through my tree because they touch
arch/powerpc, or do they go through yours because they touch
drivers/watchdog?  I'd much rather all the internal details be
contained within a single driver.
Besides, there is already precedence for very arch-specific drivers
living under arch/*/.  find ./arch -name *gpio*
Cheers,
g.
--=20
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-11-13  6:21       ` Grant Likely
@ 2009-12-08 20:48         ` Wim Van Sebroeck
  2009-12-08 21:21           ` Grant Likely
  0 siblings, 1 reply; 10+ messages in thread
From: Wim Van Sebroeck @ 2009-12-08 20:48 UTC (permalink / raw)
  To: Grant Likely
  Cc: Albrecht Dreß, devicetree-discuss, Linux PPC Development
Hi Grant,
Sorry for the delay, I need to deliver a project in a weeks time...
> In actual fact, it is a single device with multiple functions, some of
> which can be used at the same time.  The driver for the device
> determines what the device instance supports and registers the
> appropriate interfaces.  There is a GPIO controller, a PWM controller,
> a general purpose timer, and the watchdog.  Because of the
> multifunction nature of the device, there are subtle interactions
> between the functions that the driver needs to maintain.  I don't want
> to export functions from the driver which will only be used by a
> watchdog instance.  I also don't want the added code and complexity of
> a secondary probe path.  It is simpler and less code to roll all the
> behaviour up into the one driver single driver that gets probed once.
> 
> >From the maintenance perspective, having the main driver in
> arch/powerpc and the watchdog bit in drivers/watchdog doesn't really
> help much anyway because anything that changes the internal driver API
> (between the core and watchdog bits) will require cross-maintainer
> changes.  ie. do changes go through my tree because they touch
> arch/powerpc, or do they go through yours because they touch
> drivers/watchdog?  I'd much rather all the internal details be
> contained within a single driver.
Your argument about maintenance is the same one as I have: If all watchdog
driver pieces are under drivers/watchdog then it's easier for me to maintain
them. (Definitely if we are doing clean-up work and API changes).
> Besides, there is already precedence for very arch-specific drivers
> living under arch/*/.  find ./arch -name *gpio*
But in this case: I know where to find them and I will keep a mental note
about this one. And yes indeed some very arch specific drivers can reside
under arch/*/* .
So please go ahead with pulling this one in a single driver.
Kind regards,
Wim.
^ permalink raw reply	[flat|nested] 10+ messages in thread
* Re: [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api
  2009-12-08 20:48         ` Wim Van Sebroeck
@ 2009-12-08 21:21           ` Grant Likely
  0 siblings, 0 replies; 10+ messages in thread
From: Grant Likely @ 2009-12-08 21:21 UTC (permalink / raw)
  To: Wim Van Sebroeck
  Cc: Albrecht Dreß, devicetree-discuss, Linux PPC Development
On Tue, Dec 8, 2009 at 1:48 PM, Wim Van Sebroeck <wim@iguana.be> wrote:
> Hi Grant,
>
> Sorry for the delay, I need to deliver a project in a weeks time...
understood.
>> In actual fact, it is a single device with multiple functions, some of
>> which can be used at the same time. =A0The driver for the device
>> determines what the device instance supports and registers the
>> appropriate interfaces. =A0There is a GPIO controller, a PWM controller,
>> a general purpose timer, and the watchdog. =A0Because of the
>> multifunction nature of the device, there are subtle interactions
>> between the functions that the driver needs to maintain. =A0I don't want
>> to export functions from the driver which will only be used by a
>> watchdog instance. =A0I also don't want the added code and complexity of
>> a secondary probe path. =A0It is simpler and less code to roll all the
>> behaviour up into the one driver single driver that gets probed once.
>>
>> >From the maintenance perspective, having the main driver in
>> arch/powerpc and the watchdog bit in drivers/watchdog doesn't really
>> help much anyway because anything that changes the internal driver API
>> (between the core and watchdog bits) will require cross-maintainer
>> changes. =A0ie. do changes go through my tree because they touch
>> arch/powerpc, or do they go through yours because they touch
>> drivers/watchdog? =A0I'd much rather all the internal details be
>> contained within a single driver.
>
> Your argument about maintenance is the same one as I have: If all watchdo=
g
> driver pieces are under drivers/watchdog then it's easier for me to maint=
ain
> them. (Definitely if we are doing clean-up work and API changes).
:-)
>> Besides, there is already precedence for very arch-specific drivers
>> living under arch/*/. =A0find ./arch -name *gpio*
>
> But in this case: I know where to find them and I will keep a mental note
> about this one. And yes indeed some very arch specific drivers can reside
> under arch/*/* .
>
> So please go ahead with pulling this one in a single driver.
Great, Thanks Wim.
g.
--=20
Grant Likely, B.Sc., P.Eng.
Secret Lab Technologies Ltd.
^ permalink raw reply	[flat|nested] 10+ messages in thread
end of thread, other threads:[~2009-12-08 21:22 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-11-10 19:43 [PATCH 3/3] mpc52xx/wdt: WDT uses GPT api Albrecht Dreß
2009-11-10 19:59 ` Grant Likely
2009-11-10 20:26   ` Albrecht Dreß
2009-11-10 21:07     ` Grant Likely
2009-11-11  8:32     ` Aw: " Albrecht Dreß
2009-11-11 20:18       ` Grant Likely
2009-11-12 21:36     ` Wim Van Sebroeck
2009-11-13  6:21       ` Grant Likely
2009-12-08 20:48         ` Wim Van Sebroeck
2009-12-08 21:21           ` Grant Likely
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).