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
nexedi
linux
Commits
f4b89042
Commit
f4b89042
authored
May 07, 2003
by
Greg Kroah-Hartman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
TTY: add lock to tty_dev_list, and handle tty names with more than one '/'
Thanks to Al Viro for pointing out these problems.
parent
2f2a2dd0
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
8 additions
and
1 deletion
+8
-1
drivers/char/tty_io.c
drivers/char/tty_io.c
+8
-1
No files found.
drivers/char/tty_io.c
View file @
f4b89042
...
@@ -2110,6 +2110,7 @@ struct tty_dev {
...
@@ -2110,6 +2110,7 @@ struct tty_dev {
#define to_tty_dev(d) container_of(d, struct tty_dev, class_dev)
#define to_tty_dev(d) container_of(d, struct tty_dev, class_dev)
static
LIST_HEAD
(
tty_dev_list
);
static
LIST_HEAD
(
tty_dev_list
);
static
spinlock_t
tty_dev_list_lock
=
SPIN_LOCK_UNLOCKED
;
static
ssize_t
show_dev
(
struct
class_device
*
class_dev
,
char
*
buf
)
static
ssize_t
show_dev
(
struct
class_device
*
class_dev
,
char
*
buf
)
{
{
...
@@ -2130,7 +2131,7 @@ static void tty_add_class_device(char *name, dev_t dev, struct device *device)
...
@@ -2130,7 +2131,7 @@ static void tty_add_class_device(char *name, dev_t dev, struct device *device)
memset
(
tty_dev
,
0x00
,
sizeof
(
*
tty_dev
));
memset
(
tty_dev
,
0x00
,
sizeof
(
*
tty_dev
));
/* stupid '/' in tty name strings... */
/* stupid '/' in tty name strings... */
temp
=
strchr
(
name
,
'/'
);
temp
=
str
r
chr
(
name
,
'/'
);
if
(
temp
&&
(
temp
[
1
]
!=
0x00
))
if
(
temp
&&
(
temp
[
1
]
!=
0x00
))
++
temp
;
++
temp
;
else
else
...
@@ -2144,7 +2145,9 @@ static void tty_add_class_device(char *name, dev_t dev, struct device *device)
...
@@ -2144,7 +2145,9 @@ static void tty_add_class_device(char *name, dev_t dev, struct device *device)
goto
error
;
goto
error
;
class_device_create_file
(
&
tty_dev
->
class_dev
,
&
class_device_attr_dev
);
class_device_create_file
(
&
tty_dev
->
class_dev
,
&
class_device_attr_dev
);
tty_dev
->
dev
=
dev
;
tty_dev
->
dev
=
dev
;
spin_lock
(
&
tty_dev_list_lock
);
list_add
(
&
tty_dev
->
node
,
&
tty_dev_list
);
list_add
(
&
tty_dev
->
node
,
&
tty_dev_list
);
spin_unlock
(
&
tty_dev_list_lock
);
return
;
return
;
error:
error:
kfree
(
tty_dev
);
kfree
(
tty_dev
);
...
@@ -2156,6 +2159,7 @@ void tty_remove_class_device(dev_t dev)
...
@@ -2156,6 +2159,7 @@ void tty_remove_class_device(dev_t dev)
struct
list_head
*
tmp
;
struct
list_head
*
tmp
;
int
found
=
0
;
int
found
=
0
;
spin_lock
(
&
tty_dev_list_lock
);
list_for_each
(
tmp
,
&
tty_dev_list
)
{
list_for_each
(
tmp
,
&
tty_dev_list
)
{
tty_dev
=
list_entry
(
tmp
,
struct
tty_dev
,
node
);
tty_dev
=
list_entry
(
tmp
,
struct
tty_dev
,
node
);
if
((
MAJOR
(
tty_dev
->
dev
)
==
MAJOR
(
dev
))
&&
if
((
MAJOR
(
tty_dev
->
dev
)
==
MAJOR
(
dev
))
&&
...
@@ -2166,8 +2170,11 @@ void tty_remove_class_device(dev_t dev)
...
@@ -2166,8 +2170,11 @@ void tty_remove_class_device(dev_t dev)
}
}
if
(
found
)
{
if
(
found
)
{
list_del
(
&
tty_dev
->
node
);
list_del
(
&
tty_dev
->
node
);
spin_unlock
(
&
tty_dev_list_lock
);
class_device_unregister
(
&
tty_dev
->
class_dev
);
class_device_unregister
(
&
tty_dev
->
class_dev
);
kfree
(
tty_dev
);
kfree
(
tty_dev
);
}
else
{
spin_unlock
(
&
tty_dev_list_lock
);
}
}
}
}
...
...
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