dio: use probe_kernel_read()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
f9f5796e7a
commit
c02205e9f3
@ -116,7 +116,6 @@ int __init dio_find(int deviceid)
|
|||||||
*/
|
*/
|
||||||
int scode, id;
|
int scode, id;
|
||||||
u_char prid, secid, i;
|
u_char prid, secid, i;
|
||||||
mm_segment_t fs;
|
|
||||||
|
|
||||||
for (scode = 0; scode < DIO_SCMAX; scode++) {
|
for (scode = 0; scode < DIO_SCMAX; scode++) {
|
||||||
void *va;
|
void *va;
|
||||||
@ -135,17 +134,12 @@ int __init dio_find(int deviceid)
|
|||||||
else
|
else
|
||||||
va = ioremap(pa, PAGE_SIZE);
|
va = ioremap(pa, PAGE_SIZE);
|
||||||
|
|
||||||
fs = get_fs();
|
if (probe_kernel_read(&i, (unsigned char *)va + DIO_IDOFF, 1)) {
|
||||||
set_fs(KERNEL_DS);
|
|
||||||
|
|
||||||
if (get_user(i, (unsigned char *)va + DIO_IDOFF)) {
|
|
||||||
set_fs(fs);
|
|
||||||
if (scode >= DIOII_SCBASE)
|
if (scode >= DIOII_SCBASE)
|
||||||
iounmap(va);
|
iounmap(va);
|
||||||
continue; /* no board present at that select code */
|
continue; /* no board present at that select code */
|
||||||
}
|
}
|
||||||
|
|
||||||
set_fs(fs);
|
|
||||||
prid = DIO_ID(va);
|
prid = DIO_ID(va);
|
||||||
|
|
||||||
if (DIO_NEEDSSECID(prid)) {
|
if (DIO_NEEDSSECID(prid)) {
|
||||||
@ -170,7 +164,6 @@ int __init dio_find(int deviceid)
|
|||||||
static int __init dio_init(void)
|
static int __init dio_init(void)
|
||||||
{
|
{
|
||||||
int scode;
|
int scode;
|
||||||
mm_segment_t fs;
|
|
||||||
int i;
|
int i;
|
||||||
struct dio_dev *dev;
|
struct dio_dev *dev;
|
||||||
int error;
|
int error;
|
||||||
@ -214,18 +207,12 @@ static int __init dio_init(void)
|
|||||||
else
|
else
|
||||||
va = ioremap(pa, PAGE_SIZE);
|
va = ioremap(pa, PAGE_SIZE);
|
||||||
|
|
||||||
fs = get_fs();
|
if (probe_kernel_read(&i, (unsigned char *)va + DIO_IDOFF, 1)) {
|
||||||
set_fs(KERNEL_DS);
|
|
||||||
|
|
||||||
if (get_user(i, (unsigned char *)va + DIO_IDOFF)) {
|
|
||||||
set_fs(fs);
|
|
||||||
if (scode >= DIOII_SCBASE)
|
if (scode >= DIOII_SCBASE)
|
||||||
iounmap(va);
|
iounmap(va);
|
||||||
continue; /* no board present at that select code */
|
continue; /* no board present at that select code */
|
||||||
}
|
}
|
||||||
|
|
||||||
set_fs(fs);
|
|
||||||
|
|
||||||
/* Found a board, allocate it an entry in the list */
|
/* Found a board, allocate it an entry in the list */
|
||||||
dev = kzalloc(sizeof(struct dio_dev), GFP_KERNEL);
|
dev = kzalloc(sizeof(struct dio_dev), GFP_KERNEL);
|
||||||
if (!dev)
|
if (!dev)
|
||||||
|
Loading…
Reference in New Issue
Block a user