Commit ca28fe37 authored by Linus Torvalds's avatar Linus Torvalds

Merge bk://bk.arm.linux.org.uk/linux-2.6-rmk

into ppc970.osdl.org:/home/torvalds/v2.6/linux
parents 0a57a616 34529e84
...@@ -163,9 +163,9 @@ CONFIG_MACH_ and CONFIG_ARCH_ ...@@ -163,9 +163,9 @@ CONFIG_MACH_ and CONFIG_ARCH_
<http://www.arm.linux.org.uk/developer/machines/> <http://www.arm.linux.org.uk/developer/machines/>
Kernel entry (head-armv.S) Kernel entry (head.S)
-------------------------- --------------------------
The initial entry into the kernel is via head-armv.S, which uses machine The initial entry into the kernel is via head.S, which uses machine
independent code. The machine is selected by the value of 'r1' on independent code. The machine is selected by the value of 'r1' on
entry, which must be kept unique. entry, which must be kept unique.
......
/* /*
* linux/arch/arm/kernel/head-armv.S * linux/arch/arm/kernel/head.S
* *
* Copyright (C) 1994-2002 Russell King * Copyright (C) 1994-2002 Russell King
* *
......
...@@ -138,7 +138,7 @@ __arm710_setup: mov r0, #0 ...@@ -138,7 +138,7 @@ __arm710_setup: mov r0, #0
bic r0, r0, #0x0e00 @ ..V. ..RS BLDP WCAM bic r0, r0, #0x0e00 @ ..V. ..RS BLDP WCAM
orr r0, r0, #0x0100 @ .... .... .111 .... (old) orr r0, r0, #0x0100 @ .... .... .111 .... (old)
orr r0, r0, #0x003d @ .... ..01 ..11 1101 (new) orr r0, r0, #0x003d @ .... ..01 ..11 1101 (new)
mov pc, lr @ __ret (head-armv.S) mov pc, lr @ __ret (head.S)
.size __arm710_setup, . - __arm710_setup .size __arm710_setup, . - __arm710_setup
.type __arm720_setup, #function .type __arm720_setup, #function
...@@ -153,7 +153,7 @@ __arm720_setup: mov r0, #0 ...@@ -153,7 +153,7 @@ __arm720_setup: mov r0, #0
bic r0, r0, #0x0e00 @ ..V. ..RS BLDP WCAM bic r0, r0, #0x0e00 @ ..V. ..RS BLDP WCAM
orr r0, r0, #0x2100 @ .... .... .111 .... (old) orr r0, r0, #0x2100 @ .... .... .111 .... (old)
orr r0, r0, #0x003d @ ..1. ..01 ..11 1101 (new) orr r0, r0, #0x003d @ ..1. ..01 ..11 1101 (new)
mov pc, lr @ __ret (head-armv.S) mov pc, lr @ __ret (head.S)
.size __arm720_setup, . - __arm720_setup .size __arm720_setup, . - __arm720_setup
__INITDATA __INITDATA
......
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
* Changelog: * Changelog:
* 08-Nov-2004 BJD Initial creation * 08-Nov-2004 BJD Initial creation
* 12-Nov-2004 BJD Added periodic IRQ and PM code * 12-Nov-2004 BJD Added periodic IRQ and PM code
* 22-Nov-2004 BJD Sign-test on alarm code to check for <0
*/ */
#include <linux/module.h> #include <linux/module.h>
...@@ -236,26 +237,26 @@ static int s3c2410_rtc_setalarm(struct rtc_wkalrm *alrm) ...@@ -236,26 +237,26 @@ static int s3c2410_rtc_setalarm(struct rtc_wkalrm *alrm)
struct rtc_time *tm = &alrm->time; struct rtc_time *tm = &alrm->time;
unsigned int alrm_en; unsigned int alrm_en;
pr_debug("s3c2410_rtc_setalarm: %d, %02x.%02x.%02x %02x/%02x/%02x\n", pr_debug("s3c2410_rtc_setalarm: %d, %02x/%02x/%02x %02x.%02x.%02x\n",
alrm->enabled, alrm->enabled,
tm->tm_year & 0xff, tm->tm_mon & 0xff, tm->tm_mday & 0xff, tm->tm_mday & 0xff, tm->tm_mon & 0xff, tm->tm_year & 0xff,
tm->tm_hour, tm->tm_min, tm->tm_sec); tm->tm_hour & 0xff, tm->tm_min & 0xff, tm->tm_sec);
if (alrm->enabled || 1) { if (alrm->enabled || 1) {
alrm_en = readb(S3C2410_RTCALM) & S3C2410_RTCALM_ALMEN; alrm_en = readb(S3C2410_RTCALM) & S3C2410_RTCALM_ALMEN;
writeb(0x00, S3C2410_RTCALM); writeb(0x00, S3C2410_RTCALM);
if (tm->tm_sec < 60) { if (tm->tm_sec < 60 && tm->tm_sec >= 0) {
alrm_en |= S3C2410_RTCALM_SECEN; alrm_en |= S3C2410_RTCALM_SECEN;
writeb(BIN2BCD(tm->tm_sec), S3C2410_ALMSEC); writeb(BIN2BCD(tm->tm_sec), S3C2410_ALMSEC);
} }
if (tm->tm_min < 60) { if (tm->tm_min < 60 && tm->tm_min >= 0) {
alrm_en |= S3C2410_RTCALM_MINEN; alrm_en |= S3C2410_RTCALM_MINEN;
writeb(BIN2BCD(tm->tm_min), S3C2410_ALMMIN); writeb(BIN2BCD(tm->tm_min), S3C2410_ALMMIN);
} }
if (tm->tm_hour < 24) { if (tm->tm_hour < 24 && tm->tm_hour >= 0) {
alrm_en |= S3C2410_RTCALM_HOUREN; alrm_en |= S3C2410_RTCALM_HOUREN;
writeb(BIN2BCD(tm->tm_hour), S3C2410_ALMHOUR); writeb(BIN2BCD(tm->tm_hour), S3C2410_ALMHOUR);
} }
......
...@@ -24,13 +24,13 @@ struct processor; ...@@ -24,13 +24,13 @@ struct processor;
* *
* NOTE! The following structure is defined by assembly * NOTE! The following structure is defined by assembly
* language, NOT C code. For more information, check: * language, NOT C code. For more information, check:
* arch/arm/mm/proc-*.S and arch/arm/kernel/head-armv.S * arch/arm/mm/proc-*.S and arch/arm/kernel/head.S
*/ */
struct proc_info_list { struct proc_info_list {
unsigned int cpu_val; unsigned int cpu_val;
unsigned int cpu_mask; unsigned int cpu_mask;
unsigned long __cpu_mmu_flags; /* used by head-armv.S */ unsigned long __cpu_mmu_flags; /* used by head.S */
unsigned long __cpu_flush; /* used by head-armv.S */ unsigned long __cpu_flush; /* used by head.S */
const char *arch_name; const char *arch_name;
const char *elf_name; const char *elf_name;
unsigned int elf_hwcap; unsigned int elf_hwcap;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment