Re: [PATCH 7/8] Use xvmalloc to store compressed chunks

From: Nitin Gupta
Date: Sun Jul 18 2010 - 04:21:27 EST


On 07/18/2010 01:23 PM, Pekka Enberg wrote:
> Nitin Gupta wrote:
>> @@ -528,17 +581,32 @@ static int zcache_store_page(struct zcache_inode_rb *znode,
>> goto out;
>> }
>>
>> - dest_data = kmap_atomic(zpage, KM_USER0);
>> + local_irq_save(flags);
>
> Does xv_malloc() required interrupts to be disabled? If so, why doesn't the function do it by itself?
>


xvmalloc itself doesn't require disabling interrupts but zcache needs that since
otherwise, we can have deadlock between xvmalloc pool lock and mapping->tree_lock
which zcache_put_page() is called. OTOH, zram does not require this disabling of
interrupts. So, interrupts are disable separately for zcache case.

Thanks,
Nitin
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/