13 Jul, 2007

3 commits

  • * master.kernel.org:/pub/scm/linux/kernel/git/gregkh/driver-2.6: (61 commits)
    sysfs: add parameter "struct bin_attribute *" in .read/.write methods for sysfs binary attributes
    sysfs: make directory dentries and inodes reclaimable
    sysfs: implement sysfs_get_dentry()
    sysfs: move sysfs_drop_dentry() to dir.c and make it static
    sysfs: restructure add/remove paths and fix inode update
    sysfs: use sysfs_mutex to protect the sysfs_dirent tree
    sysfs: consolidate sysfs spinlocks
    sysfs: make kobj point to sysfs_dirent instead of dentry
    sysfs: implement sysfs_find_dirent() and sysfs_get_dirent()
    sysfs: implement SYSFS_FLAG_REMOVED flag
    sysfs: rename sysfs_dirent->s_type to s_flags and make room for flags
    sysfs: make sysfs_drop_dentry() access inodes using ilookup()
    sysfs: Fix oops in sysfs_drop_dentry on x86_64
    sysfs: use singly-linked list for sysfs_dirent tree
    sysfs: slim down sysfs_dirent->s_active
    sysfs: move s_active functions to fs/sysfs/dir.c
    sysfs: fix root sysfs_dirent -> root dentry association
    sysfs: use iget_locked() instead of new_inode()
    sysfs: reorganize sysfs_new_indoe() and sysfs_create()
    sysfs: fix parent refcounting during rename and move
    ...

    Linus Torvalds
     
  • * 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus:
    [MIPS] Rename PC speaker code
    [MIPS] Don't use genrtc.
    [MIPS] Remove unused time.c for swarm
    [MIPS] Sparse: Use NULL for pointer
    [MIPS] Fix a sparse warning in arch/mips/pci/pci.c
    [MIPS] SMTC: Interrupt mask backstop hack
    [MIPS] separate platform_device registration for VR41xx RTC
    [MIPS] Separate platform_device registration for VR41xx GPIO
    [MIPS] MIPSsim: Fix build.
    [MIPS] separate platform_device registration for VR41xx serial interface
    [MIPS] Include cacheflush.h in uncache.c
    [MIPS] Cleanup tlbdebug.h
    [MIPS] Change names of local variables to silence sparse (part 2)
    [MIPS] Workaround for a sparse warning in include/asm-mips/io.h
    [MIPS] RM: Use only phyiscal address for 82596 and 53c710
    [MIPS] Hydrogen3: Remove remaining bits of code.
    [MIPS] DEC: Fix modpost warning.
    Revert "[MIPS] DEC: Fix modpost warning."
    [MIPS] Fix resume for 64K page size on R4000 class processors.

    Linus Torvalds
     
  • Signed-off-by: Yoichi Yuasa
    Signed-off-by: Ralf Baechle

    Yoichi Yuasa
     

12 Jul, 2007

