22258fa40e
This patch extends the Ebony and Walnut platform code to instantiate the existing ds1742 RTC class driver for the DS1743 RTC/NVRAM chip found on both those boards. The patch uses a helper function to scan the device tree and instantiate the appropriate platform_device based on it, so it should be easy to extend for other boards which have mmio mapped RTC chips. Along with this, the device tree binding for the ds1743 chips is tweaked, based on the existing DS1385 OF binding found at: http://playground.sun.com/1275/proposals/Closed/Remanded/Accepted/346-it.txt Although that document covers the NVRAM portion of the chip, whereas here we're interested in the RTC portion, so it's not entirely clear if that's a good model. This implements only RTC class driver support - that is /dev/rtc0, not /dev/rtc, and the low-level get/set time callbacks remain unimplemented. That means in order to get at the clock you will either need a modified version of hwclock which will look at /dev/rtc0, or you'll need to configure udev to symlink rtc0 to rtc. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Josh Boyer <jwboyer@linux.vnet.ibm.com>
42 lines
1.3 KiB
C
42 lines
1.3 KiB
C
#ifndef _ASM_POWERPC_OF_PLATFORM_H
|
|
#define _ASM_POWERPC_OF_PLATFORM_H
|
|
/*
|
|
* Copyright (C) 2006 Benjamin Herrenschmidt, IBM Corp.
|
|
* <benh@kernel.crashing.org>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*
|
|
*/
|
|
|
|
/* This is just here during the transition */
|
|
#include <linux/of_platform.h>
|
|
|
|
/* Platform drivers register/unregister */
|
|
static inline int of_register_platform_driver(struct of_platform_driver *drv)
|
|
{
|
|
return of_register_driver(drv, &of_platform_bus_type);
|
|
}
|
|
static inline void of_unregister_platform_driver(struct of_platform_driver *drv)
|
|
{
|
|
of_unregister_driver(drv);
|
|
}
|
|
|
|
/* Platform devices and busses creation */
|
|
extern struct of_device *of_platform_device_create(struct device_node *np,
|
|
const char *bus_id,
|
|
struct device *parent);
|
|
/* pseudo "matches" value to not do deep probe */
|
|
#define OF_NO_DEEP_PROBE ((struct of_device_id *)-1)
|
|
|
|
extern int of_platform_bus_probe(struct device_node *root,
|
|
const struct of_device_id *matches,
|
|
struct device *parent);
|
|
|
|
extern struct of_device *of_find_device_by_phandle(phandle ph);
|
|
|
|
extern void of_instantiate_rtc(void);
|
|
|
|
#endif /* _ASM_POWERPC_OF_PLATFORM_H */
|