Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
linux
Commits
ea4078bd
Commit
ea4078bd
authored
Oct 02, 2002
by
Jeff Dike
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Small changes to bring UML up to date with 2.5.40.
parent
7570df54
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
18 additions
and
22 deletions
+18
-22
arch/um/Makefile
arch/um/Makefile
+0
-5
arch/um/drivers/chan_kern.c
arch/um/drivers/chan_kern.c
+1
-1
arch/um/drivers/ubd_kern.c
arch/um/drivers/ubd_kern.c
+4
-3
arch/um/include/sysdep-ppc/sigcontext.h
arch/um/include/sysdep-ppc/sigcontext.h
+2
-2
arch/um/kernel/signal_kern.c
arch/um/kernel/signal_kern.c
+10
-10
arch/um/kernel/trap_user.c
arch/um/kernel/trap_user.c
+1
-1
No files found.
arch/um/Makefile
View file @
ea4078bd
...
@@ -30,11 +30,6 @@ PROFILE += -pg -DPROFILING
...
@@ -30,11 +30,6 @@ PROFILE += -pg -DPROFILING
LINK_PROFILE
=
$(PROFILE)
-Wl
,--wrap,__monstartup
LINK_PROFILE
=
$(PROFILE)
-Wl
,--wrap,__monstartup
endif
endif
ARCH_SUBDIRS
=
$(ARCH_DIR)
/drivers
$(ARCH_DIR)
/kernel
\
$(ARCH_DIR)
/sys-
$(SUBARCH)
$(ARCH_DIR)
/os-
$(OS)
SUBDIRS
+=
$(ARCH_SUBDIRS)
core-y
+=
$(ARCH_DIR)
/kernel/
\
core-y
+=
$(ARCH_DIR)
/kernel/
\
$(ARCH_DIR)
/drivers/
\
$(ARCH_DIR)
/drivers/
\
$(ARCH_DIR)
/sys-
$(SUBARCH)
/
$(ARCH_DIR)
/sys-
$(SUBARCH)
/
...
...
arch/um/drivers/chan_kern.c
View file @
ea4078bd
...
@@ -409,7 +409,7 @@ void chan_interrupt(struct list_head *chans, struct tq_struct *task,
...
@@ -409,7 +409,7 @@ void chan_interrupt(struct list_head *chans, struct tq_struct *task,
do
{
do
{
if
((
tty
!=
NULL
)
&&
if
((
tty
!=
NULL
)
&&
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)){
(
tty
->
flip
.
count
>=
TTY_FLIPBUF_SIZE
)){
queue_task
(
task
,
&
tq_timer
);
schedule_task
(
task
);
goto
out
;
goto
out
;
}
}
err
=
chan
->
ops
->
read
(
chan
->
fd
,
&
c
,
chan
->
data
);
err
=
chan
->
ops
->
read
(
chan
->
fd
,
&
c
,
chan
->
data
);
...
...
arch/um/drivers/ubd_kern.c
View file @
ea4078bd
...
@@ -406,7 +406,7 @@ static int ubd_add(int n)
...
@@ -406,7 +406,7 @@ static int ubd_add(int n)
ubd_gendisk
[
n
].
major
=
MAJOR_NR
;
ubd_gendisk
[
n
].
major
=
MAJOR_NR
;
ubd_gendisk
[
n
].
first_minor
=
n
<<
UBD_SHIFT
;
ubd_gendisk
[
n
].
first_minor
=
n
<<
UBD_SHIFT
;
ubd_gendisk
[
n
].
minor_shift
=
UBD_SHIFT
;
ubd_gendisk
[
n
].
minor_shift
=
UBD_SHIFT
;
ubd_gendisk
[
n
].
fops
=
&
ubd_
f
ops
;
ubd_gendisk
[
n
].
fops
=
&
ubd_
bl
ops
;
if
(
fakehd_set
)
if
(
fakehd_set
)
sprintf
(
ubd_gendisk
[
n
].
disk_name
,
"hd%c"
,
n
+
'a'
);
sprintf
(
ubd_gendisk
[
n
].
disk_name
,
"hd%c"
,
n
+
'a'
);
else
else
...
@@ -416,7 +416,7 @@ static int ubd_add(int n)
...
@@ -416,7 +416,7 @@ static int ubd_add(int n)
fake_gendisk
[
n
].
major
=
fake_major
;
fake_gendisk
[
n
].
major
=
fake_major
;
fake_gendisk
[
n
].
first_minor
=
n
<<
UBD_SHIFT
;
fake_gendisk
[
n
].
first_minor
=
n
<<
UBD_SHIFT
;
fake_gendisk
[
n
].
minor_shift
=
UBD_SHIFT
;
fake_gendisk
[
n
].
minor_shift
=
UBD_SHIFT
;
fake_gendisk
[
n
].
fops
=
&
ubd_
f
ops
;
fake_gendisk
[
n
].
fops
=
&
ubd_
bl
ops
;
sprintf
(
fake_gendisk
[
n
].
disk_name
,
"ubd%d"
,
n
);
sprintf
(
fake_gendisk
[
n
].
disk_name
,
"ubd%d"
,
n
);
}
}
...
@@ -445,7 +445,7 @@ static int ubd_add(int n)
...
@@ -445,7 +445,7 @@ static int ubd_add(int n)
if
(
real
==
NULL
)
return
(
-
1
);
if
(
real
==
NULL
)
return
(
-
1
);
ubd_dev
[
n
].
real
=
real
;
ubd_dev
[
n
].
real
=
real
;
make_ide_entries
(
ubd_gendisk
[
n
].
name
);
make_ide_entries
(
ubd_gendisk
[
n
].
disk_
name
);
return
(
0
);
return
(
0
);
}
}
...
@@ -863,6 +863,7 @@ static int ubd_ioctl(struct inode * inode, struct file * file,
...
@@ -863,6 +863,7 @@ static int ubd_ioctl(struct inode * inode, struct file * file,
return
(
-
EFAULT
);
return
(
-
EFAULT
);
return
(
0
);
return
(
0
);
}
}
return
(
-
EINVAL
);
}
}
static
int
ubd_revalidate
(
kdev_t
rdev
)
static
int
ubd_revalidate
(
kdev_t
rdev
)
...
...
arch/um/include/sysdep-ppc/sigcontext.h
View file @
ea4078bd
...
@@ -9,7 +9,7 @@
...
@@ -9,7 +9,7 @@
#define DSISR_WRITE 0x02000000
#define DSISR_WRITE 0x02000000
#define SC_FAULT_ADDR(sc) ({ \
#define SC_FAULT_ADDR(sc) ({ \
struct sigcontext
_struct
*_sc = (sc); \
struct sigcontext *_sc = (sc); \
long retval = -1; \
long retval = -1; \
switch (_sc->regs->trap) { \
switch (_sc->regs->trap) { \
case 0x300: \
case 0x300: \
...
@@ -27,7 +27,7 @@
...
@@ -27,7 +27,7 @@
})
})
#define SC_FAULT_WRITE(sc) ({ \
#define SC_FAULT_WRITE(sc) ({ \
struct sigcontext
_struct
*_sc = (sc); \
struct sigcontext *_sc = (sc); \
long retval = -1; \
long retval = -1; \
switch (_sc->regs->trap) { \
switch (_sc->regs->trap) { \
case 0x300: \
case 0x300: \
...
...
arch/um/kernel/signal_kern.c
View file @
ea4078bd
...
@@ -101,12 +101,12 @@ static int handle_signal(struct pt_regs *regs, unsigned long signr,
...
@@ -101,12 +101,12 @@ static int handle_signal(struct pt_regs *regs, unsigned long signr,
ka
->
sa
.
sa_handler
=
SIG_DFL
;
ka
->
sa
.
sa_handler
=
SIG_DFL
;
if
(
!
(
ka
->
sa
.
sa_flags
&
SA_NODEFER
))
{
if
(
!
(
ka
->
sa
.
sa_flags
&
SA_NODEFER
))
{
spin_lock_irq
(
&
current
->
sig
mask_
lock
);
spin_lock_irq
(
&
current
->
sig
->
sig
lock
);
sigorsets
(
&
current
->
blocked
,
&
current
->
blocked
,
sigorsets
(
&
current
->
blocked
,
&
current
->
blocked
,
&
ka
->
sa
.
sa_mask
);
&
ka
->
sa
.
sa_mask
);
sigaddset
(
&
current
->
blocked
,
signr
);
sigaddset
(
&
current
->
blocked
,
signr
);
recalc_sigpending
();
recalc_sigpending
();
spin_unlock_irq
(
&
current
->
sig
mask_
lock
);
spin_unlock_irq
(
&
current
->
sig
->
sig
lock
);
}
}
sp
=
PT_REGS_SP
(
regs
);
sp
=
PT_REGS_SP
(
regs
);
...
@@ -188,11 +188,11 @@ int sys_sigsuspend(int history0, int history1, old_sigset_t mask)
...
@@ -188,11 +188,11 @@ int sys_sigsuspend(int history0, int history1, old_sigset_t mask)
sigset_t
saveset
;
sigset_t
saveset
;
mask
&=
_BLOCKABLE
;
mask
&=
_BLOCKABLE
;
spin_lock_irq
(
&
current
->
sig
mask_
lock
);
spin_lock_irq
(
&
current
->
sig
->
sig
lock
);
saveset
=
current
->
blocked
;
saveset
=
current
->
blocked
;
siginitset
(
&
current
->
blocked
,
mask
);
siginitset
(
&
current
->
blocked
,
mask
);
recalc_sigpending
();
recalc_sigpending
();
spin_unlock_irq
(
&
current
->
sig
mask_
lock
);
spin_unlock_irq
(
&
current
->
sig
->
sig
lock
);
while
(
1
)
{
while
(
1
)
{
current
->
state
=
TASK_INTERRUPTIBLE
;
current
->
state
=
TASK_INTERRUPTIBLE
;
...
@@ -214,11 +214,11 @@ int sys_rt_sigsuspend(sigset_t *unewset, size_t sigsetsize)
...
@@ -214,11 +214,11 @@ int sys_rt_sigsuspend(sigset_t *unewset, size_t sigsetsize)
return
-
EFAULT
;
return
-
EFAULT
;
sigdelsetmask
(
&
newset
,
~
_BLOCKABLE
);
sigdelsetmask
(
&
newset
,
~
_BLOCKABLE
);
spin_lock_irq
(
&
current
->
sig
mask_
lock
);
spin_lock_irq
(
&
current
->
sig
->
sig
lock
);
saveset
=
current
->
blocked
;
saveset
=
current
->
blocked
;
current
->
blocked
=
newset
;
current
->
blocked
=
newset
;
recalc_sigpending
();
recalc_sigpending
();
spin_unlock_irq
(
&
current
->
sig
mask_
lock
);
spin_unlock_irq
(
&
current
->
sig
->
sig
lock
);
while
(
1
)
{
while
(
1
)
{
current
->
state
=
TASK_INTERRUPTIBLE
;
current
->
state
=
TASK_INTERRUPTIBLE
;
...
@@ -234,13 +234,13 @@ int sys_sigreturn(struct pt_regs regs)
...
@@ -234,13 +234,13 @@ int sys_sigreturn(struct pt_regs regs)
void
*
mask
=
sp_to_mask
(
PT_REGS_SP
(
&
regs
));
void
*
mask
=
sp_to_mask
(
PT_REGS_SP
(
&
regs
));
int
sig_size
=
(
_NSIG_WORDS
-
1
)
*
sizeof
(
unsigned
long
);
int
sig_size
=
(
_NSIG_WORDS
-
1
)
*
sizeof
(
unsigned
long
);
spin_lock_irq
(
&
current
->
sig
mask_
lock
);
spin_lock_irq
(
&
current
->
sig
->
sig
lock
);
copy_from_user
(
&
current
->
blocked
.
sig
[
0
],
sc_sigmask
(
sc
),
copy_from_user
(
&
current
->
blocked
.
sig
[
0
],
sc_sigmask
(
sc
),
sizeof
(
current
->
blocked
.
sig
[
0
]));
sizeof
(
current
->
blocked
.
sig
[
0
]));
copy_from_user
(
&
current
->
blocked
.
sig
[
1
],
mask
,
sig_size
);
copy_from_user
(
&
current
->
blocked
.
sig
[
1
],
mask
,
sig_size
);
sigdelsetmask
(
&
current
->
blocked
,
~
_BLOCKABLE
);
sigdelsetmask
(
&
current
->
blocked
,
~
_BLOCKABLE
);
recalc_sigpending
();
recalc_sigpending
();
spin_unlock_irq
(
&
current
->
sig
mask_
lock
);
spin_unlock_irq
(
&
current
->
sig
->
sig
lock
);
copy_sc_from_user
(
current
->
thread
.
regs
.
regs
.
sc
,
sc
,
copy_sc_from_user
(
current
->
thread
.
regs
.
regs
.
sc
,
sc
,
&
signal_frame_sc
.
arch
);
&
signal_frame_sc
.
arch
);
return
(
PT_REGS_SYSCALL_RET
(
&
current
->
thread
.
regs
));
return
(
PT_REGS_SYSCALL_RET
(
&
current
->
thread
.
regs
));
...
@@ -252,11 +252,11 @@ int sys_rt_sigreturn(struct pt_regs regs)
...
@@ -252,11 +252,11 @@ int sys_rt_sigreturn(struct pt_regs regs)
void
*
mask
=
sp_to_rt_mask
(
PT_REGS_SP
(
&
regs
));
void
*
mask
=
sp_to_rt_mask
(
PT_REGS_SP
(
&
regs
));
int
sig_size
=
_NSIG_WORDS
*
sizeof
(
unsigned
long
);
int
sig_size
=
_NSIG_WORDS
*
sizeof
(
unsigned
long
);
spin_lock_irq
(
&
current
->
sig
mask_
lock
);
spin_lock_irq
(
&
current
->
sig
->
sig
lock
);
copy_from_user
(
&
current
->
blocked
,
mask
,
sig_size
);
copy_from_user
(
&
current
->
blocked
,
mask
,
sig_size
);
sigdelsetmask
(
&
current
->
blocked
,
~
_BLOCKABLE
);
sigdelsetmask
(
&
current
->
blocked
,
~
_BLOCKABLE
);
recalc_sigpending
();
recalc_sigpending
();
spin_unlock_irq
(
&
current
->
sig
mask_
lock
);
spin_unlock_irq
(
&
current
->
sig
->
sig
lock
);
copy_sc_from_user
(
current
->
thread
.
regs
.
regs
.
sc
,
sc
,
copy_sc_from_user
(
current
->
thread
.
regs
.
regs
.
sc
,
sc
,
&
signal_frame_sc
.
arch
);
&
signal_frame_sc
.
arch
);
return
(
PT_REGS_SYSCALL_RET
(
&
current
->
thread
.
regs
));
return
(
PT_REGS_SYSCALL_RET
(
&
current
->
thread
.
regs
));
...
...
arch/um/kernel/trap_user.c
View file @
ea4078bd
...
@@ -416,7 +416,7 @@ int nsegfaults = 0;
...
@@ -416,7 +416,7 @@ int nsegfaults = 0;
void
segv_handler
(
int
sig
,
struct
uml_pt_regs
*
regs
)
void
segv_handler
(
int
sig
,
struct
uml_pt_regs
*
regs
)
{
{
struct
sigcontext
_struct
*
context
=
regs
->
sc
;
struct
sigcontext
*
context
=
regs
->
sc
;
int
index
;
int
index
;
if
(
regs
->
is_user
&&
!
SEGV_IS_FIXABLE
(
context
)){
if
(
regs
->
is_user
&&
!
SEGV_IS_FIXABLE
(
context
)){
...
...
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