3 commits

  • The x1205 driver moved to the RTC subsystem and was significantly
    modified since then, so just delete the outdated documentation.

    Signed-off-by: Jean Delvare
    Cc: Alessandro Zummo

    Jean Delvare
     
  • Well, first of all, I don't want to change so many files either.

    What I do:
    Adding a new parameter "struct bin_attribute *" in the
    .read/.write methods for the sysfs binary attributes.

    In fact, only the four lines change in fs/sysfs/bin.c and
    include/linux/sysfs.h do the real work.
    But I have to update all the files that use binary attributes
    to make them compatible with the new .read and .write methods.
    I'm not sure if I missed any. :(

    Why I do this:
    For a sysfs attribute, we can get a pointer pointing to the
    struct attribute in the .show/.store method,
    while we can't do this for the binary attributes.
    I don't know why this is different, but this does make it not
    so handy to use the binary attributes as the regular ones.
    So I think this patch is reasonable. :)

    Who benefits from it:
    The patch that exposes ACPI tables in sysfs
    requires such an improvement.
    All the table binary attributes share the same .read method.
    Parameter "struct bin_attribute *" is used to get
    the table signature and instance number which are used to
    distinguish different ACPI table binary attributes.

    Without this parameter, we need to offer different .read methods
    for different ACPI table binary attributes.
    This is impossible as there are various ACPI tables on different
    platforms, and we don't know what they are until they are loaded.

    Signed-off-by: Zhang Rui
    Signed-off-by: Greg Kroah-Hartman

    Zhang Rui
     
  • sysfs is now completely out of driver/module lifetime game. After
    deletion, a sysfs node doesn't access anything outside sysfs proper,
    so there's no reason to hold onto the attribute owners. Note that
    often the wrong modules were accounted for as owners leading to
    accessing removed modules.

    This patch kills now unnecessary attribute->owner. Note that with
    this change, userland holding a sysfs node does not prevent the
    backing module from being unloaded.

    For more info regarding lifetime rule cleanup, please read the
    following message.

    http://article.gmane.org/gmane.linux.kernel/510293

    (tweaked by Greg to not delete the field just yet, to make it easier to
    merge things properly.)

    Signed-off-by: Tejun Heo
    Cc: Cornelia Huck
    Cc: Andrew Morton
    Signed-off-by: Greg Kroah-Hartman

    Tejun Heo
     

01 Jun, 2007

1 commit

  • Intel Macs (and possibly other machines) provide a PNP entry for the RTC,
    but provide no IRQ. As a result the rtc-cmos driver doesn't allow wakeup
    alarms. If the RTC is located at the legacy ioport range, assume that it's
    on IRQ 8 unless the tables say otherwise.

    Signed-off-by: Matthew Garrett
    Cc: Matthieu CASTET
    Signed-off-by: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Matthew Garrett
     

17 May, 2007

2 commits


12 May, 2007

1 commit

  • * 'upstream' of git://ftp.linux-mips.org/pub/scm/upstream-linus: (28 commits)
    [MIPS] Rework cobalt_board_id
    [MIPS] Use RTC_CMOS for Cobalt
    [MIPS] Use platform_device for Cobalt UART
    [MIPS] Separate Alchemy processor based boards config
    [MIPS] Fix build error in atomic64_cmpxchg
    [MIPS] Run checksyscalls for N32 and O32 ABI
    [MIPS] tlbex: use __maybe_unused
    [MIPS] excite: use __maybe_unused
    [MIPS] Add extern cobalt_board_id
    [MIPS] Remove unused CONFIG_TOSHIBA_BOARDS
    [MIPS] Rename tb0229_defconfig to tb0219_defconfig
    [MIPS] Update tb0229_defconfig; add CONFIG_GPIO_TB0219.
    [MIPS] Add minimum defconfig for RBHMA4200
    [MIPS] SB1: Build fix.
    [MIPS] Drop __devinit tag from allocate_irqno() and free_irqno()
    [MIPS] clocksource: use CLOCKSOURCE_MASK() macro
    [MIPS] Remove LIMITED_DMA support
    [MIPS] Remove Momenco Jaguar ATX support
    [MIPS] Remove Momenco Ocelot G support
    [MIPS] FPU hazard handling
    ...

    Linus Torvalds
     

11 May, 2007

4 commits


10 May, 2007

2 commits

  • Disable some more menus in the configuration files that are of no
    interest to a s390 machine.

    Signed-off-by: Martin Schwidefsky

    Martin Schwidefsky
     
  • * master.kernel.org:/pub/scm/linux/kernel/git/lethal/sh-2.6:
    sh: Fix stacktrace simplification fallout.
    sh: SH7760 DMABRG support.
    sh: clockevent/clocksource/hrtimers/nohz TMU support.
    sh: Truncate MAX_ACTIVE_REGIONS for the common case.
    rtc: rtc-sh: Fix rtc_dev pointer for rtc_update_irq().
    sh: Convert to common die chain.
    sh: Wire up utimensat syscall.
    sh: landisk mv_nr_irqs definition.
    sh: Fixup ndelay() xloops calculation for alternate HZ.
    sh: Add 32-bit opcode feature CPU flag.
    sh: Fix PC adjustments for varying opcode length.
    sh: Support for SH-2A 32-bit opcodes.
    sh: Kill off redundant __div64_32 symbol export.
    sh: Share exception vector table for SH-3/4.
    sh: Always define TRAPA_BUG_OPCODE.
    sh: __GFP_REPEAT for pte allocations, too.
    rtc: rtc-sh: Fix up dev_dbg() warnings.
    sh: generic quicklist support.

    Linus Torvalds
     

