Commit aa47cc1c authored by Al Viro's avatar Al Viro

irda: don't open-code memdup_user()

and no, GFP_ATOMIC does not make any sense there...
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 7f2d17c6
...@@ -1901,16 +1901,10 @@ static int irda_setsockopt(struct socket *sock, int level, int optname, ...@@ -1901,16 +1901,10 @@ static int irda_setsockopt(struct socket *sock, int level, int optname,
goto out; goto out;
} }
ias_opt = kmalloc(sizeof(struct irda_ias_set), GFP_ATOMIC);
if (ias_opt == NULL) {
err = -ENOMEM;
goto out;
}
/* Copy query to the driver. */ /* Copy query to the driver. */
if (copy_from_user(ias_opt, optval, optlen)) { ias_opt = memdup_user(optval, optlen);
kfree(ias_opt); if (IS_ERR(ias_opt)) {
err = -EFAULT; err = PTR_ERR(ias_opt);
goto out; goto out;
} }
...@@ -2032,16 +2026,10 @@ static int irda_setsockopt(struct socket *sock, int level, int optname, ...@@ -2032,16 +2026,10 @@ static int irda_setsockopt(struct socket *sock, int level, int optname,
goto out; goto out;
} }
ias_opt = kmalloc(sizeof(struct irda_ias_set), GFP_ATOMIC);
if (ias_opt == NULL) {
err = -ENOMEM;
goto out;
}
/* Copy query to the driver. */ /* Copy query to the driver. */
if (copy_from_user(ias_opt, optval, optlen)) { ias_opt = memdup_user(optval, optlen);
kfree(ias_opt); if (IS_ERR(ias_opt)) {
err = -EFAULT; err = PTR_ERR(ias_opt);
goto out; goto out;
} }
...@@ -2317,16 +2305,10 @@ static int irda_getsockopt(struct socket *sock, int level, int optname, ...@@ -2317,16 +2305,10 @@ static int irda_getsockopt(struct socket *sock, int level, int optname,
goto out; goto out;
} }
ias_opt = kmalloc(sizeof(struct irda_ias_set), GFP_ATOMIC);
if (ias_opt == NULL) {
err = -ENOMEM;
goto out;
}
/* Copy query to the driver. */ /* Copy query to the driver. */
if (copy_from_user(ias_opt, optval, len)) { ias_opt = memdup_user(optval, len);
kfree(ias_opt); if (IS_ERR(ias_opt)) {
err = -EFAULT; err = PTR_ERR(ias_opt);
goto out; goto out;
} }
...@@ -2381,16 +2363,10 @@ static int irda_getsockopt(struct socket *sock, int level, int optname, ...@@ -2381,16 +2363,10 @@ static int irda_getsockopt(struct socket *sock, int level, int optname,
goto out; goto out;
} }
ias_opt = kmalloc(sizeof(struct irda_ias_set), GFP_ATOMIC);
if (ias_opt == NULL) {
err = -ENOMEM;
goto out;
}
/* Copy query to the driver. */ /* Copy query to the driver. */
if (copy_from_user(ias_opt, optval, len)) { ias_opt = memdup_user(optval, len);
kfree(ias_opt); if (IS_ERR(ias_opt)) {
err = -EFAULT; err = PTR_ERR(ias_opt);
goto out; goto out;
} }
......
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