Commit 88abaab4 authored by Eric Sesterhenn's avatar Eric Sesterhenn Committed by Linus Torvalds

[PATCH] s390: kzalloc() conversion in drivers/s390

Convert all kmalloc + memset sequences in drivers/s390 to kzalloc usage.
Signed-off-by: default avatarEric Sesterhenn <snakebyte@gmx.de>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent fb630517
...@@ -71,10 +71,9 @@ dasd_alloc_device(void) ...@@ -71,10 +71,9 @@ dasd_alloc_device(void)
{ {
struct dasd_device *device; struct dasd_device *device;
device = kmalloc(sizeof (struct dasd_device), GFP_ATOMIC); device = kzalloc(sizeof (struct dasd_device), GFP_ATOMIC);
if (device == NULL) if (device == NULL)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(device, 0, sizeof (struct dasd_device));
/* open_count = 0 means device online but not in use */ /* open_count = 0 means device online but not in use */
atomic_set(&device->open_count, -1); atomic_set(&device->open_count, -1);
...@@ -547,29 +546,26 @@ dasd_kmalloc_request(char *magic, int cplength, int datasize, ...@@ -547,29 +546,26 @@ dasd_kmalloc_request(char *magic, int cplength, int datasize,
(cplength*sizeof(struct ccw1)) > PAGE_SIZE) (cplength*sizeof(struct ccw1)) > PAGE_SIZE)
BUG(); BUG();
cqr = kmalloc(sizeof(struct dasd_ccw_req), GFP_ATOMIC); cqr = kzalloc(sizeof(struct dasd_ccw_req), GFP_ATOMIC);
if (cqr == NULL) if (cqr == NULL)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(cqr, 0, sizeof(struct dasd_ccw_req));
cqr->cpaddr = NULL; cqr->cpaddr = NULL;
if (cplength > 0) { if (cplength > 0) {
cqr->cpaddr = kmalloc(cplength*sizeof(struct ccw1), cqr->cpaddr = kcalloc(cplength, sizeof(struct ccw1),
GFP_ATOMIC | GFP_DMA); GFP_ATOMIC | GFP_DMA);
if (cqr->cpaddr == NULL) { if (cqr->cpaddr == NULL) {
kfree(cqr); kfree(cqr);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(cqr->cpaddr, 0, cplength*sizeof(struct ccw1));
} }
cqr->data = NULL; cqr->data = NULL;
if (datasize > 0) { if (datasize > 0) {
cqr->data = kmalloc(datasize, GFP_ATOMIC | GFP_DMA); cqr->data = kzalloc(datasize, GFP_ATOMIC | GFP_DMA);
if (cqr->data == NULL) { if (cqr->data == NULL) {
kfree(cqr->cpaddr); kfree(cqr->cpaddr);
kfree(cqr); kfree(cqr);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(cqr->data, 0, datasize);
} }
strncpy((char *) &cqr->magic, magic, 4); strncpy((char *) &cqr->magic, magic, 4);
ASCEBC((char *) &cqr->magic, 4); ASCEBC((char *) &cqr->magic, 4);
......
...@@ -388,12 +388,11 @@ dcssblk_add_store(struct device *dev, struct device_attribute *attr, const char ...@@ -388,12 +388,11 @@ dcssblk_add_store(struct device *dev, struct device_attribute *attr, const char
/* /*
* get a struct dcssblk_dev_info * get a struct dcssblk_dev_info
*/ */
dev_info = kmalloc(sizeof(struct dcssblk_dev_info), GFP_KERNEL); dev_info = kzalloc(sizeof(struct dcssblk_dev_info), GFP_KERNEL);
if (dev_info == NULL) { if (dev_info == NULL) {
rc = -ENOMEM; rc = -ENOMEM;
goto out; goto out;
} }
memset(dev_info, 0, sizeof(struct dcssblk_dev_info));
strcpy(dev_info->segment_name, local_buf); strcpy(dev_info->segment_name, local_buf);
strlcpy(dev_info->dev.bus_id, local_buf, BUS_ID_SIZE); strlcpy(dev_info->dev.bus_id, local_buf, BUS_ID_SIZE);
......
...@@ -368,10 +368,9 @@ fs3270_alloc_view(void) ...@@ -368,10 +368,9 @@ fs3270_alloc_view(void)
{ {
struct fs3270 *fp; struct fs3270 *fp;
fp = (struct fs3270 *) kmalloc(sizeof(struct fs3270),GFP_KERNEL); fp = kzalloc(sizeof(struct fs3270),GFP_KERNEL);
if (!fp) if (!fp)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(fp, 0, sizeof(struct fs3270));
fp->init = raw3270_request_alloc(0); fp->init = raw3270_request_alloc(0);
if (IS_ERR(fp->init)) { if (IS_ERR(fp->init)) {
kfree(fp); kfree(fp);
......
...@@ -50,14 +50,12 @@ kbd_alloc(void) { ...@@ -50,14 +50,12 @@ kbd_alloc(void) {
struct kbd_data *kbd; struct kbd_data *kbd;
int i, len; int i, len;
kbd = kmalloc(sizeof(struct kbd_data), GFP_KERNEL); kbd = kzalloc(sizeof(struct kbd_data), GFP_KERNEL);
if (!kbd) if (!kbd)
goto out; goto out;
memset(kbd, 0, sizeof(struct kbd_data)); kbd->key_maps = kzalloc(sizeof(key_maps), GFP_KERNEL);
kbd->key_maps = kmalloc(sizeof(key_maps), GFP_KERNEL);
if (!key_maps) if (!key_maps)
goto out_kbd; goto out_kbd;
memset(kbd->key_maps, 0, sizeof(key_maps));
for (i = 0; i < ARRAY_SIZE(key_maps); i++) { for (i = 0; i < ARRAY_SIZE(key_maps); i++) {
if (key_maps[i]) { if (key_maps[i]) {
kbd->key_maps[i] = kbd->key_maps[i] =
...@@ -68,10 +66,9 @@ kbd_alloc(void) { ...@@ -68,10 +66,9 @@ kbd_alloc(void) {
sizeof(u_short)*NR_KEYS); sizeof(u_short)*NR_KEYS);
} }
} }
kbd->func_table = kmalloc(sizeof(func_table), GFP_KERNEL); kbd->func_table = kzalloc(sizeof(func_table), GFP_KERNEL);
if (!kbd->func_table) if (!kbd->func_table)
goto out_maps; goto out_maps;
memset(kbd->func_table, 0, sizeof(func_table));
for (i = 0; i < ARRAY_SIZE(func_table); i++) { for (i = 0; i < ARRAY_SIZE(func_table); i++) {
if (func_table[i]) { if (func_table[i]) {
len = strlen(func_table[i]) + 1; len = strlen(func_table[i]) + 1;
...@@ -82,10 +79,9 @@ kbd_alloc(void) { ...@@ -82,10 +79,9 @@ kbd_alloc(void) {
} }
} }
kbd->fn_handler = kbd->fn_handler =
kmalloc(sizeof(fn_handler_fn *) * NR_FN_HANDLER, GFP_KERNEL); kzalloc(sizeof(fn_handler_fn *) * NR_FN_HANDLER, GFP_KERNEL);
if (!kbd->fn_handler) if (!kbd->fn_handler)
goto out_func; goto out_func;
memset(kbd->fn_handler, 0, sizeof(fn_handler_fn *) * NR_FN_HANDLER);
kbd->accent_table = kbd->accent_table =
kmalloc(sizeof(struct kbdiacr)*MAX_DIACR, GFP_KERNEL); kmalloc(sizeof(struct kbdiacr)*MAX_DIACR, GFP_KERNEL);
if (!kbd->accent_table) if (!kbd->accent_table)
......
...@@ -257,14 +257,13 @@ mon_alloc_mem(void) ...@@ -257,14 +257,13 @@ mon_alloc_mem(void)
int i,j; int i,j;
struct mon_private *monpriv; struct mon_private *monpriv;
monpriv = kmalloc(sizeof(struct mon_private), GFP_KERNEL); monpriv = kzalloc(sizeof(struct mon_private), GFP_KERNEL);
if (!monpriv) { if (!monpriv) {
P_ERROR("no memory for monpriv\n"); P_ERROR("no memory for monpriv\n");
return NULL; return NULL;
} }
memset(monpriv, 0, sizeof(struct mon_private));
for (i = 0; i < MON_MSGLIM; i++) { for (i = 0; i < MON_MSGLIM; i++) {
monpriv->msg_array[i] = kmalloc(sizeof(struct mon_msg), monpriv->msg_array[i] = kzalloc(sizeof(struct mon_msg),
GFP_KERNEL); GFP_KERNEL);
if (!monpriv->msg_array[i]) { if (!monpriv->msg_array[i]) {
P_ERROR("open, no memory for msg_array\n"); P_ERROR("open, no memory for msg_array\n");
...@@ -272,7 +271,6 @@ mon_alloc_mem(void) ...@@ -272,7 +271,6 @@ mon_alloc_mem(void)
kfree(monpriv->msg_array[j]); kfree(monpriv->msg_array[j]);
return NULL; return NULL;
} }
memset(monpriv->msg_array[i], 0, sizeof(struct mon_msg));
} }
return monpriv; return monpriv;
} }
......
...@@ -115,10 +115,9 @@ raw3270_request_alloc(size_t size) ...@@ -115,10 +115,9 @@ raw3270_request_alloc(size_t size)
struct raw3270_request *rq; struct raw3270_request *rq;
/* Allocate request structure */ /* Allocate request structure */
rq = kmalloc(sizeof(struct raw3270_request), GFP_KERNEL | GFP_DMA); rq = kzalloc(sizeof(struct raw3270_request), GFP_KERNEL | GFP_DMA);
if (!rq) if (!rq)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(rq, 0, sizeof(struct raw3270_request));
/* alloc output buffer. */ /* alloc output buffer. */
if (size > 0) { if (size > 0) {
......
...@@ -44,11 +44,10 @@ struct tape_class_device *register_tape_dev( ...@@ -44,11 +44,10 @@ struct tape_class_device *register_tape_dev(
int rc; int rc;
char * s; char * s;
tcd = kmalloc(sizeof(struct tape_class_device), GFP_KERNEL); tcd = kzalloc(sizeof(struct tape_class_device), GFP_KERNEL);
if (!tcd) if (!tcd)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(tcd, 0, sizeof(struct tape_class_device));
strncpy(tcd->device_name, device_name, TAPECLASS_NAME_LEN); strncpy(tcd->device_name, device_name, TAPECLASS_NAME_LEN);
for (s = strchr(tcd->device_name, '/'); s; s = strchr(s, '/')) for (s = strchr(tcd->device_name, '/'); s; s = strchr(s, '/'))
*s = '!'; *s = '!';
......
...@@ -453,16 +453,14 @@ tape_alloc_device(void) ...@@ -453,16 +453,14 @@ tape_alloc_device(void)
{ {
struct tape_device *device; struct tape_device *device;
device = (struct tape_device *) device = kzalloc(sizeof(struct tape_device), GFP_KERNEL);
kmalloc(sizeof(struct tape_device), GFP_KERNEL);
if (device == NULL) { if (device == NULL) {
DBF_EXCEPTION(2, "ti:no mem\n"); DBF_EXCEPTION(2, "ti:no mem\n");
PRINT_INFO ("can't allocate memory for " PRINT_INFO ("can't allocate memory for "
"tape info structure\n"); "tape info structure\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(device, 0, sizeof(struct tape_device)); device->modeset_byte = kmalloc(1, GFP_KERNEL | GFP_DMA);
device->modeset_byte = (char *) kmalloc(1, GFP_KERNEL | GFP_DMA);
if (device->modeset_byte == NULL) { if (device->modeset_byte == NULL) {
DBF_EXCEPTION(2, "ti:no mem\n"); DBF_EXCEPTION(2, "ti:no mem\n");
PRINT_INFO("can't allocate memory for modeset byte\n"); PRINT_INFO("can't allocate memory for modeset byte\n");
...@@ -659,34 +657,30 @@ tape_alloc_request(int cplength, int datasize) ...@@ -659,34 +657,30 @@ tape_alloc_request(int cplength, int datasize)
DBF_LH(6, "tape_alloc_request(%d, %d)\n", cplength, datasize); DBF_LH(6, "tape_alloc_request(%d, %d)\n", cplength, datasize);
request = (struct tape_request *) kmalloc(sizeof(struct tape_request), request = kzalloc(sizeof(struct tape_request), GFP_KERNEL);
GFP_KERNEL);
if (request == NULL) { if (request == NULL) {
DBF_EXCEPTION(1, "cqra nomem\n"); DBF_EXCEPTION(1, "cqra nomem\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(request, 0, sizeof(struct tape_request));
/* allocate channel program */ /* allocate channel program */
if (cplength > 0) { if (cplength > 0) {
request->cpaddr = kmalloc(cplength*sizeof(struct ccw1), request->cpaddr = kcalloc(cplength, sizeof(struct ccw1),
GFP_ATOMIC | GFP_DMA); GFP_ATOMIC | GFP_DMA);
if (request->cpaddr == NULL) { if (request->cpaddr == NULL) {
DBF_EXCEPTION(1, "cqra nomem\n"); DBF_EXCEPTION(1, "cqra nomem\n");
kfree(request); kfree(request);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(request->cpaddr, 0, cplength*sizeof(struct ccw1));
} }
/* alloc small kernel buffer */ /* alloc small kernel buffer */
if (datasize > 0) { if (datasize > 0) {
request->cpdata = kmalloc(datasize, GFP_KERNEL | GFP_DMA); request->cpdata = kzalloc(datasize, GFP_KERNEL | GFP_DMA);
if (request->cpdata == NULL) { if (request->cpdata == NULL) {
DBF_EXCEPTION(1, "cqra nomem\n"); DBF_EXCEPTION(1, "cqra nomem\n");
kfree(request->cpaddr); kfree(request->cpaddr);
kfree(request); kfree(request);
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
memset(request->cpdata, 0, datasize);
} }
DBF_LH(6, "New request %p(%p/%p)\n", request, request->cpaddr, DBF_LH(6, "New request %p(%p/%p)\n", request, request->cpaddr,
request->cpdata); request->cpdata);
......
...@@ -691,10 +691,9 @@ tty3270_alloc_view(void) ...@@ -691,10 +691,9 @@ tty3270_alloc_view(void)
struct tty3270 *tp; struct tty3270 *tp;
int pages; int pages;
tp = kmalloc(sizeof(struct tty3270),GFP_KERNEL); tp = kzalloc(sizeof(struct tty3270), GFP_KERNEL);
if (!tp) if (!tp)
goto out_err; goto out_err;
memset(tp, 0, sizeof(struct tty3270));
tp->freemem_pages = tp->freemem_pages =
kmalloc(sizeof(void *) * TTY3270_STRING_PAGES, GFP_KERNEL); kmalloc(sizeof(void *) * TTY3270_STRING_PAGES, GFP_KERNEL);
if (!tp->freemem_pages) if (!tp->freemem_pages)
...@@ -767,16 +766,14 @@ tty3270_alloc_screen(struct tty3270 *tp) ...@@ -767,16 +766,14 @@ tty3270_alloc_screen(struct tty3270 *tp)
int lines; int lines;
size = sizeof(struct tty3270_line) * (tp->view.rows - 2); size = sizeof(struct tty3270_line) * (tp->view.rows - 2);
tp->screen = kmalloc(size, GFP_KERNEL); tp->screen = kzalloc(size, GFP_KERNEL);
if (!tp->screen) if (!tp->screen)
goto out_err; goto out_err;
memset(tp->screen, 0, size);
for (lines = 0; lines < tp->view.rows - 2; lines++) { for (lines = 0; lines < tp->view.rows - 2; lines++) {
size = sizeof(struct tty3270_cell) * tp->view.cols; size = sizeof(struct tty3270_cell) * tp->view.cols;
tp->screen[lines].cells = kmalloc(size, GFP_KERNEL); tp->screen[lines].cells = kzalloc(size, GFP_KERNEL);
if (!tp->screen[lines].cells) if (!tp->screen[lines].cells)
goto out_screen; goto out_screen;
memset(tp->screen[lines].cells, 0, size);
} }
return 0; return 0;
out_screen: out_screen:
......
...@@ -759,9 +759,8 @@ vmlogrdr_register_device(struct vmlogrdr_priv_t *priv) { ...@@ -759,9 +759,8 @@ vmlogrdr_register_device(struct vmlogrdr_priv_t *priv) {
struct device *dev; struct device *dev;
int ret; int ret;
dev = kmalloc(sizeof(struct device), GFP_KERNEL); dev = kzalloc(sizeof(struct device), GFP_KERNEL);
if (dev) { if (dev) {
memset(dev, 0, sizeof(struct device));
snprintf(dev->bus_id, BUS_ID_SIZE, "%s", snprintf(dev->bus_id, BUS_ID_SIZE, "%s",
priv->internal_name); priv->internal_name);
dev->bus = &iucv_bus; dev->bus = &iucv_bus;
......
...@@ -157,11 +157,10 @@ ccwgroup_create(struct device *root, ...@@ -157,11 +157,10 @@ ccwgroup_create(struct device *root,
if (argc > 256) /* disallow dumb users */ if (argc > 256) /* disallow dumb users */
return -EINVAL; return -EINVAL;
gdev = kmalloc(sizeof(*gdev) + argc*sizeof(gdev->cdev[0]), GFP_KERNEL); gdev = kzalloc(sizeof(*gdev) + argc*sizeof(gdev->cdev[0]), GFP_KERNEL);
if (!gdev) if (!gdev)
return -ENOMEM; return -ENOMEM;
memset(gdev, 0, sizeof(*gdev) + argc*sizeof(gdev->cdev[0]));
atomic_set(&gdev->onoff, 0); atomic_set(&gdev->onoff, 0);
del_drvdata = 0; del_drvdata = 0;
......
...@@ -1403,10 +1403,9 @@ new_channel_path(int chpid) ...@@ -1403,10 +1403,9 @@ new_channel_path(int chpid)
struct channel_path *chp; struct channel_path *chp;
int ret; int ret;
chp = kmalloc(sizeof(struct channel_path), GFP_KERNEL); chp = kzalloc(sizeof(struct channel_path), GFP_KERNEL);
if (!chp) if (!chp)
return -ENOMEM; return -ENOMEM;
memset(chp, 0, sizeof(struct channel_path));
/* fill in status, etc. */ /* fill in status, etc. */
chp->id = chpid; chp->id = chpid;
......
...@@ -630,10 +630,9 @@ css_enqueue_subchannel_slow(struct subchannel_id schid) ...@@ -630,10 +630,9 @@ css_enqueue_subchannel_slow(struct subchannel_id schid)
struct slow_subchannel *new_slow_sch; struct slow_subchannel *new_slow_sch;
unsigned long flags; unsigned long flags;
new_slow_sch = kmalloc(sizeof(struct slow_subchannel), GFP_ATOMIC); new_slow_sch = kzalloc(sizeof(struct slow_subchannel), GFP_ATOMIC);
if (!new_slow_sch) if (!new_slow_sch)
return -ENOMEM; return -ENOMEM;
memset(new_slow_sch, 0, sizeof(struct slow_subchannel));
new_slow_sch->schid = schid; new_slow_sch->schid = schid;
spin_lock_irqsave(&slow_subchannel_lock, flags); spin_lock_irqsave(&slow_subchannel_lock, flags);
list_add_tail(&new_slow_sch->slow_list, &slow_subchannels_head); list_add_tail(&new_slow_sch->slow_list, &slow_subchannels_head);
......
...@@ -826,17 +826,15 @@ io_subchannel_probe (struct subchannel *sch) ...@@ -826,17 +826,15 @@ io_subchannel_probe (struct subchannel *sch)
get_device(&cdev->dev); get_device(&cdev->dev);
return 0; return 0;
} }
cdev = kmalloc (sizeof(*cdev), GFP_KERNEL); cdev = kzalloc (sizeof(*cdev), GFP_KERNEL);
if (!cdev) if (!cdev)
return -ENOMEM; return -ENOMEM;
memset(cdev, 0, sizeof(struct ccw_device)); cdev->private = kzalloc(sizeof(struct ccw_device_private),
cdev->private = kmalloc(sizeof(struct ccw_device_private),
GFP_KERNEL | GFP_DMA); GFP_KERNEL | GFP_DMA);
if (!cdev->private) { if (!cdev->private) {
kfree(cdev); kfree(cdev);
return -ENOMEM; return -ENOMEM;
} }
memset(cdev->private, 0, sizeof(struct ccw_device_private));
atomic_set(&cdev->private->onoff, 0); atomic_set(&cdev->private->onoff, 0);
cdev->dev = (struct device) { cdev->dev = (struct device) {
.parent = &sch->dev, .parent = &sch->dev,
......
...@@ -359,10 +359,9 @@ read_dev_chars (struct ccw_device *cdev, void **buffer, int length) ...@@ -359,10 +359,9 @@ read_dev_chars (struct ccw_device *cdev, void **buffer, int length)
CIO_TRACE_EVENT (4, "rddevch"); CIO_TRACE_EVENT (4, "rddevch");
CIO_TRACE_EVENT (4, sch->dev.bus_id); CIO_TRACE_EVENT (4, sch->dev.bus_id);
rdc_ccw = kmalloc(sizeof(struct ccw1), GFP_KERNEL | GFP_DMA); rdc_ccw = kzalloc(sizeof(struct ccw1), GFP_KERNEL | GFP_DMA);
if (!rdc_ccw) if (!rdc_ccw)
return -ENOMEM; return -ENOMEM;
memset(rdc_ccw, 0, sizeof(struct ccw1));
rdc_ccw->cmd_code = CCW_CMD_RDC; rdc_ccw->cmd_code = CCW_CMD_RDC;
rdc_ccw->count = length; rdc_ccw->count = length;
rdc_ccw->flags = CCW_FLAG_SLI; rdc_ccw->flags = CCW_FLAG_SLI;
...@@ -426,16 +425,14 @@ read_conf_data_lpm (struct ccw_device *cdev, void **buffer, int *length, __u8 lp ...@@ -426,16 +425,14 @@ read_conf_data_lpm (struct ccw_device *cdev, void **buffer, int *length, __u8 lp
if (!ciw || ciw->cmd == 0) if (!ciw || ciw->cmd == 0)
return -EOPNOTSUPP; return -EOPNOTSUPP;
rcd_ccw = kmalloc(sizeof(struct ccw1), GFP_KERNEL | GFP_DMA); rcd_ccw = kzalloc(sizeof(struct ccw1), GFP_KERNEL | GFP_DMA);
if (!rcd_ccw) if (!rcd_ccw)
return -ENOMEM; return -ENOMEM;
memset(rcd_ccw, 0, sizeof(struct ccw1)); rcd_buf = kzalloc(ciw->count, GFP_KERNEL | GFP_DMA);
rcd_buf = kmalloc(ciw->count, GFP_KERNEL | GFP_DMA);
if (!rcd_buf) { if (!rcd_buf) {
kfree(rcd_ccw); kfree(rcd_ccw);
return -ENOMEM; return -ENOMEM;
} }
memset (rcd_buf, 0, ciw->count);
rcd_ccw->cmd_code = ciw->cmd; rcd_ccw->cmd_code = ciw->cmd;
rcd_ccw->cda = (__u32) __pa (rcd_buf); rcd_ccw->cda = (__u32) __pa (rcd_buf);
rcd_ccw->count = ciw->count; rcd_ccw->count = ciw->count;
......
...@@ -1686,16 +1686,14 @@ qdio_alloc_qs(struct qdio_irq *irq_ptr, ...@@ -1686,16 +1686,14 @@ qdio_alloc_qs(struct qdio_irq *irq_ptr,
int result=-ENOMEM; int result=-ENOMEM;
for (i=0;i<no_input_qs;i++) { for (i=0;i<no_input_qs;i++) {
q=kmalloc(sizeof(struct qdio_q),GFP_KERNEL); q = kzalloc(sizeof(struct qdio_q), GFP_KERNEL);
if (!q) { if (!q) {
QDIO_PRINT_ERR("kmalloc of q failed!\n"); QDIO_PRINT_ERR("kmalloc of q failed!\n");
goto out; goto out;
} }
memset(q,0,sizeof(struct qdio_q)); q->slib = kmalloc(PAGE_SIZE, GFP_KERNEL);
q->slib=kmalloc(PAGE_SIZE,GFP_KERNEL);
if (!q->slib) { if (!q->slib) {
QDIO_PRINT_ERR("kmalloc of slib failed!\n"); QDIO_PRINT_ERR("kmalloc of slib failed!\n");
goto out; goto out;
...@@ -1705,14 +1703,12 @@ qdio_alloc_qs(struct qdio_irq *irq_ptr, ...@@ -1705,14 +1703,12 @@ qdio_alloc_qs(struct qdio_irq *irq_ptr,
} }
for (i=0;i<no_output_qs;i++) { for (i=0;i<no_output_qs;i++) {
q=kmalloc(sizeof(struct qdio_q),GFP_KERNEL); q = kzalloc(sizeof(struct qdio_q), GFP_KERNEL);
if (!q) { if (!q) {
goto out; goto out;
} }
memset(q,0,sizeof(struct qdio_q));
q->slib=kmalloc(PAGE_SIZE,GFP_KERNEL); q->slib=kmalloc(PAGE_SIZE,GFP_KERNEL);
if (!q->slib) { if (!q->slib) {
QDIO_PRINT_ERR("kmalloc of slib failed!\n"); QDIO_PRINT_ERR("kmalloc of slib failed!\n");
...@@ -2984,7 +2980,7 @@ qdio_allocate(struct qdio_initialize *init_data) ...@@ -2984,7 +2980,7 @@ qdio_allocate(struct qdio_initialize *init_data)
qdio_allocate_do_dbf(init_data); qdio_allocate_do_dbf(init_data);
/* create irq */ /* create irq */
irq_ptr=kmalloc(sizeof(struct qdio_irq), GFP_KERNEL | GFP_DMA); irq_ptr = kzalloc(sizeof(struct qdio_irq), GFP_KERNEL | GFP_DMA);
QDIO_DBF_TEXT0(0,setup,"irq_ptr:"); QDIO_DBF_TEXT0(0,setup,"irq_ptr:");
QDIO_DBF_HEX0(0,setup,&irq_ptr,sizeof(void*)); QDIO_DBF_HEX0(0,setup,&irq_ptr,sizeof(void*));
...@@ -2994,8 +2990,6 @@ qdio_allocate(struct qdio_initialize *init_data) ...@@ -2994,8 +2990,6 @@ qdio_allocate(struct qdio_initialize *init_data)
return -ENOMEM; return -ENOMEM;
} }
memset(irq_ptr,0,sizeof(struct qdio_irq));
init_MUTEX(&irq_ptr->setting_up_sema); init_MUTEX(&irq_ptr->setting_up_sema);
/* QDR must be in DMA area since CCW data address is only 32 bit */ /* QDR must be in DMA area since CCW data address is only 32 bit */
...@@ -3686,10 +3680,10 @@ qdio_get_qdio_memory(void) ...@@ -3686,10 +3680,10 @@ qdio_get_qdio_memory(void)
for (i=1;i<INDICATORS_PER_CACHELINE;i++) for (i=1;i<INDICATORS_PER_CACHELINE;i++)
indicator_used[i]=0; indicator_used[i]=0;
indicators=(__u32*)kmalloc(sizeof(__u32)*(INDICATORS_PER_CACHELINE), indicators = kzalloc(sizeof(__u32)*(INDICATORS_PER_CACHELINE),
GFP_KERNEL); GFP_KERNEL);
if (!indicators) return -ENOMEM; if (!indicators)
memset(indicators,0,sizeof(__u32)*(INDICATORS_PER_CACHELINE)); return -ENOMEM;
return 0; return 0;
} }
......
...@@ -707,13 +707,12 @@ z90crypt_open(struct inode *inode, struct file *filp) ...@@ -707,13 +707,12 @@ z90crypt_open(struct inode *inode, struct file *filp)
if (quiesce_z90crypt) if (quiesce_z90crypt)
return -EQUIESCE; return -EQUIESCE;
private_data_p = kmalloc(sizeof(struct priv_data), GFP_KERNEL); private_data_p = kzalloc(sizeof(struct priv_data), GFP_KERNEL);
if (!private_data_p) { if (!private_data_p) {
PRINTK("Memory allocate failed\n"); PRINTK("Memory allocate failed\n");
return -ENOMEM; return -ENOMEM;
} }
memset((void *)private_data_p, 0, sizeof(struct priv_data));
private_data_p->status = STAT_OPEN; private_data_p->status = STAT_OPEN;
private_data_p->opener_pid = PID(); private_data_p->opener_pid = PID();
filp->private_data = private_data_p; filp->private_data = private_data_p;
...@@ -2737,13 +2736,11 @@ create_z90crypt(int *cdx_p) ...@@ -2737,13 +2736,11 @@ create_z90crypt(int *cdx_p)
z90crypt.max_count = Z90CRYPT_NUM_DEVS; z90crypt.max_count = Z90CRYPT_NUM_DEVS;
z90crypt.cdx = *cdx_p; z90crypt.cdx = *cdx_p;
hdware_blk_p = (struct hdware_block *) hdware_blk_p = kzalloc(sizeof(struct hdware_block), GFP_ATOMIC);
kmalloc(sizeof(struct hdware_block), GFP_ATOMIC);
if (!hdware_blk_p) { if (!hdware_blk_p) {
PDEBUG("kmalloc for hardware block failed\n"); PDEBUG("kmalloc for hardware block failed\n");
return ENOMEM; return ENOMEM;
} }
memset(hdware_blk_p, 0x00, sizeof(struct hdware_block));
z90crypt.hdware_info = hdware_blk_p; z90crypt.hdware_info = hdware_blk_p;
return 0; return 0;
...@@ -2978,12 +2975,11 @@ create_crypto_device(int index) ...@@ -2978,12 +2975,11 @@ create_crypto_device(int index)
total_size = sizeof(struct device) + total_size = sizeof(struct device) +
z90crypt.q_depth_array[index] * sizeof(int); z90crypt.q_depth_array[index] * sizeof(int);
dev_ptr = (struct device *) kmalloc(total_size, GFP_ATOMIC); dev_ptr = kzalloc(total_size, GFP_ATOMIC);
if (!dev_ptr) { if (!dev_ptr) {
PRINTK("kmalloc device %d failed\n", index); PRINTK("kmalloc device %d failed\n", index);
return ENOMEM; return ENOMEM;
} }
memset(dev_ptr, 0, total_size);
dev_ptr->dev_resp_p = kmalloc(MAX_RESPONSE_SIZE, GFP_ATOMIC); dev_ptr->dev_resp_p = kmalloc(MAX_RESPONSE_SIZE, GFP_ATOMIC);
if (!dev_ptr->dev_resp_p) { if (!dev_ptr->dev_resp_p) {
kfree(dev_ptr); kfree(dev_ptr);
......
...@@ -310,7 +310,7 @@ claw_probe(struct ccwgroup_device *cgdev) ...@@ -310,7 +310,7 @@ claw_probe(struct ccwgroup_device *cgdev)
printk(KERN_INFO "claw: variable cgdev =\n"); printk(KERN_INFO "claw: variable cgdev =\n");
dumpit((char *)cgdev, sizeof(struct ccwgroup_device)); dumpit((char *)cgdev, sizeof(struct ccwgroup_device));
#endif #endif
privptr = kmalloc(sizeof(struct claw_privbk), GFP_KERNEL); privptr = kzalloc(sizeof(struct claw_privbk), GFP_KERNEL);
if (privptr == NULL) { if (privptr == NULL) {
probe_error(cgdev); probe_error(cgdev);
put_device(&cgdev->dev); put_device(&cgdev->dev);
...@@ -319,7 +319,6 @@ claw_probe(struct ccwgroup_device *cgdev) ...@@ -319,7 +319,6 @@ claw_probe(struct ccwgroup_device *cgdev)
CLAW_DBF_TEXT_(2,setup,"probex%d",-ENOMEM); CLAW_DBF_TEXT_(2,setup,"probex%d",-ENOMEM);
return -ENOMEM; return -ENOMEM;
} }
memset(privptr,0x00,sizeof(struct claw_privbk));
privptr->p_mtc_envelope= kmalloc( MAX_ENVELOPE_SIZE, GFP_KERNEL); privptr->p_mtc_envelope= kmalloc( MAX_ENVELOPE_SIZE, GFP_KERNEL);
privptr->p_env = kmalloc(sizeof(struct claw_env), GFP_KERNEL); privptr->p_env = kmalloc(sizeof(struct claw_env), GFP_KERNEL);
if ((privptr->p_mtc_envelope==NULL) || (privptr->p_env==NULL)) { if ((privptr->p_mtc_envelope==NULL) || (privptr->p_env==NULL)) {
......
...@@ -21,38 +21,34 @@ init_fsm(char *name, const char **state_names, const char **event_names, int nr_ ...@@ -21,38 +21,34 @@ init_fsm(char *name, const char **state_names, const char **event_names, int nr_
fsm_function_t *m; fsm_function_t *m;
fsm *f; fsm *f;
this = (fsm_instance *)kmalloc(sizeof(fsm_instance), order); this = kzalloc(sizeof(fsm_instance), order);
if (this == NULL) { if (this == NULL) {
printk(KERN_WARNING printk(KERN_WARNING
"fsm(%s): init_fsm: Couldn't alloc instance\n", name); "fsm(%s): init_fsm: Couldn't alloc instance\n", name);
return NULL; return NULL;
} }
memset(this, 0, sizeof(fsm_instance));
strlcpy(this->name, name, sizeof(this->name)); strlcpy(this->name, name, sizeof(this->name));
f = (fsm *)kmalloc(sizeof(fsm), order); f = kzalloc(sizeof(fsm), order);
if (f == NULL) { if (f == NULL) {
printk(KERN_WARNING printk(KERN_WARNING
"fsm(%s): init_fsm: Couldn't alloc fsm\n", name); "fsm(%s): init_fsm: Couldn't alloc fsm\n", name);
kfree_fsm(this); kfree_fsm(this);
return NULL; return NULL;
} }
memset(f, 0, sizeof(fsm));
f->nr_events = nr_events; f->nr_events = nr_events;
f->nr_states = nr_states; f->nr_states = nr_states;
f->event_names = event_names; f->event_names = event_names;
f->state_names = state_names; f->state_names = state_names;
this->f = f; this->f = f;
m = (fsm_function_t *)kmalloc( m = kcalloc(nr_states*nr_events, sizeof(fsm_function_t), order);
sizeof(fsm_function_t) * nr_states * nr_events, order);
if (m == NULL) { if (m == NULL) {
printk(KERN_WARNING printk(KERN_WARNING
"fsm(%s): init_fsm: Couldn't alloc jumptable\n", name); "fsm(%s): init_fsm: Couldn't alloc jumptable\n", name);
kfree_fsm(this); kfree_fsm(this);
return NULL; return NULL;
} }
memset(m, 0, sizeof(fsm_function_t) * f->nr_states * f->nr_events);
f->jumpmatrix = m; f->jumpmatrix = m;
for (i = 0; i < tmpl_len; i++) { for (i = 0; i < tmpl_len; i++) {
......
...@@ -386,7 +386,7 @@ iucv_init(void) ...@@ -386,7 +386,7 @@ iucv_init(void)
} }
/* Note: GFP_DMA used used to get memory below 2G */ /* Note: GFP_DMA used used to get memory below 2G */
iucv_external_int_buffer = kmalloc(sizeof(iucv_GeneralInterrupt), iucv_external_int_buffer = kzalloc(sizeof(iucv_GeneralInterrupt),
GFP_KERNEL|GFP_DMA); GFP_KERNEL|GFP_DMA);
if (!iucv_external_int_buffer) { if (!iucv_external_int_buffer) {
printk(KERN_WARNING printk(KERN_WARNING
...@@ -396,10 +396,9 @@ iucv_init(void) ...@@ -396,10 +396,9 @@ iucv_init(void)
bus_unregister(&iucv_bus); bus_unregister(&iucv_bus);
return -ENOMEM; return -ENOMEM;
} }
memset(iucv_external_int_buffer, 0, sizeof(iucv_GeneralInterrupt));
/* Initialize parameter pool */ /* Initialize parameter pool */
iucv_param_pool = kmalloc(sizeof(iucv_param) * PARAM_POOL_SIZE, iucv_param_pool = kzalloc(sizeof(iucv_param) * PARAM_POOL_SIZE,
GFP_KERNEL|GFP_DMA); GFP_KERNEL|GFP_DMA);
if (!iucv_param_pool) { if (!iucv_param_pool) {
printk(KERN_WARNING "%s: Could not allocate param pool\n", printk(KERN_WARNING "%s: Could not allocate param pool\n",
...@@ -410,7 +409,6 @@ iucv_init(void) ...@@ -410,7 +409,6 @@ iucv_init(void)
bus_unregister(&iucv_bus); bus_unregister(&iucv_bus);
return -ENOMEM; return -ENOMEM;
} }
memset(iucv_param_pool, 0, sizeof(iucv_param) * PARAM_POOL_SIZE);
/* Initialize irq queue */ /* Initialize irq queue */
INIT_LIST_HEAD(&iucv_irq_queue); INIT_LIST_HEAD(&iucv_irq_queue);
...@@ -793,15 +791,14 @@ iucv_register_program (__u8 pgmname[16], ...@@ -793,15 +791,14 @@ iucv_register_program (__u8 pgmname[16],
} }
max_connections = iucv_query_maxconn(); max_connections = iucv_query_maxconn();
iucv_pathid_table = kmalloc(max_connections * sizeof(handler *), iucv_pathid_table = kcalloc(max_connections, sizeof(handler *),
GFP_ATOMIC); GFP_ATOMIC);
if (iucv_pathid_table == NULL) { if (iucv_pathid_table == NULL) {
printk(KERN_WARNING "%s: iucv_pathid_table storage " printk(KERN_WARNING "%s: iucv_pathid_table storage "
"allocation failed\n", __FUNCTION__); "allocation failed\n", __FUNCTION__);
kfree(new_handler); kfree(new_handler);
return NULL; return NULL;
} }
memset (iucv_pathid_table, 0, max_connections * sizeof(handler *));
} }
memset(new_handler, 0, sizeof (handler)); memset(new_handler, 0, sizeof (handler));
memcpy(new_handler->id.user_data, pgmname, memcpy(new_handler->id.user_data, pgmname,
......
...@@ -115,11 +115,10 @@ lcs_alloc_channel(struct lcs_channel *channel) ...@@ -115,11 +115,10 @@ lcs_alloc_channel(struct lcs_channel *channel)
LCS_DBF_TEXT(2, setup, "ichalloc"); LCS_DBF_TEXT(2, setup, "ichalloc");
for (cnt = 0; cnt < LCS_NUM_BUFFS; cnt++) { for (cnt = 0; cnt < LCS_NUM_BUFFS; cnt++) {
/* alloc memory fo iobuffer */ /* alloc memory fo iobuffer */
channel->iob[cnt].data = (void *) channel->iob[cnt].data =
kmalloc(LCS_IOBUFFERSIZE, GFP_DMA | GFP_KERNEL); kzalloc(LCS_IOBUFFERSIZE, GFP_DMA | GFP_KERNEL);
if (channel->iob[cnt].data == NULL) if (channel->iob[cnt].data == NULL)
break; break;
memset(channel->iob[cnt].data, 0, LCS_IOBUFFERSIZE);
channel->iob[cnt].state = BUF_STATE_EMPTY; channel->iob[cnt].state = BUF_STATE_EMPTY;
} }
if (cnt < LCS_NUM_BUFFS) { if (cnt < LCS_NUM_BUFFS) {
...@@ -182,10 +181,9 @@ lcs_alloc_card(void) ...@@ -182,10 +181,9 @@ lcs_alloc_card(void)
LCS_DBF_TEXT(2, setup, "alloclcs"); LCS_DBF_TEXT(2, setup, "alloclcs");
card = kmalloc(sizeof(struct lcs_card), GFP_KERNEL | GFP_DMA); card = kzalloc(sizeof(struct lcs_card), GFP_KERNEL | GFP_DMA);
if (card == NULL) if (card == NULL)
return NULL; return NULL;
memset(card, 0, sizeof(struct lcs_card));
card->lan_type = LCS_FRAME_TYPE_AUTO; card->lan_type = LCS_FRAME_TYPE_AUTO;
card->pkt_seq = 0; card->pkt_seq = 0;
card->lancmd_timeout = LCS_LANCMD_TIMEOUT_DEFAULT; card->lancmd_timeout = LCS_LANCMD_TIMEOUT_DEFAULT;
...@@ -793,10 +791,9 @@ lcs_alloc_reply(struct lcs_cmd *cmd) ...@@ -793,10 +791,9 @@ lcs_alloc_reply(struct lcs_cmd *cmd)
LCS_DBF_TEXT(4, trace, "getreply"); LCS_DBF_TEXT(4, trace, "getreply");
reply = kmalloc(sizeof(struct lcs_reply), GFP_ATOMIC); reply = kzalloc(sizeof(struct lcs_reply), GFP_ATOMIC);
if (!reply) if (!reply)
return NULL; return NULL;
memset(reply,0,sizeof(struct lcs_reply));
atomic_set(&reply->refcnt,1); atomic_set(&reply->refcnt,1);
reply->sequence_no = cmd->sequence_no; reply->sequence_no = cmd->sequence_no;
reply->received = 0; reply->received = 0;
......
...@@ -1728,14 +1728,13 @@ static int ...@@ -1728,14 +1728,13 @@ static int
netiucv_register_device(struct net_device *ndev) netiucv_register_device(struct net_device *ndev)
{ {
struct netiucv_priv *priv = ndev->priv; struct netiucv_priv *priv = ndev->priv;
struct device *dev = kmalloc(sizeof(struct device), GFP_KERNEL); struct device *dev = kzalloc(sizeof(struct device), GFP_KERNEL);
int ret; int ret;
IUCV_DBF_TEXT(trace, 3, __FUNCTION__); IUCV_DBF_TEXT(trace, 3, __FUNCTION__);
if (dev) { if (dev) {
memset(dev, 0, sizeof(struct device));
snprintf(dev->bus_id, BUS_ID_SIZE, "net%s", ndev->name); snprintf(dev->bus_id, BUS_ID_SIZE, "net%s", ndev->name);
dev->bus = &iucv_bus; dev->bus = &iucv_bus;
dev->parent = iucv_root; dev->parent = iucv_root;
...@@ -1784,11 +1783,9 @@ netiucv_new_connection(struct net_device *dev, char *username) ...@@ -1784,11 +1783,9 @@ netiucv_new_connection(struct net_device *dev, char *username)
{ {
struct iucv_connection **clist = &iucv_connections; struct iucv_connection **clist = &iucv_connections;
struct iucv_connection *conn = struct iucv_connection *conn =
(struct iucv_connection *) kzalloc(sizeof(struct iucv_connection), GFP_KERNEL);
kmalloc(sizeof(struct iucv_connection), GFP_KERNEL);
if (conn) { if (conn) {
memset(conn, 0, sizeof(struct iucv_connection));
skb_queue_head_init(&conn->collect_queue); skb_queue_head_init(&conn->collect_queue);
skb_queue_head_init(&conn->commit_queue); skb_queue_head_init(&conn->commit_queue);
conn->max_buffsize = NETIUCV_BUFSIZE_DEFAULT; conn->max_buffsize = NETIUCV_BUFSIZE_DEFAULT;
......
...@@ -389,9 +389,8 @@ qeth_eddp_create_eddp_data(struct qeth_hdr *qh, u8 *nh, u8 nhl, u8 *th, u8 thl) ...@@ -389,9 +389,8 @@ qeth_eddp_create_eddp_data(struct qeth_hdr *qh, u8 *nh, u8 nhl, u8 *th, u8 thl)
struct qeth_eddp_data *eddp; struct qeth_eddp_data *eddp;
QETH_DBF_TEXT(trace, 5, "eddpcrda"); QETH_DBF_TEXT(trace, 5, "eddpcrda");
eddp = kmalloc(sizeof(struct qeth_eddp_data), GFP_ATOMIC); eddp = kzalloc(sizeof(struct qeth_eddp_data), GFP_ATOMIC);
if (eddp){ if (eddp){
memset(eddp, 0, sizeof(struct qeth_eddp_data));
eddp->nhl = nhl; eddp->nhl = nhl;
eddp->thl = thl; eddp->thl = thl;
memcpy(&eddp->qh, qh, sizeof(struct qeth_hdr)); memcpy(&eddp->qh, qh, sizeof(struct qeth_hdr));
...@@ -542,12 +541,11 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb, ...@@ -542,12 +541,11 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb,
QETH_DBF_TEXT(trace, 5, "creddpcg"); QETH_DBF_TEXT(trace, 5, "creddpcg");
/* create the context and allocate pages */ /* create the context and allocate pages */
ctx = kmalloc(sizeof(struct qeth_eddp_context), GFP_ATOMIC); ctx = kzalloc(sizeof(struct qeth_eddp_context), GFP_ATOMIC);
if (ctx == NULL){ if (ctx == NULL){
QETH_DBF_TEXT(trace, 2, "ceddpcn1"); QETH_DBF_TEXT(trace, 2, "ceddpcn1");
return NULL; return NULL;
} }
memset(ctx, 0, sizeof(struct qeth_eddp_context));
ctx->type = QETH_LARGE_SEND_EDDP; ctx->type = QETH_LARGE_SEND_EDDP;
qeth_eddp_calc_num_pages(ctx, skb, hdr_len); qeth_eddp_calc_num_pages(ctx, skb, hdr_len);
if (ctx->elements_per_skb > QETH_MAX_BUFFER_ELEMENTS(card)){ if (ctx->elements_per_skb > QETH_MAX_BUFFER_ELEMENTS(card)){
...@@ -555,13 +553,12 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb, ...@@ -555,13 +553,12 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb,
kfree(ctx); kfree(ctx);
return NULL; return NULL;
} }
ctx->pages = kmalloc(ctx->num_pages * sizeof(u8 *), GFP_ATOMIC); ctx->pages = kcalloc(ctx->num_pages, sizeof(u8 *), GFP_ATOMIC);
if (ctx->pages == NULL){ if (ctx->pages == NULL){
QETH_DBF_TEXT(trace, 2, "ceddpcn2"); QETH_DBF_TEXT(trace, 2, "ceddpcn2");
kfree(ctx); kfree(ctx);
return NULL; return NULL;
} }
memset(ctx->pages, 0, ctx->num_pages * sizeof(u8 *));
for (i = 0; i < ctx->num_pages; ++i){ for (i = 0; i < ctx->num_pages; ++i){
addr = (u8 *)__get_free_page(GFP_ATOMIC); addr = (u8 *)__get_free_page(GFP_ATOMIC);
if (addr == NULL){ if (addr == NULL){
...@@ -573,15 +570,13 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb, ...@@ -573,15 +570,13 @@ qeth_eddp_create_context_generic(struct qeth_card *card, struct sk_buff *skb,
memset(addr, 0, PAGE_SIZE); memset(addr, 0, PAGE_SIZE);
ctx->pages[i] = addr; ctx->pages[i] = addr;
} }
ctx->elements = kmalloc(ctx->num_elements * ctx->elements = kcalloc(ctx->num_elements,
sizeof(struct qeth_eddp_element), GFP_ATOMIC); sizeof(struct qeth_eddp_element), GFP_ATOMIC);
if (ctx->elements == NULL){ if (ctx->elements == NULL){
QETH_DBF_TEXT(trace, 2, "ceddpcn4"); QETH_DBF_TEXT(trace, 2, "ceddpcn4");
qeth_eddp_free_context(ctx); qeth_eddp_free_context(ctx);
return NULL; return NULL;
} }
memset(ctx->elements, 0,
ctx->num_elements * sizeof(struct qeth_eddp_element));
/* reset num_elements; will be incremented again in fill_buffer to /* reset num_elements; will be incremented again in fill_buffer to
* reflect number of actually used elements */ * reflect number of actually used elements */
ctx->num_elements = 0; ctx->num_elements = 0;
......
...@@ -297,12 +297,10 @@ qeth_alloc_card(void) ...@@ -297,12 +297,10 @@ qeth_alloc_card(void)
struct qeth_card *card; struct qeth_card *card;
QETH_DBF_TEXT(setup, 2, "alloccrd"); QETH_DBF_TEXT(setup, 2, "alloccrd");
card = (struct qeth_card *) kmalloc(sizeof(struct qeth_card), card = kzalloc(sizeof(struct qeth_card), GFP_DMA|GFP_KERNEL);
GFP_DMA|GFP_KERNEL);
if (!card) if (!card)
return NULL; return NULL;
QETH_DBF_HEX(setup, 2, &card, sizeof(void *)); QETH_DBF_HEX(setup, 2, &card, sizeof(void *));
memset(card, 0, sizeof(struct qeth_card));
if (qeth_setup_channel(&card->read)) { if (qeth_setup_channel(&card->read)) {
kfree(card); kfree(card);
return NULL; return NULL;
...@@ -1632,9 +1630,8 @@ qeth_alloc_reply(struct qeth_card *card) ...@@ -1632,9 +1630,8 @@ qeth_alloc_reply(struct qeth_card *card)
{ {
struct qeth_reply *reply; struct qeth_reply *reply;
reply = kmalloc(sizeof(struct qeth_reply), GFP_ATOMIC); reply = kzalloc(sizeof(struct qeth_reply), GFP_ATOMIC);
if (reply){ if (reply){
memset(reply, 0, sizeof(struct qeth_reply));
atomic_set(&reply->refcnt, 1); atomic_set(&reply->refcnt, 1);
reply->card = card; reply->card = card;
}; };
...@@ -3348,13 +3345,11 @@ qeth_qdio_establish(struct qeth_card *card) ...@@ -3348,13 +3345,11 @@ qeth_qdio_establish(struct qeth_card *card)
QETH_DBF_TEXT(setup, 2, "qdioest"); QETH_DBF_TEXT(setup, 2, "qdioest");
qib_param_field = kmalloc(QDIO_MAX_BUFFERS_PER_Q * sizeof(char), qib_param_field = kzalloc(QDIO_MAX_BUFFERS_PER_Q * sizeof(char),
GFP_KERNEL); GFP_KERNEL);
if (!qib_param_field) if (!qib_param_field)
return -ENOMEM; return -ENOMEM;
memset(qib_param_field, 0, QDIO_MAX_BUFFERS_PER_Q * sizeof(char));
qeth_create_qib_param_field(card, qib_param_field); qeth_create_qib_param_field(card, qib_param_field);
qeth_create_qib_param_field_blkt(card, qib_param_field); qeth_create_qib_param_field_blkt(card, qib_param_field);
...@@ -4819,9 +4814,8 @@ qeth_arp_query(struct qeth_card *card, char *udata) ...@@ -4819,9 +4814,8 @@ qeth_arp_query(struct qeth_card *card, char *udata)
/* get size of userspace buffer and mask_bits -> 6 bytes */ /* get size of userspace buffer and mask_bits -> 6 bytes */
if (copy_from_user(&qinfo, udata, 6)) if (copy_from_user(&qinfo, udata, 6))
return -EFAULT; return -EFAULT;
if (!(qinfo.udata = kmalloc(qinfo.udata_len, GFP_KERNEL))) if (!(qinfo.udata = kzalloc(qinfo.udata_len, GFP_KERNEL)))
return -ENOMEM; return -ENOMEM;
memset(qinfo.udata, 0, qinfo.udata_len);
qinfo.udata_offset = QETH_QARP_ENTRIES_OFFSET; qinfo.udata_offset = QETH_QARP_ENTRIES_OFFSET;
iob = qeth_get_setassparms_cmd(card, IPA_ARP_PROCESSING, iob = qeth_get_setassparms_cmd(card, IPA_ARP_PROCESSING,
IPA_CMD_ASS_ARP_QUERY_INFO, IPA_CMD_ASS_ARP_QUERY_INFO,
...@@ -4969,11 +4963,10 @@ qeth_snmp_command(struct qeth_card *card, char *udata) ...@@ -4969,11 +4963,10 @@ qeth_snmp_command(struct qeth_card *card, char *udata)
return -EFAULT; return -EFAULT;
} }
qinfo.udata_len = ureq->hdr.data_len; qinfo.udata_len = ureq->hdr.data_len;
if (!(qinfo.udata = kmalloc(qinfo.udata_len, GFP_KERNEL))){ if (!(qinfo.udata = kzalloc(qinfo.udata_len, GFP_KERNEL))){
kfree(ureq); kfree(ureq);
return -ENOMEM; return -ENOMEM;
} }
memset(qinfo.udata, 0, qinfo.udata_len);
qinfo.udata_offset = sizeof(struct qeth_snmp_ureq_hdr); qinfo.udata_offset = sizeof(struct qeth_snmp_ureq_hdr);
iob = qeth_get_adapter_cmd(card, IPA_SETADP_SET_SNMP_CONTROL, iob = qeth_get_adapter_cmd(card, IPA_SETADP_SET_SNMP_CONTROL,
...@@ -5564,12 +5557,11 @@ qeth_get_addr_buffer(enum qeth_prot_versions prot) ...@@ -5564,12 +5557,11 @@ qeth_get_addr_buffer(enum qeth_prot_versions prot)
{ {
struct qeth_ipaddr *addr; struct qeth_ipaddr *addr;
addr = kmalloc(sizeof(struct qeth_ipaddr), GFP_ATOMIC); addr = kzalloc(sizeof(struct qeth_ipaddr), GFP_ATOMIC);
if (addr == NULL) { if (addr == NULL) {
PRINT_WARN("Not enough memory to add address\n"); PRINT_WARN("Not enough memory to add address\n");
return NULL; return NULL;
} }
memset(addr,0,sizeof(struct qeth_ipaddr));
addr->type = QETH_IP_TYPE_NORMAL; addr->type = QETH_IP_TYPE_NORMAL;
addr->proto = prot; addr->proto = prot;
return addr; return addr;
......
...@@ -1145,11 +1145,10 @@ qeth_dev_ipato_add_store(const char *buf, size_t count, ...@@ -1145,11 +1145,10 @@ qeth_dev_ipato_add_store(const char *buf, size_t count,
if ((rc = qeth_parse_ipatoe(buf, proto, addr, &mask_bits))) if ((rc = qeth_parse_ipatoe(buf, proto, addr, &mask_bits)))
return rc; return rc;
if (!(ipatoe = kmalloc(sizeof(struct qeth_ipato_entry), GFP_KERNEL))){ if (!(ipatoe = kzalloc(sizeof(struct qeth_ipato_entry), GFP_KERNEL))){
PRINT_WARN("No memory to allocate ipato entry\n"); PRINT_WARN("No memory to allocate ipato entry\n");
return -ENOMEM; return -ENOMEM;
} }
memset(ipatoe, 0, sizeof(struct qeth_ipato_entry));
ipatoe->proto = proto; ipatoe->proto = proto;
memcpy(ipatoe->addr, addr, (proto == QETH_PROT_IPV4)? 4:16); memcpy(ipatoe->addr, addr, (proto == QETH_PROT_IPV4)? 4:16);
ipatoe->mask_bits = mask_bits; ipatoe->mask_bits = mask_bits;
......
...@@ -27,10 +27,9 @@ s390_root_dev_register(const char *name) ...@@ -27,10 +27,9 @@ s390_root_dev_register(const char *name)
if (!strlen(name)) if (!strlen(name))
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
dev = kmalloc(sizeof(struct device), GFP_KERNEL); dev = kzalloc(sizeof(struct device), GFP_KERNEL);
if (!dev) if (!dev)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
memset(dev, 0, sizeof(struct device));
strncpy(dev->bus_id, name, min(strlen(name), (size_t)BUS_ID_SIZE)); strncpy(dev->bus_id, name, min(strlen(name), (size_t)BUS_ID_SIZE));
dev->release = s390_root_dev_release; dev->release = s390_root_dev_release;
ret = device_register(dev); ret = device_register(dev);
......
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