09 May, 2007

19 commits

  • Fix several typos in help text in Kconfig* files.

    Signed-off-by: David Sterba
    Signed-off-by: Adrian Bunk

    David Sterba
     
  • When the rtc_update_irq() callsites stopped passing in the
    class_dev, the rtc_dev references weren't fixed. Fix it up,
    so we pass in the proper pointer.

    Signed-off-by: Paul Mundt

    Paul Mundt
     
  • Signed-off-by: Paul Mundt

    Paul Mundt
     
  • Replace CONFIG_PNPACPI with CONFIG_PNP, so it loads on ACPI-less PNPBIOS
    systems.

    Signed-off-by: Marko Vrh
    Acked-by: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Marko Vrh
     
  • This fixes a common glitch in how RTC drivers handle two "set alarm" modes,
    by getting rid of the surprising/hidden one that was rarely implemented
    correctly (and which could expose nonportable hardware-specific behavior).

    The glitch comes from the /dev/rtcX logic implementing the legacy
    RTC_ALM_SET (limited to 24 hours, needing RTC_AIE_ON) ioctl on top of the
    RTC driver call providing access to the newer RTC_WKALM_SET (without those
    limitations) by initializing the day/month/year fields to be invalid ...
    that second mode.

    Now, since few RTC drivers check those fields, and most hardware misbehaves
    when faced with invalid date fields, many RTC drivers will set bogus alarm
    times on those RTC_ALM_SET code paths. (Several in-tree drivers have that
    issue, and I also noticed it with code reviews on several new RTC drivers.)

    This patch ensures that RTC drivers never see such invalid alarm fields, by
    moving some logic out of rtc-omap into the RTC_ALM_SET code and adding an
    explicit check (which will prevent the issue on other code paths).

    Signed-off-by: David Brownell
    Cc: Scott Wood
    Cc: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • David says "884b4aaaa242a2db8c8252796f0118164a680ab5 should be reverted. It
    added an rtc_merge_alarm() call to the 2.6.20 kernel, which hasn't yet been
    used by any in-tree driver; this patch obviates the need for that call, and
    uses a more robust approach."

    Cc: Scott Wood
    Cc: Alessandro Zummo
    Cc: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Andrew Morton
     
  • I finally got around to testing the updated wakeup event hooks for rtc-cmos,
    and they follow in two patches:

    - Interface update ... when a simple enable_irq_wake() doesn't suffice,
    the platform data can hold suspend/resume callback hooks.

    - ACPI implementation ... provides callback hooks to do ACPI magic, and
    eliminate the legacy /proc/acpi/alarm file.

    The interface update could go into 2.6.21, but that's not essential; they
    will be NOPs on most PCs, without the ACPI stuff.

    I suspect the ACPI folk may have opinions about how to merge that second
    patch, and how to obsolete that legacy procfs file. I'd like to see that
    merge into 2.6.22 if possible...

    As for how to kick it in ... two ways:

    - The appended "rtcwake" program; updated since the last time it was
    posted, it deals much better with timezones and DST.

    - Write the /sys/class/rtc/.../wakealarm file, then go to sleep.

    For some reason RTC wake from "swsusp" stopped working on a system where
    it previously worked; the alarm setting appears to get clobbered. But
    on the bright side, RTC wake from "standby" worked on a system that had
    never been able to resume from that state before ... IDEACPI is my guess
    as to why it finally started to work. It's the old "two steps forward,
    one step back" dance, I guess.

    - Dave

    /* gcc -Wall -Os -o rtcwake rtcwake.c */

    #include
    #include
    #include
    #include
    #include
    #include
    #include
    #include

    #include
    #include
    #include

    #include

    /* constants from legacy PC/AT hardware */
    #define RTC_PF 0x40
    #define RTC_AF 0x20
    #define RTC_UF 0x10

    /*
    * rtcwake -- enter a system sleep state until specified wakeup time.
    *
    * This uses cross-platform Linux interfaces to enter a system sleep state,
    * and leave it no later than a specified time. It uses any RTC framework
    * driver that supports standard driver model wakeup flags.
    *
    * This is normally used like the old "apmsleep" utility, to wake from a
    * suspend state like ACPI S1 (standby) or S3 (suspend-to-RAM). Most
    * platforms can implement those without analogues of BIOS, APM, or ACPI.
    *
    * On some systems, this can also be used like "nvram-wakeup", waking
    * from states like ACPI S4 (suspend to disk). Not all systems have
    * persistent media that are appropriate for such suspend modes.
    *
    * The best way to set the system's RTC is so that it holds the current
    * time in UTC. Use the "-l" flag to tell this program that the system
    * RTC uses a local timezone instead (maybe you dual-boot MS-Windows).
    */

    static char *progname;

    #ifdef DEBUG
    #define VERSION "1.0 dev (" __DATE__ " " __TIME__ ")"
    #else
    #define VERSION "0.9"
    #endif

    static unsigned verbose;
    static int rtc_is_utc = -1;

    static int may_wakeup(const char *devname)
    {
    char buf[128], *s;
    FILE *f;

    snprintf(buf, sizeof buf, "/sys/class/rtc/%s/device/power/wakeup",
    devname);
    f = fopen(buf, "r");
    if (!f) {
    perror(buf);
    return 0;
    }
    fgets(buf, sizeof buf, f);
    fclose(f);

    s = strchr(buf, '\n');
    if (!s)
    return 0;
    *s = 0;

    /* wakeup events could be disabled or not supported */
    return strcmp(buf, "enabled") == 0;
    }

    /* all times should be in UTC */
    static time_t sys_time;
    static time_t rtc_time;

    static int get_basetimes(int fd)
    {
    struct tm tm;
    struct rtc_time rtc;

    /* this process works in RTC time, except when working
    * with the system clock (which always uses UTC).
    */
    if (rtc_is_utc)
    setenv("TZ", "UTC", 1);
    tzset();

    /* read rtc and system clocks "at the same time", or as
    * precisely (+/- a second) as we can read them.
    */
    if (ioctl(fd, RTC_RD_TIME, &rtc) < 0) {
    perror("read rtc time");
    return 0;
    }
    sys_time = time(0);
    if (sys_time == (time_t)-1) {
    perror("read system time");
    return 0;
    }

    /* convert rtc_time to normal arithmetic-friendly form,
    * updating tm.tm_wday as used by asctime().
    */
    memset(&tm, 0, sizeof tm);
    tm.tm_sec = rtc.tm_sec;
    tm.tm_min = rtc.tm_min;
    tm.tm_hour = rtc.tm_hour;
    tm.tm_mday = rtc.tm_mday;
    tm.tm_mon = rtc.tm_mon;
    tm.tm_year = rtc.tm_year;
    tm.tm_isdst = rtc.tm_isdst; /* stays unspecified? */
    rtc_time = mktime(&tm);

    if (rtc_time == (time_t)-1) {
    perror("convert rtc time");
    return 0;
    }

    if (verbose) {
    if (!rtc_is_utc) {
    printf("\ttzone = %ld\n", timezone);
    printf("\ttzname = %s\n", tzname[daylight]);
    gmtime_r(&rtc_time, &tm);
    }
    printf("\tsystime = %ld, (UTC) %s",
    (long) sys_time, asctime(gmtime(&sys_time)));
    printf("\trtctime = %ld, (UTC) %s",
    (long) rtc_time, asctime(&tm));
    }

    return 1;
    }

    static int setup_alarm(int fd, time_t *wakeup)
    {
    struct tm *tm;
    struct rtc_wkalrm wake;

    tm = gmtime(wakeup);

    wake.time.tm_sec = tm->tm_sec;
    wake.time.tm_min = tm->tm_min;
    wake.time.tm_hour = tm->tm_hour;
    wake.time.tm_mday = tm->tm_mday;
    wake.time.tm_mon = tm->tm_mon;
    wake.time.tm_year = tm->tm_year;
    wake.time.tm_wday = tm->tm_wday;
    wake.time.tm_yday = tm->tm_yday;
    wake.time.tm_isdst = tm->tm_isdst;

    /* many rtc alarms only support up to 24 hours from 'now' ... */
    if ((rtc_time + (24 * 60 * 60)) > *wakeup) {
    if (ioctl(fd, RTC_ALM_SET, &wake.time) < 0) {
    perror("set rtc alarm");
    return 0;
    }
    if (ioctl(fd, RTC_AIE_ON, 0) < 0) {
    perror("enable rtc alarm");
    return 0;
    }

    /* ... so use the "more than 24 hours" request only if we must */
    } else {
    /* avoid an extra AIE_ON call */
    wake.enabled = 1;

    if (ioctl(fd, RTC_WKALM_SET, &wake) < 0) {
    perror("set rtc wake alarm");
    return 0;
    }
    }

    return 1;
    }

    static void suspend_system(const char *suspend)
    {
    FILE *f = fopen("/sys/power/state", "w");

    if (!f) {
    perror("/sys/power/state");
    return;
    }

    fprintf(f, "%s\n", suspend);
    fflush(f);

    /* this executes after wake from suspend */
    fclose(f);
    }

    int main(int argc, char **argv)
    {
    static char *devname = "rtc0";
    static unsigned seconds = 0;
    static char *suspend = "standby";

    int t;
    int fd;
    time_t alarm = 0;

    progname = strrchr(argv[0], '/');
    if (progname)
    progname++;
    else
    progname = argv[0];
    if (chdir("/dev/") < 0) {
    perror("chdir /dev");
    return 1;
    }

    while ((t = getopt(argc, argv, "d:lm:s:t:uVv")) != EOF) {
    switch (t) {

    case 'd':
    devname = optarg;
    break;

    case 'l':
    rtc_is_utc = 0;
    break;

    /* what system power mode to use? for now handle only
    * standardized mode names; eventually when systems define
    * their own state names, parse /sys/power/state.
    *
    * "on" is used just to test the RTC alarm mechanism,
    * bypassing all the wakeup-from-sleep infrastructure.
    */
    case 'm':
    if (strcmp(optarg, "standby") == 0
    || strcmp(optarg, "mem") == 0
    || strcmp(optarg, "disk") == 0
    || strcmp(optarg, "on") == 0
    ) {
    suspend = optarg;
    break;
    }
    printf("%s: unrecognized suspend state '%s'\n",
    progname, optarg);
    goto usage;

    /* alarm time, seconds-to-sleep (relative) */
    case 's':
    t = atoi(optarg);
    if (t < 0) {
    printf("%s: illegal interval %s seconds\n",
    progname, optarg);
    goto usage;
    }
    seconds = t;
    break;

    /* alarm time, time_t (absolute, seconds since 1/1 1970 UTC) */
    case 't':
    t = atoi(optarg);
    if (t < 0) {
    printf("%s: illegal time_t value %s\n",
    progname, optarg);
    goto usage;
    }
    alarm = t;
    break;

    case 'u':
    rtc_is_utc = 1;
    break;

    case 'v':
    verbose++;
    break;

    case 'V':
    printf("%s: version %s\n", progname, VERSION);
    break;

    default:
    usage:
    printf("usage: %s [options]"
    "\n\t"
    "-d rtc0|rtc1|...\t(select rtc)"
    "\n\t"
    "-l\t\t\t(RTC uses local timezone)"
    "\n\t"
    "-m standby|mem|...\t(sleep mode)"
    "\n\t"
    "-s seconds\t\t(seconds to sleep)"
    "\n\t"
    "-t time_t\t\t(time to wake)"
    "\n\t"
    "-u\t\t\t(RTC uses UTC)"
    "\n\t"
    "-v\t\t\t(verbose messages)"
    "\n\t"
    "-V\t\t\t(show version)"
    "\n",
    progname);
    return 1;
    }
    }

    if (!alarm && !seconds) {
    printf("%s: must provide wake time\n", progname);
    goto usage;
    }

    /* REVISIT: if /etc/adjtime exists, read it to see what
    * the util-linux version of hwclock assumes.
    */
    if (rtc_is_utc == -1) {
    printf("%s: assuming RTC uses UTC ...\n", progname);
    rtc_is_utc = 1;
    }

    /* this RTC must exist and (if we'll sleep) be wakeup-enabled */
    fd = open(devname, O_RDONLY);
    if (fd < 0) {
    perror(devname);
    return 1;
    }
    if (strcmp(suspend, "on") != 0 && !may_wakeup(devname)) {
    printf("%s: %s not enabled for wakeup events\n",
    progname, devname);
    return 1;
    }

    /* relative or absolute alarm time, normalized to time_t */
    if (!get_basetimes(fd))
    return 1;
    if (verbose)
    printf("alarm %ld, sys_time %ld, rtc_time %ld, seconds %u\n",
    alarm, sys_time, rtc_time, seconds);
    if (alarm) {
    if (alarm < sys_time) {
    printf("%s: time doesn't go backward to %s",
    progname, ctime(&alarm));
    return 1;
    }
    alarm += sys_time - rtc_time;
    } else
    alarm = rtc_time + seconds + 1;
    if (setup_alarm(fd, &alarm) < 0)
    return 1;

    sync();
    printf("%s: wakeup from \"%s\" using %s at %s",
    progname, suspend, devname,
    ctime(&alarm));
    fflush(stdout);
    usleep(10 * 1000);

    if (strcmp(suspend, "on") != 0)
    suspend_system(suspend);
    else {
    unsigned long data;

    do {
    t = read(fd, &data, sizeof data);
    if (t < 0) {
    perror("rtc read");
    break;
    }
    if (verbose)
    printf("... %s: %03lx\n", devname, data);
    } while (!(data & RTC_AF));
    }

    if (ioctl(fd, RTC_AIE_OFF, 0) < 0)
    perror("disable rtc alarm interrupt");

    close(fd);
    return 0;
    }

    This patch:

    Make rtc-cmos do the relevant magic so this RTC can wake the system from a
    sleep state. That magic comes in two basic flavors:

    - Straightforward: enable_irq_wake(), the way it'd work on most SOC chips;
    or generally with system sleep states which don't disable core IRQ logic.

    - Roundabout, using non-IRQ platform hooks. This is needed with ACPI and
    one almost-clone chip which uses a special wakeup-only alarm. (That's
    the RTC used on Footbridge boards, FWIW, which don't do PM in Linux.)

    A separate patch implements those hooks for ACPI platforms, so that rtc_cmos
    can issue system wakeup events (and its sysfs "wakealarm" attribute works on
    at least some systems).

    Signed-off-by: David Brownell
    Cc: Alessandro Zummo
    Cc: Len Brown
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • - vr41xx_rtc_read_alarm() reports alarm enabled.
    - vr41xx_rtc_set_alarm() sets alarm disable/enable by rtc_wkalrm.enabled.

    Signed-off-by: Yoichi Yuasa
    Acked-by: Alessandro Zummo
    Acked-by: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Yoichi Yuasa
     
  • Signed-off-by: Alessandro Zummo
    Cc: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Alessandro Zummo
     
  • Fix a goof in the revised classdev support for RTCs: make sure the /dev
    node info is ready before the device is registered, not after. Otherwise
    the /sys/class/rtc/rtcN/dev attribute won't be created and then udev won't
    have the information it needs to create the /dev/rtcN node.

    Signed-off-by: David Brownell
    Cc: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • Signed-off-by: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • RTC class suspend/resume support, re-initializing the system clock on resume
    from the clock used to initialize it at boot time.

    - The reinit-on-resume is hooked to the existing RTC_HCTOSYS config
    option, on the grounds that a clock good enough for init must also
    be good enough for re-init.

    - Inlining a version of the code used by ARM, to save and restore the
    delta between a selected RTC and the current system wall-clock time.

    - Removes calls to that ARM code from AT91, OMAP1, and S3C RTCs. This
    means that systems using those RTCs across suspend/resume will likely
    want to change their kernel configs to enable RTC_HCTOSYS.

    If HCTOSYS isn't using a second RTC (with battery?), this changes the
    system's initial date from Jan 1970 to the epoch this hardware uses:
    1998 for AT91, 2000 for OMAP1 (assuming no split power mode), etc.

    This goes on top of the patch series removing "struct class_device" usage
    from the RTC framework. That's all needed for class suspend()/resume().

    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • Finish converting the RTC framework so it no longer uses class_device.

    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • This simplifies the RTC procfs support by removing the class_interface that
    hooks it into the rtc core. If it's configured, then sysfs support is now
    part of the RTC core, and is never a separate module.

    It also removes the class_interface hook, now that its last remaining user is
    gone. (That API is usable only with a "struct class_device".)

    It's another step towards being able to remove "struct class_device".

    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • This simplifies the RTC sysfs support by removing the class_interface that
    hooks it into the rtc core. If it's configured, then sysfs support is now
    part of the RTC core, and is never a separate module.

    It's another step towards being able to remove "struct class_device".

    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • This patch removes class_device from the programming interface that the RTC
    framework exposes to the rest of the kernel. Now an rtc_device is passed,
    which is more type-safe and streamlines all the relevant code.

    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • This simplifies the /dev support by removing a superfluous class_device (the
    /sys/class/rtc-dev stuff) and the class_interface that hooks it into the rtc
    core. Accordingly, if it's configured then /dev support is now part of the
    RTC core, and is never a separate module.

    It's another step towards being able to remove "struct class_device".

    [bunk@stusta.de: drivers/rtc/rtc-dev.c should #include "rtc-core.h"]
    Signed-off-by: David Brownell
    Acked-by: Greg Kroah-Hartman
    Acked-By: Alessandro Zummo
    Signed-off-by: Adrian Bunk
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     
  • Signed-off-by: Dale Farnsworth.org
    Cc: Alessandro Zummo
    Cc: David Brownell
    Cc: Jean Delvare
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Dale Farnsworth
     
  • Add an RTC driver for Ricoh RS5C313 RTC chip.

    [akpm@linux-foundation.org: Zillions of coding-style fixes]
    [akpm@linux-foundation.org: build fixes]
    Signed-off-by: Nobuhiro Iwamatsu
    Cc: Alessandro Zummo
    Cc: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Nobuhiro Iwamatsu
     

08 May, 2007

1 commit

  • This patch implements the driver necessary use the Analog Devices Blackfin
    processor's on-chip RTC controller.

    Signed-off-by: Bryan Wu
    Cc: Alessandro Zummo
    Cc: David Brownell
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    Wu, Bryan
     

03 Apr, 2007

1 commit

  • Lockdep reported cmos_suspend() and cmos_resume() calling rtc_update_irq()
    with IRQs enabled; not allowed.

    Also fix problems seen on some hardware, whereby false alarm IRQs could be
    reported (primarily to userspace); and update two comments to match changes
    in ACPI. Those make up most of this patch, by volume.

    Signed-off-by: David Brownell
    Cc: Alessandro Zummo
    Signed-off-by: Andrew Morton
    Signed-off-by: Linus Torvalds

    David Brownell
     

05 Mar, 2007

3 commits