September 2009 Archives

Intel X25-M G2 vs. Old Laptop Drive Benchmarks

| No Comments | No TrackBacks

I thought it would be a good idea to run some quick benchmarks on my old mechanical drive before I wipe it and use it another laptop. I have some pseudo-scientific charts and numbers here, but I also have some "me with a stopwatch" boot time numbers. They mostly only show how abysmal my boot up times are, mostly because of all the extra junk I have starting up.

I clocked the time from hitting the power button to seeing grub at well under 2 seconds. For both test I brought up the grub menu and I did my best to hit enter and start my stop watch (a.k.a. my old Treo 650) at the same time. When the GDM login appeared, I stopped the clock.

The 120 GB 7200 RPM laptop drive came in at a whopping 36 seconds. The X25 gave a much better result of 15 seconds. The software installed on both drives is exactly the same, but the root file system on the mechanical drive is ext3 instead of ext4. It isn't quite apples to apples but it is what I have here in front of me.

Some Real Bonnie++ Benchmarks

Show:

Charts are nice, but here's the actual numbers to go along with it:

Version 1.03c                           ------Sequential Output------ --Sequential Input- --Random-
                                        -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
Machine                              Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
Laptop PIIX Deadline X25-M          6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
Laptop AHCI Deadline X25-M          6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
Laptop PIIX CFQ X25-M               6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26
Laptop PIIX CFQ 120 GB 7200 RPM     6464M 45043  91 53992  14 19104   5 37053  81  46116   7 161.7   0
Laptop AHCI CFQ 120 GB 7200 RPM     6528M 41883  87 49245  10 17348   4 43423  82  56122   7 178.1   0
Xen Server Deadline RAID 10         1080M 68909  97 128789 45 48402  18 55770  91 106948  24 326.2   0
Laptop PIIX DL X25-M v1.4*          6280M 41521  77 69559  15 23754   6 30857  78 142922  13  5309   0
Laptop PIIX DL X25-M v1.4 TRIMed**  6280M 50354  98 66394  16 24923   8 31937  80 119348  19  4569  10
Laptop AHCI DL X25-M v1.4 TRIMed*** 6528M 42587  81 49367  11 23277   7 41588  81 150217  21 14115  35
Core I7 Laptop AHCI DL X25-M        8192M 56415  89 87157  11 39827   9 69707  98 298590  29 16150  45

I included an old benchmark of my web server. It has four 7200 RPM SATA drives in a Linux software RAID 10. I am very happy with now well the X25-M compares to the array.

I tested both the CFQ and Deadline IO schedulers on the X25. The machine felt more responsive when the test was running on the Deadline scheduler. I started a to test the noop scheduler but the machine felt much worse than it did during the CFQ test. I didn't bother letting that test continue after that.

Having AHCI and NCQ improves read performance pretty significantly and it seems to improve seek time dramatically, especially for the SSD. If you are able to use AHCI I would recommend it.

I wanted to run some bonnie++ benchmarks against the X25 because they I couldn't find any anywhere else. Bonnie++ doesn't do a very good job of highlighting the biggest advantage of the X25 because it only has one random access test.

Results From the "Butt Dyno"

Every time you make a performance modification to your car you have to take it for a test on the "butt dyno." It just means you get in the car and see how much faster it feels. Sometimes the performance boost is mostly in your head, like when you upgrade to a K&N air filter or a bigger exhaust.

Sometimes install a bigger turbocharger... I remember the last time I did that. I bet I had a great big smile on my face during that first shift from first to second gear. It made a very noticeable difference in the performance of the car.

That's the way the X25-M feels. Everything loads a bit faster and I/O intensive background tasks are much less likely to bog down the rest of the machine. I sure didn't enjoy booting up the old platter drive to run the benchmarks on it...

How Hot is the X25-M?

When I pulled the X25 out to swap in the old drive I noticed that it was warmer than I expected it to be. I imagine the metal housing makes it feel a bit warmer than an overworked SD card. My brain thought it was almost as warm as the old drive got.

I was very wrong. I pulled the mechanical drive out almost immediately after the bonnie++ runs. I would describe it as actually being hot. I put it down pretty quickly, it was uncomfortable to hold.

*Update 2009-10-27: X25-M v1.4 Firmware Update

I reran Bonnie with the latest firmware update. My test methodology is a little bit unfair. The previous tests were done on a very fresh drive. I'm now over 80% full and I probably have hundreds of gigs of rewrites on this drive.

I probably should have run a quick benchmark before I updated the firmware, but it is too late for that now! I am not surprised that most of the numbers went down. I am very surprised the sequential input speed is up by 30%. That is even outperforming my previous speeds with AHCI enabled.

**Update 2009-11-15: X25-M after a TRIM

