diff options
author | Dan Carpenter <dan.carpenter@oracle.com> | 2012-05-15 04:47:47 -0400 |
---|---|---|
committer | Konrad Rzeszutek Wilk <konrad.wilk@oracle.com> | 2012-05-21 11:03:29 -0400 |
commit | 201a52bea928687b7557728b176ac4f8a37d5cbd (patch) | |
tree | ff5f609f12d6cc69e5ffec1ca971bbcb36694776 | |
parent | d79d5959a023fd637e90ed1ff6547ff09d19396b (diff) |
hvc_xen: NULL dereference on allocation failure
If kzalloc() returns a NULL here, we pass a NULL to
xencons_disconnect_backend() which will cause an Oops.
Also I removed the __GFP_ZERO while I was at it since kzalloc() implies
__GFP_ZERO.
CC: stable@kernel.org
Acked-by: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
-rw-r--r-- | drivers/tty/hvc/hvc_xen.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/tty/hvc/hvc_xen.c b/drivers/tty/hvc/hvc_xen.c index 83d5c88e7165..d3d91dae065c 100644 --- a/drivers/tty/hvc/hvc_xen.c +++ b/drivers/tty/hvc/hvc_xen.c | |||
@@ -430,9 +430,9 @@ static int __devinit xencons_probe(struct xenbus_device *dev, | |||
430 | if (devid == 0) | 430 | if (devid == 0) |
431 | return -ENODEV; | 431 | return -ENODEV; |
432 | 432 | ||
433 | info = kzalloc(sizeof(struct xencons_info), GFP_KERNEL | __GFP_ZERO); | 433 | info = kzalloc(sizeof(struct xencons_info), GFP_KERNEL); |
434 | if (!info) | 434 | if (!info) |
435 | goto error_nomem; | 435 | return -ENOMEM; |
436 | dev_set_drvdata(&dev->dev, info); | 436 | dev_set_drvdata(&dev->dev, info); |
437 | info->xbdev = dev; | 437 | info->xbdev = dev; |
438 | info->vtermno = xenbus_devid_to_vtermno(devid); | 438 | info->vtermno = xenbus_devid_to_vtermno(devid); |