staging: zcache: fix memory corruption bug
authorSeth Jennings <sjenning@linux.vnet.ibm.com>
Tue, 28 Feb 2012 22:02:23 +0000 (16:02 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 29 Feb 2012 23:23:38 +0000 (15:23 -0800)
This patch fixes a bug where the zv code writes before the allocated
buffer, resulting in system memory corruption. This was introduced
during the switch from xvmalloc to zsmalloc.

Signed-off-by: Seth Jennings <sjenning@linux.vnet.ibm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/staging/zcache/zcache-main.c

index 46c7c04c2451c0d95717f940f96eee9958317663..70734652f724fe4810da4343eb9e9cff1001fd6d 100644 (file)
@@ -701,7 +701,6 @@ static struct zv_hdr *zv_create(struct zs_pool *pool, uint32_t pool_id,
        u32 size = clen + sizeof(struct zv_hdr);
        int chunks = (size + (CHUNK_SIZE - 1)) >> CHUNK_SHIFT;
        void *handle = NULL;
-       char *buf;
 
        BUG_ON(!irqs_disabled());
        BUG_ON(chunks >= NCHUNKS);
@@ -710,14 +709,13 @@ static struct zv_hdr *zv_create(struct zs_pool *pool, uint32_t pool_id,
                goto out;
        atomic_inc(&zv_curr_dist_counts[chunks]);
        atomic_inc(&zv_cumul_dist_counts[chunks]);
-       zv = (struct zv_hdr *)((char *)cdata - sizeof(*zv));
+       zv = zs_map_object(pool, handle);
        zv->index = index;
        zv->oid = *oid;
        zv->pool_id = pool_id;
        zv->size = clen;
        SET_SENTINEL(zv, ZVH);
-       buf = zs_map_object(pool, handle);
-       memcpy(buf, zv, clen + sizeof(*zv));
+       memcpy((char *)zv + sizeof(struct zv_hdr), cdata, clen);
        zs_unmap_object(pool, handle);
 out:
        return handle;