I was able to TRIM my X25-M so I reran the bonnie. Small sequential output was improved. I have no idea why sequential block input was up so high on the last test.

*Update 2009-12-15: X25-M freshly TRIMed with AHCI and 2.6.31 kernel with BFS

I was pointed to a better AHCI quirks patch in a comment by felix krull.

The patch is working very well so far and I was itching to run a benchmark with AHCI and the newer v1.4 X25-M firmware. This benchmark may not be quite apples-to-oranges, though... I'm currently running Linux kernel version 2.6.31 patched with the BFS scheduler and most of the preempt options turned on.

Update 2010-03-24: X25-M transplanted into my new HP DV8T Core i7 laptop

The SATA 150 bottleneck is now gone. I expected it to break 200MB/s on the sequential input test but I certainly didn't expect to be approaching 300MB/s.

Intel X25-M G2 Upgrade, and a Lack of AHCI

| No Comments | No TrackBacks
My shiny new 80 GB second generation Intel X25-M has arrived.  So far I am very happy with it, and it is very fast.  I don't have many real numbers yet, just a couple of [bonnie++](http://www.textuality.com/bonnie/) benchmarks:

    Version 1.03c       ------Sequential Output------ --Sequential Input- --Random-
                        -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
    Machine        Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
    cfq           6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26
    deadline      6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12

    xenhost       1080M 68909  97 128789  45 48402  18 55770  91 106948  24 326.2   0

The first two entries are my laptop with the cfq and deadline schedulers.  The third entry is an old benchmark of the server hosting all my Xen virtual machines.  It is running Linux software RAID 10 on four 400 GB 7200 RPM SATA disks.

At first glance I was pretty happy with how well the X25 kept up with the RAID 10, and the numbers certainly beat my old laptop disk by a huge margin.  I was especially happy with the 4500-5500 random seeks per second.  The numbers seemed a bit low to me, though.  So I tried a simpler test:

    root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
    500+0 records in
    500+0 records out
    1048576000 bytes (1.0 GB) copied, 10.5582 s, 99.3 MB/s

All my simple tests with `dd` are pegged out at around 100 MB/sec.  After doing some research I learned that the BIOS in my laptop is setting my ICH7 chipset to compatibility mode.  This is limiting the drive to UDMA/133 speeds, which probably puts a real world upper limit in the 100MB/sec range.

