Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
49e7dc54
Commit
49e7dc54
authored
Apr 30, 2005
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge of master.kernel.org:/home/rmk/linux-2.6-rmk.git
parents
9ea1f8f5
bb9bffcb
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
60 additions
and
23 deletions
+60
-23
arch/arm/common/rtctime.c
arch/arm/common/rtctime.c
+15
-14
arch/arm/mach-integrator/time.c
arch/arm/mach-integrator/time.c
+12
-5
arch/arm/mach-pxa/generic.c
arch/arm/mach-pxa/generic.c
+25
-0
drivers/char/s3c2410-rtc.c
drivers/char/s3c2410-rtc.c
+6
-2
include/asm-arm/rtc.h
include/asm-arm/rtc.h
+2
-2
No files found.
arch/arm/common/rtctime.c
View file @
49e7dc54
...
@@ -141,10 +141,10 @@ void rtc_next_alarm_time(struct rtc_time *next, struct rtc_time *now, struct rtc
...
@@ -141,10 +141,10 @@ void rtc_next_alarm_time(struct rtc_time *next, struct rtc_time *now, struct rtc
next
->
tm_sec
=
alrm
->
tm_sec
;
next
->
tm_sec
=
alrm
->
tm_sec
;
}
}
static
inline
void
rtc_read_time
(
struct
rtc_ops
*
ops
,
struct
rtc_time
*
tm
)
static
inline
int
rtc_read_time
(
struct
rtc_ops
*
ops
,
struct
rtc_time
*
tm
)
{
{
memset
(
tm
,
0
,
sizeof
(
struct
rtc_time
));
memset
(
tm
,
0
,
sizeof
(
struct
rtc_time
));
ops
->
read_time
(
tm
);
return
ops
->
read_time
(
tm
);
}
}
static
inline
int
rtc_set_time
(
struct
rtc_ops
*
ops
,
struct
rtc_time
*
tm
)
static
inline
int
rtc_set_time
(
struct
rtc_ops
*
ops
,
struct
rtc_time
*
tm
)
...
@@ -163,8 +163,7 @@ static inline int rtc_read_alarm(struct rtc_ops *ops, struct rtc_wkalrm *alrm)
...
@@ -163,8 +163,7 @@ static inline int rtc_read_alarm(struct rtc_ops *ops, struct rtc_wkalrm *alrm)
int
ret
=
-
EINVAL
;
int
ret
=
-
EINVAL
;
if
(
ops
->
read_alarm
)
{
if
(
ops
->
read_alarm
)
{
memset
(
alrm
,
0
,
sizeof
(
struct
rtc_wkalrm
));
memset
(
alrm
,
0
,
sizeof
(
struct
rtc_wkalrm
));
ops
->
read_alarm
(
alrm
);
ret
=
ops
->
read_alarm
(
alrm
);
ret
=
0
;
}
}
return
ret
;
return
ret
;
}
}
...
@@ -283,7 +282,9 @@ static int rtc_ioctl(struct inode *inode, struct file *file, unsigned int cmd,
...
@@ -283,7 +282,9 @@ static int rtc_ioctl(struct inode *inode, struct file *file, unsigned int cmd,
break
;
break
;
case
RTC_RD_TIME
:
case
RTC_RD_TIME
:
rtc_read_time
(
ops
,
&
tm
);
ret
=
rtc_read_time
(
ops
,
&
tm
);
if
(
ret
)
break
;
ret
=
copy_to_user
(
uarg
,
&
tm
,
sizeof
(
tm
));
ret
=
copy_to_user
(
uarg
,
&
tm
,
sizeof
(
tm
));
if
(
ret
)
if
(
ret
)
ret
=
-
EFAULT
;
ret
=
-
EFAULT
;
...
@@ -424,15 +425,15 @@ static int rtc_read_proc(char *page, char **start, off_t off, int count, int *eo
...
@@ -424,15 +425,15 @@ static int rtc_read_proc(char *page, char **start, off_t off, int count, int *eo
struct
rtc_time
tm
;
struct
rtc_time
tm
;
char
*
p
=
page
;
char
*
p
=
page
;
rtc_read_time
(
ops
,
&
tm
);
if
(
rtc_read_time
(
ops
,
&
tm
)
==
0
)
{
p
+=
sprintf
(
p
,
p
+=
sprintf
(
p
,
"rtc_time
\t
: %02d:%02d:%02d
\n
"
"rtc_time
\t
: %02d:%02d:
%02d
\n
"
"rtc_date
\t
: %04d-%02d-
%02d
\n
"
"rtc_date
\t
: %04d-%02d-%02d
\n
"
"rtc_epoch
\t
: %04lu
\n
"
,
"rtc_epoch
\t
: %04lu
\n
"
,
tm
.
tm_hour
,
tm
.
tm_min
,
tm
.
tm_sec
,
tm
.
tm_hour
,
tm
.
tm_min
,
tm
.
tm_sec
,
tm
.
tm_year
+
1900
,
tm
.
tm_mon
+
1
,
tm
.
tm_mday
,
tm
.
tm_year
+
1900
,
tm
.
tm_mon
+
1
,
tm
.
tm_mday
,
rtc_epoch
);
rtc_epoch
);
}
if
(
rtc_read_alarm
(
ops
,
&
alrm
)
==
0
)
{
if
(
rtc_read_alarm
(
ops
,
&
alrm
)
==
0
)
{
p
+=
sprintf
(
p
,
"alrm_time
\t
: "
);
p
+=
sprintf
(
p
,
"alrm_time
\t
: "
);
...
...
arch/arm/mach-integrator/time.c
View file @
49e7dc54
...
@@ -40,25 +40,32 @@ static int integrator_set_rtc(void)
...
@@ -40,25 +40,32 @@ static int integrator_set_rtc(void)
return
1
;
return
1
;
}
}
static
void
rtc_read_alarm
(
struct
rtc_wkalrm
*
alrm
)
static
int
rtc_read_alarm
(
struct
rtc_wkalrm
*
alrm
)
{
{
rtc_time_to_tm
(
readl
(
rtc_base
+
RTC_MR
),
&
alrm
->
time
);
rtc_time_to_tm
(
readl
(
rtc_base
+
RTC_MR
),
&
alrm
->
time
);
return
0
;
}
}
static
int
rtc_set_alarm
(
struct
rtc_wkalrm
*
alrm
)
static
in
line
in
t
rtc_set_alarm
(
struct
rtc_wkalrm
*
alrm
)
{
{
unsigned
long
time
;
unsigned
long
time
;
int
ret
;
int
ret
;
ret
=
rtc_tm_to_time
(
&
alrm
->
time
,
&
time
);
/*
* At the moment, we can only deal with non-wildcarded alarm times.
*/
ret
=
rtc_valid_tm
(
&
alrm
->
time
);
if
(
ret
==
0
)
ret
=
rtc_tm_to_time
(
&
alrm
->
time
,
&
time
);
if
(
ret
==
0
)
if
(
ret
==
0
)
writel
(
time
,
rtc_base
+
RTC_MR
);
writel
(
time
,
rtc_base
+
RTC_MR
);
return
ret
;
return
ret
;
}
}
static
void
rtc_read_time
(
struct
rtc_time
*
tm
)
static
int
rtc_read_time
(
struct
rtc_time
*
tm
)
{
{
rtc_time_to_tm
(
readl
(
rtc_base
+
RTC_DR
),
tm
);
rtc_time_to_tm
(
readl
(
rtc_base
+
RTC_DR
),
tm
);
return
0
;
}
}
/*
/*
...
@@ -69,7 +76,7 @@ static void rtc_read_time(struct rtc_time *tm)
...
@@ -69,7 +76,7 @@ static void rtc_read_time(struct rtc_time *tm)
* edge of the 1Hz clock, we must write the time one second
* edge of the 1Hz clock, we must write the time one second
* in advance.
* in advance.
*/
*/
static
int
rtc_set_time
(
struct
rtc_time
*
tm
)
static
in
line
in
t
rtc_set_time
(
struct
rtc_time
*
tm
)
{
{
unsigned
long
time
;
unsigned
long
time
;
int
ret
;
int
ret
;
...
...
arch/arm/mach-pxa/generic.c
View file @
49e7dc54
...
@@ -220,6 +220,30 @@ static struct platform_device stuart_device = {
...
@@ -220,6 +220,30 @@ static struct platform_device stuart_device = {
.
id
=
2
,
.
id
=
2
,
};
};
static
struct
resource
i2c_resources
[]
=
{
{
.
start
=
0x40301680
,
.
end
=
0x403016a3
,
.
flags
=
IORESOURCE_MEM
,
},
{
.
start
=
IRQ_I2C
,
.
end
=
IRQ_I2C
,
.
flags
=
IORESOURCE_IRQ
,
},
};
static
struct
platform_device
i2c_device
=
{
.
name
=
"pxa2xx-i2c"
,
.
id
=
0
,
.
resource
=
i2c_resources
,
.
num_resources
=
ARRAY_SIZE
(
i2c_resources
),
};
void
__init
pxa_set_i2c_info
(
struct
i2c_pxa_platform_data
*
info
)
{
i2c_device
.
dev
.
platform_data
=
info
;
}
static
struct
platform_device
*
devices
[]
__initdata
=
{
static
struct
platform_device
*
devices
[]
__initdata
=
{
&
pxamci_device
,
&
pxamci_device
,
&
udc_device
,
&
udc_device
,
...
@@ -227,6 +251,7 @@ static struct platform_device *devices[] __initdata = {
...
@@ -227,6 +251,7 @@ static struct platform_device *devices[] __initdata = {
&
ffuart_device
,
&
ffuart_device
,
&
btuart_device
,
&
btuart_device
,
&
stuart_device
,
&
stuart_device
,
&
i2c_device
,
};
};
static
int
__init
pxa_init
(
void
)
static
int
__init
pxa_init
(
void
)
...
...
drivers/char/s3c2410-rtc.c
View file @
49e7dc54
...
@@ -116,7 +116,7 @@ static void s3c2410_rtc_setfreq(int freq)
...
@@ -116,7 +116,7 @@ static void s3c2410_rtc_setfreq(int freq)
/* Time read/write */
/* Time read/write */
static
void
s3c2410_rtc_gettime
(
struct
rtc_time
*
rtc_tm
)
static
int
s3c2410_rtc_gettime
(
struct
rtc_time
*
rtc_tm
)
{
{
unsigned
int
have_retried
=
0
;
unsigned
int
have_retried
=
0
;
...
@@ -151,6 +151,8 @@ static void s3c2410_rtc_gettime(struct rtc_time *rtc_tm)
...
@@ -151,6 +151,8 @@ static void s3c2410_rtc_gettime(struct rtc_time *rtc_tm)
rtc_tm
->
tm_year
+=
100
;
rtc_tm
->
tm_year
+=
100
;
rtc_tm
->
tm_mon
-=
1
;
rtc_tm
->
tm_mon
-=
1
;
return
0
;
}
}
...
@@ -171,7 +173,7 @@ static int s3c2410_rtc_settime(struct rtc_time *tm)
...
@@ -171,7 +173,7 @@ static int s3c2410_rtc_settime(struct rtc_time *tm)
return
0
;
return
0
;
}
}
static
void
s3c2410_rtc_getalarm
(
struct
rtc_wkalrm
*
alrm
)
static
int
s3c2410_rtc_getalarm
(
struct
rtc_wkalrm
*
alrm
)
{
{
struct
rtc_time
*
alm_tm
=
&
alrm
->
time
;
struct
rtc_time
*
alm_tm
=
&
alrm
->
time
;
unsigned
int
alm_en
;
unsigned
int
alm_en
;
...
@@ -231,6 +233,8 @@ static void s3c2410_rtc_getalarm(struct rtc_wkalrm *alrm)
...
@@ -231,6 +233,8 @@ static void s3c2410_rtc_getalarm(struct rtc_wkalrm *alrm)
}
}
/* todo - set alrm->enabled ? */
/* todo - set alrm->enabled ? */
return
0
;
}
}
static
int
s3c2410_rtc_setalarm
(
struct
rtc_wkalrm
*
alrm
)
static
int
s3c2410_rtc_setalarm
(
struct
rtc_wkalrm
*
alrm
)
...
...
include/asm-arm/rtc.h
View file @
49e7dc54
...
@@ -18,9 +18,9 @@ struct rtc_ops {
...
@@ -18,9 +18,9 @@ struct rtc_ops {
void
(
*
release
)(
void
);
void
(
*
release
)(
void
);
int
(
*
ioctl
)(
unsigned
int
,
unsigned
long
);
int
(
*
ioctl
)(
unsigned
int
,
unsigned
long
);
void
(
*
read_time
)(
struct
rtc_time
*
);
int
(
*
read_time
)(
struct
rtc_time
*
);
int
(
*
set_time
)(
struct
rtc_time
*
);
int
(
*
set_time
)(
struct
rtc_time
*
);
void
(
*
read_alarm
)(
struct
rtc_wkalrm
*
);
int
(
*
read_alarm
)(
struct
rtc_wkalrm
*
);
int
(
*
set_alarm
)(
struct
rtc_wkalrm
*
);
int
(
*
set_alarm
)(
struct
rtc_wkalrm
*
);
int
(
*
proc
)(
char
*
buf
);
int
(
*
proc
)(
char
*
buf
);
};
};
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment