[dm-devel] [PATCH] reworked dm-switch target

Mikulas Patocka mpatocka at redhat.com
Thu Aug 30 00:51:06 UTC 2012



On Fri, 24 Aug 2012, Jim Ramsay wrote:

> I'm also not that familiar with what other devices use vmalloc space in
> the kernel - With a limited resource like this we must make sure we can
> properly contend with other consumers of the space.
> 
> So in conclusion, I think we're converging on something that we're all
> going to be happy with - We just need to ensure that the performance of
> the proposed changes are acceptable compared to our existing code.
> 
> To that end I will be devoting some time next week to getting your
> driver working with our userland to test page table uploading and actual
> IO performance.  Would you mind taking some time to give a try to the
> latest 'v4' version of this driver, and doing an independent comparison?
> 
> v4 driver code is here:
>   http://www.redhat.com/archives/dm-devel/2012-August/msg00299.html
> v4 userland example code is here:
>   http://www.redhat.com/archives/dm-devel/2012-August/msg00300.html
> 
> -- 
> Jim Ramsay

Hi

I tested your and my dm-switch implementation. I created 3 1GB ramdisk 
devices, filled them with data (so that alloc-on-demand in the ramdisk 
driver doesn't influence the benchmark). Then I placed dm-switch device on 
these ramdisks, with page size 3 sectors and page table of repetitive 
pattern 012012012...

I ran fio command performing 8 parallel I/O threads (on two quad-core 
Opterons), each reading or writing 512-bytes with direct I/O: "fio 
--rw=randrw --size=1G --bs=512 --filename=/dev/mapper/switch2 --direct=1 
--name=job1 --name=job2 --name=job3 --name=job4 --name=job5 --name=job6 
--name=job7 --name=job8"

Basically, the worst performance brake is the spinlock in your code, 
otherwise there is not much difference. vmalloc doesn't slow it down 
(actually it was slightly faster with vmalloc than with kmalloc).

Your original code
15.15s, stdev 0.05

Your code (with spinlock removed):
14.33s, stdev 0.17

Your code (with spinlock and RCU removed):
14.38s, stdev 0.16

My code (with kmalloc):
14.45s, stdev 0.17

My code (with vmalloc):
14.31s, stdev 0.11

Mikulas




More information about the dm-devel mailing list