The BIOS in my Dell Inspiron 6400 does not let me change the mode of the ICH7.  There seems to be at least [one kernel patch](http://mjg59.livejournal.com/85504.html) that attempts to enable AHCI after boot up.  I might give it a try in the next few days and see what the numbers look like.

This has still been a huge performance increase over my 120 GB, 7200 RPM laptop drive, even without being able to use the full potential of the X25.  My unscientific &quot;one-hippopotamus, two-hippopotamus&quot; boot up test easily comes in at under 10 seconds from grub to login screen (I&apos;m running Ubuntu 9.04).  I am pretty certain that the old drive was in the 15-16 second range.  I&apos;ll have to boot the old disk, use a stop watch, and run some benchmarks later in the week. </text></entry>
<entry id='11' allow_comments='1' allow_pings='1' atom_id='tag:blog.patshead.com,2009:/blog//1.11' author_id='1' authored_on='20090922160000' basename='forcing_ahci_to_increase_intel_x25-m_performance' blog_id='1' class='entry' comment_count='4' convert_breaks='markdown' created_by='1' created_on='20090919181355' modified_by='1' modified_on='20090920084123' ping_count='0' status='2' title='Forcing AHCI To Increase Intel X25-M Performance' week_number='200939'><keywords>linux, ahci, ubuntu, intel x25</keywords><text>The BIOS in my Dell Inspiron 6400 does not allow me to set the ICH7 SATA controller to AHCI mode.  I grabbed a fresh copy of the Linux 2.6.31 kernel source and applied [this AHCI quirks patch](http://www.codon.org.uk/~mjg59/tmp/ahci_quirk_cleanup.diff) to it.  I copied the [Ubuntu](http://www.ubuntu.com) `/boot/config-2.6.28-15-generic` to the new source directory and ran a `make oldconfig`.

With the stock [Ubuntu](http://www.ubuntu.com) 2.6.28-15-generic amd64 kernel `dmesg` showed that the controller was using the ata_piix driver and [NCQ](http://en.wikipedia.org/wiki/Native_Command_Queuing#NCQ_in_Solid-State_Drives) was disabled:

    [    1.696401] scsi0 : ata_piix
    [    1.696594] scsi1 : ata_piix
    [    1.860550] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 0/32)

With the 2.6.31 kernel with the patch applied `dmesg` showed:

    [    1.918218] scsi0 : ahci
    [    1.918414] scsi1 : ahci
    [    2.400540] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 31/32)

This is definitely an improvement, so I ran another quick `dd` to see if there was a change:

    root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
    500+0 records in
    500+0 records out
    1048576000 bytes (1.0 GB) copied, 8.45229 s, 124 MB/s

That was definitely an improvement so I thought it was time to run [bonnie++](http://www.textuality.com/bonnie/) again:

    Version 1.03c                     ------Sequential Output------ --Sequential Input- --Random-
                                      -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
    Machine                      Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
    2.6.31 ahci deadline        6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
    2.6.28 piix deadline        6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
    2.6.28 piix cfq             6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26

Enabling AHCI and [NCQ](http://en.wikipedia.org/wiki/Native_Command_Queuing#NCQ_in_Solid-State_Drives) gave me a small decrease in sequential output performance, a very nice increase in sequential input performance, and an insane increase in seeks per second.  I can only assume that the seeks per second was helped so tremendously by [NCQ](http://en.wikipedia.org/wiki/Native_Command_Queuing#NCQ_in_Solid-State_Drives).

So far I have found to major issues with using this kernel patch.  The laptop won&apos;t resume from a suspend and my optical drive has disappeared. From what I can tell, these two problems vary by machine.

On an unrelated note, my wifi (iwl3945) connects much faster with 2.6.31 than it did with 2.6.28.

Forcing AHCI To Increase Intel X25-M Performance

| No Comments | No TrackBacks

The BIOS in my Dell Inspiron 6400 does not allow me to set the ICH7 SATA controller to AHCI mode. I grabbed a fresh copy of the Linux 2.6.31 kernel source and applied this AHCI quirks patch to it. I copied the Ubuntu /boot/config-2.6.28-15-generic to the new source directory and ran a make oldconfig.

With the stock Ubuntu 2.6.28-15-generic amd64 kernel dmesg showed that the controller was using the ata_piix driver and NCQ was disabled:

[    1.696401] scsi0 : ata_piix
[    1.696594] scsi1 : ata_piix
[    1.860550] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 0/32)

With the 2.6.31 kernel with the patch applied dmesg showed:

[    1.918218] scsi0 : ahci
[    1.918414] scsi1 : ahci
[    2.400540] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 31/32)

This is definitely an improvement, so I ran another quick dd to see if there was a change:

root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
500+0 records in
500+0 records out
1048576000 bytes (1.0 GB) copied, 8.45229 s, 124 MB/s

That was definitely an improvement so I thought it was time to run bonnie++ again:

Version 1.03c                     ------Sequential Output------ --Sequential Input- --Random-
                                  -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
Machine                      Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
2.6.31 ahci deadline        6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
2.6.28 piix deadline        6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
2.6.28 piix cfq             6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26

Enabling AHCI and NCQ gave me a small decrease in sequential output performance, a very nice increase in sequential input performance, and an insane increase in seeks per second. I can only assume that the seeks per second was helped so tremendously by NCQ.

So far I have found to major issues with using this kernel patch. The laptop won't resume from a suspend and my optical drive has disappeared. From what I can tell, these two problems vary by machine.

On an unrelated note, my wifi (iwl3945) connects much faster with 2.6.31 than it did with 2.6.28.

Forcing AHCI To Increase Intel X25-M Performance

| No Comments | No TrackBacks

The BIOS in my Dell Inspiron 6400 does not allow me to set the ICH7 SATA controller to AHCI mode. I grabbed a fresh copy of the Linux 2.6.31 kernel source and applied this AHCI quirks patch to it. I copied the Ubuntu /boot/config-2.6.28-15-generic to the new source directory and ran a make oldconfig.

With the stock Ubuntu 2.6.28-15-generic amd64 kernel dmesg showed that the controller was using the ata_piix driver and NCQ was disabled:

[    1.696401] scsi0 : ata_piix
[    1.696594] scsi1 : ata_piix
[    1.860550] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 0/32)

With the 2.6.31 kernel with the patch applied dmesg showed:

[    1.918218] scsi0 : ahci
[    1.918414] scsi1 : ahci
[    2.400540] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 31/32)

This is definitely an improvement, so I ran another quick dd to see if there was a change:

root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
500+0 records in
500+0 records out
1048576000 bytes (1.0 GB) copied, 8.45229 s, 124 MB/s

That was definitely an improvement so I thought it was time to run bonnie++ again:

Version 1.03c                     ------Sequential Output------ --Sequential Input- --Random-
                                  -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
Machine                      Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
2.6.31 ahci deadline        6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
2.6.28 piix deadline        6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
2.6.28 piix cfq             6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26

Enabling AHCI and NCQ gave me a small decrease in sequential output performance, a very nice increase in sequential input performance, and an insane increase in seeks per second. I can only assume that the seeks per second was helped so tremendously by NCQ.

So far I have found to major issues with using this kernel patch. The laptop won't resume from a suspend and my optical drive has disappeared. From what I can tell, these two problems vary by machine.

On an unrelated note, my wifi (iwl3945) connects much faster with 2.6.31 than it did with 2.6.28.

Forcing AHCI To Increase Intel X25-M Performance

| No Comments | No TrackBacks

The BIOS in my Dell Inspiron 6400 does not allow me to set the ICH7 SATA controller to AHCI mode. I grabbed a fresh copy of the Linux 2.6.31 kernel source and applied this AHCI quirks patch to it. I copied the Ubuntu /boot/config-2.6.28-15-generic to the new source directory and ran a make oldconfig.

With the stock Ubuntu 2.6.28-15-generic amd64 kernel dmesg showed that the controller was using the ata_piix driver and NCQ was disabled:

[    1.696401] scsi0 : ata_piix
[    1.696594] scsi1 : ata_piix
[    1.860550] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 0/32)

With the 2.6.31 kernel with the patch applied dmesg showed:

[    1.918218] scsi0 : ahci
[    1.918414] scsi1 : ahci
[    2.400540] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 31/32)

This is definitely an improvement, so I ran another quick dd to see if there was a change:

root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
500+0 records in
500+0 records out
1048576000 bytes (1.0 GB) copied, 8.45229 s, 124 MB/s

That was definitely an improvement so I thought it was time to run bonnie++ again:

Version 1.03c                     ------Sequential Output------ --Sequential Input- --Random-
                                  -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
Machine                      Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
2.6.31 ahci deadline        6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
2.6.28 piix deadline        6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
2.6.28 piix cfq             6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26

Enabling AHCI and NCQ gave me a small decrease in sequential output performance, a very nice increase in sequential input performance, and an insane increase in seeks per second. I can only assume that the seeks per second was helped so tremendously by NCQ.

So far I have found to major issues with using this kernel patch. The laptop won't resume from a suspend and my optical drive has disappeared. From what I can tell, these two problems vary by machine.

On an unrelated note, my wifi (iwl3945) connects much faster with 2.6.31 than it did with 2.6.28.

Forcing AHCI To Increase Intel X25-M Performance

| No Comments | No TrackBacks

The BIOS in my Dell Inspiron 6400 does not allow me to set the ICH7 SATA controller to AHCI mode. I grabbed a fresh copy of the Linux 2.6.31 kernel source and applied this AHCI quirks patch to it. I copied the Ubuntu /boot/config-2.6.28-15-generic to the new source directory and ran a make oldconfig.

With the stock Ubuntu 2.6.28-15-generic amd64 kernel dmesg showed that the controller was using the ata_piix driver and NCQ was disabled:

[    1.696401] scsi0 : ata_piix
[    1.696594] scsi1 : ata_piix
[    1.860550] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 0/32)

With the 2.6.31 kernel with the patch applied dmesg showed:

[    1.918218] scsi0 : ahci
[    1.918414] scsi1 : ahci
[    2.400540] ata1.00: 156301488 sectors, multi 8: LBA48 NCQ (depth 31/32)

This is definitely an improvement, so I ran another quick dd to see if there was a change:

root@zaphod:~# dd if=/dev/sda2 of=/dev/null bs=2M count=500
500+0 records in
500+0 records out
1048576000 bytes (1.0 GB) copied, 8.45229 s, 124 MB/s

That was definitely an improvement so I thought it was time to run bonnie++ again:

Version 1.03c                     ------Sequential Output------ --Sequential Input- --Random-
                                  -Per Chr- --Block-- -Rewrite- -Per Chr- --Block-- --Seeks--
Machine                      Size K/sec %CP K/sec %CP K/sec %CP K/sec %CP K/sec %CP  /sec %CP
2.6.31 ahci deadline        6528M 45836  96 74973  15 36691  10 43531  78 139407  17 13431  39
2.6.28 piix deadline        6464M 48265  96 81809  23 37340  11 36500  70 108486  18  5502  12
2.6.28 piix cfq             6464M 47577  96 82931  21 38706  11 46920  91 116400  20  4482  26

Enabling AHCI and NCQ gave me a small decrease in sequential output performance, a very nice increase in sequential input performance, and an insane increase in seeks per second. I can only assume that the seeks per second was helped so tremendously by NCQ.

So far I have found to major issues with using this kernel patch. The laptop won't resume from a suspend and my optical drive has disappeared. From what I can tell, these two problems vary by machine.

On an unrelated note, my wifi (iwl3945) connects much faster with 2.6.31 than it did with 2.6.28.

About this Archive

This page is an archive of entries from September 2009 listed from newest to oldest.

August 2009 is the previous archive.

October 2009 is the next archive.

Find recent content on the main index or look in the archives to find all content.

Categories

Pages

OpenID accepted here Learn more about OpenID