Ad0 errors with CompactFlash Sandisk cards and Soekris net5501
-
-
Okay then it has to be something else on that card. Can you use it with your camera or windows machine without errors?
-
I haven't tried moving files in and out of it on Windows, but it seems to format it just fine and then detect it as a drive. Also in Linux if I format, seems like I can access it thereafter.
Okay then it has to be something else on that card. Can you use it with your camera or windows machine without errors?
-
I think there are a few different types of errors reported in this thread:
I haven't tried moving files in and out of it on Windows, but it seems to format it just fine and then detect it as a drive. Also in Linux if I format, seems like I can access it thereafter.
Neither of these tests are good tests that the whole card can be read and written.
On linux something like dd if=/dev/sdxx of=/dev/null bs=65536 can be used to read the whole card and something like dd if=/dev/zero of=/dev/sdaxx bs=65536 can be used to write zeroes to the whole card (where sdxx is carefully chosen to match the device assignment for the card).
I have exactly the same problem on a Soekris net4801. A 4 GB image on a new 4 GB SanDisk Ultra card gives a write error at the end.
This is almost certainly because the card is not large enough. It seems that once a 4GB card could hold 4102410241024 bytes of data an then some "genius" decided that a 4GB card needed to be able to hold only 4100010001000 bytes of data and then some "genius" decided the 4100010001000 bytes could include error detection bytes and then some genius decided the 4100010001000 byes could also include "replacement" blocks and then some genius decided that 3.9100010001000 could be rounded up to 4GB etc etc with each act of "genius" reducing the data space available to the end user. On what I've seen reported I would guess there could be a good case made to an aggressive consumer affairs department that a card advertised as 4GB must have at least 4100010001000 bytes available to the end user for file storage. But that is a digression.
I tried with the 2G image, sadly the results are the same:
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119Is buying a new CF card my best bet, or even my only choice?</nid_not_found></ready,dsc,error></nid_not_found></ready,dsc,error></nid_not_found></ready,dsc,error>
This doesn't look as if you are running the 2GB image. The logical blocks are 512 bytes long. LBA (Logical Block Address) 7813119 * 512 is about 4,000,316,928 which is well over 2GB. The 2GB image should not be referencing any block above something a little less than 210241024*1024/512.
In a net6501, I am having sort of similar errors on a 4G mSATA card that I purchased from Soekris, its a Transcend 4g MSA500 (I think?, something like this). I tested 2G and 4G nanobsd images on it with the same result.
_ad4: 3775MB <ts4gmsa500 20101212="">at ata2-master PIO4 SATA 3Gb/s
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3861855
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3452247
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3450831
ad4: TIMEOUT - READ retrying (0 retries left) LBA=3450831
ad4: FAILURE - READ timed out LBA=3450831
g_vfs_done():ufs/pfsense0[READ(offset=1766785024, length=14336)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1514407
ad4: TIMEOUT - READ retrying (0 retries left) LBA=1514407
ad4: FAILURE - READ timed out LBA=1514407
g_vfs_done():ufs/pfsense0[READ(offset=775335936, length=2048)]error = 5
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3450831
ad4: TIMEOUT - READ retrying (0 retries left) LBA=3450831
ad4: FAILURE - READ timed out LBA=3450831
g_vfs_done():ufs/pfsense0[READ(offset=1766785024, length=14336)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1514407
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1866375
ad4: TIMEOUT - READ retrying (1 retry left) LBA=311183
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3447463
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1814527
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1764455
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1503551
ad4: TIMEOUT - READ retrying (1 retry left) LBA=327975
ad4: TIMEOUT - READ retrying (0 retries left) LBA=327975
ad4: FAILURE - READ timed out LBA=327975These all look like the disk has bad spots at the referenced LBAs. However the problem could be that you are using quite new motherboard and FreeBSD needs some tweaks to work well with that chipset (or that "disk").
On a pfsense 2.0, I have a lot of I/O errors:
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119</nid_not_found></ready,dsc,error></nid_not_found></ready,dsc,error>As discussed earlier in this reply, the disk image you wrote to the card is too large for the card. In fact it appears that it is just too large. Your card claims to have user capacity of 4,000,317,440 bytes, the read starts at byte 4,000,316,928 which is the last block. Perhaps it was a multi-block read.
i am getting the same errors. tried two different cards. they are transcend industrial CF cards in an ide carrier in a dual atom d525 system. (hacom mars) dmesg | grep ad0
ad0: 1943MB <transcend 20070418="">at ata0-master PIO4
ad0: FAILURE - READ status=ff <busy,ready,dma_ready,dsc,drq,correctable,index,error>error=0 LBA=532431
ad0: FAILURE - WRITE status=ff <busy,ready,dma_ready,dsc,drq,correctable,index,error>error=58 <uncorrectable,nid_not_found,media_change_reqest>LBA=88375
ad0: TIMEOUT - WRITE retrying (1 retry left) LBA=88631
ad0: FAILURE - WRITE status=ff <busy,ready,dma_ready,dsc,drq,correctable,index,error>error=58 <uncorrectable,nid_not_found,media_change_reqest>LBA=88887
ad0: TIMEOUT - WRITE retrying (0 retries left) LBA=88631
ad0: FAILURE - READ status=ff <busy,ready,dma_ready,dsc,drq,correctable,index,error>error=0 LBA=233943</busy,ready,dma_ready,dsc,drq,correctable,index,error></uncorrectable,nid_not_found,media_change_reqest></busy,ready,dma_ready,dsc,drq,correctable,index,error></uncorrectable,nid_not_found,media_change_reqest></busy,ready,dma_ready,dsc,drq,correctable,index,error></busy,ready,dma_ready,dsc,drq,correctable,index,error></transcend>Notice the READ failures are flagged CORRECTABLE. I presume these are corrected and are reported as an indication of a developing bad spot on the "disk". (They might go uncorrectable one day soon.) The write failures (retries exhausted) indicate a bad spot. These are not related to the disk being too small to hold the file system that was written to it. Maybe you could use the Linux commands I gave earlier to test out the card with a different operating system. Did your two different cards report errors at the same LBAs?</ts4gmsa500>_
-
Thx for your input. I am still scratching my head.
In a net6501, I am having sort of similar errors on a 4G mSATA card that I purchased from Soekris, its a Transcend 4g MSA500 (I think?, something like this). I tested 2G and 4G nanobsd images on it with the same result.
_ad4: 3775MB <ts4gmsa500 20101212="">at ata2-master PIO4 SATA 3Gb/s
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3861855
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3452247
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3450831
ad4: TIMEOUT - READ retrying (0 retries left) LBA=3450831
ad4: FAILURE - READ timed out LBA=3450831
g_vfs_done():ufs/pfsense0[READ(offset=1766785024, length=14336)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1514407
ad4: TIMEOUT - READ retrying (0 retries left) LBA=1514407
ad4: FAILURE - READ timed out LBA=1514407
g_vfs_done():ufs/pfsense0[READ(offset=775335936, length=2048)]error = 5
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3450831
ad4: TIMEOUT - READ retrying (0 retries left) LBA=3450831
ad4: FAILURE - READ timed out LBA=3450831
g_vfs_done():ufs/pfsense0[READ(offset=1766785024, length=14336)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1514407
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1866375
ad4: TIMEOUT - READ retrying (1 retry left) LBA=311183
ad4: TIMEOUT - READ retrying (1 retry left) LBA=3447463
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1814527
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1764455
ad4: TIMEOUT - READ retrying (1 retry left) LBA=1503551
ad4: TIMEOUT - READ retrying (1 retry left) LBA=327975
ad4: TIMEOUT - READ retrying (0 retries left) LBA=327975
ad4: FAILURE - READ timed out LBA=327975These all look like the disk has bad spots at the referenced LBAs. However the problem could be that you are using quite new motherboard and FreeBSD needs some tweaks to work well with that chipset (or that "disk").</ts4gmsa500>_
-
On my net6501 I am trying a different mSATA here, its 20GB in size. Applied the 4g nanobsd image to it /w dd in Linux.
On boot and during use I get this (still scratching my head):
Trying to mount root from ufs:/dev/ufs/pfsense0
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=332239
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1513199
ad4: TIMEOUT - READ_MUL retrying (0 retries left) LBA=1513199
ad4: FAILURE - READ_MUL timed out LBA=1513199
g_vfs_done():ufs/pfsense0[READ(offset=774717440, length=18944)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=3450767
ad4: TIMEOUT - READ_MUL retrying (0 retries left) LBA=3450767
ad4: FAILURE - READ_MUL timed out LBA=3450767
g_vfs_done():ufs/pfsense0[READ(offset=1766752256, length=18944)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1135623
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1765855
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1768839
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=442207
ad4: TIMEOUT - READ_MUL retrying (0 retries left) LBA=442207
ad4: FAILURE - READ_MUL timed out LBA=442207
g_vfs_done():ufs/pfsense0[READ(offset=226369536, length=35328)]error = 5
vnode_pager_getpages: I/O read error
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=442207
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1513199
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1765455
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=1134127
ad4: TIMEOUT - READ_MUL retrying (1 retry left) LBA=332151I can work in the CLI/console but I am unsure here on continuing.
Update:
I took a 2.5" 320GB Sata drive and wrote the 4G nanobsd image to it in Linux via: dd if=pfsense.img of=/dev/sdX
booted up the net6501 and have the same result.
So either my ability to write the nanobsd image sucks (which doesn't make sense)
or
Something with the nanobsd and the net6501? -
Getting same issues here with ANY compactflash card I use. All are 2gb and I am getting the identical messages whether using the 2gb or 1gb of pfsense 2.0 nano image for i386 vga.
The specific message is:
ad0: 1953MB <sandisk sdcfj-2048="" hdx4.03="">ad0: Failure Read_DMA timed out LBA=4001759
ad0: Failure Read_DMA timed out LBA=4001743
ad0: Failure Read_DMA timed out LBA=4001756etc.
The hardware I am using is an asus Pundit P1-PH1. This very unit has been running flawlessly for the last 2 years with an embedded version of pfsense 1.2. The errors I am receiving now occur with the original compact flash card that was used for the last 2 years as well as a brand new one from Sandisk and new units from R Data. It doesn't matter who's cf card I use…. all are 2gb... all are having the exact same issue. This CAN NOT be an issue with compact flash cards. It's happening to far too many people with unrelated hardware. Has anyone actually had success flashing and using the nano versions of pfsense 2.0?
In all cases the write process to these flash drives is completed without errors. In all cases, pfsense boots and runs through it's motions until it gets to the ad0 device which is the compact flash card.
I have tested these cards (all of them) on a win7 machine. I am able to partition and format at will, copy files to and from the flash drive and have confirmed integrity of the files once copied from the flash drive back to the hard drive.
I'm happy to provide any additional information/testing that might be requested to help narrow down this issue as it is without question a big time pain in the behind right now.
It should be noted, while it is not the desired configuration, I have reluctantly installed a hard drive on the same asus Pundit and have successfully loaded pfsense 2.0 i386. Pretty certain it's not a hardware issue.</sandisk>
-
I have been able to install embedded/nanobsd 2.0.x on a net5501 with no problems / no errors. I have run into problems with a net6501 and the nanobsd/embedded however. Still not sure what is going on there.
Getting same issues here with ANY compactflash card I use. All are 2gb and I am getting the identical messages whether using the 2gb or 1gb of pfsense 2.0 nano image for i386 vga.
The specific message is:
ad0: 1953MB <sandisk sdcfj-2048="" hdx4.03="">ad0: Failure Read_DMA timed out LBA=4001759
ad0: Failure Read_DMA timed out LBA=4001743
ad0: Failure Read_DMA timed out LBA=4001756etc.
The hardware I am using is an asus Pundit P1-PH1. This very unit has been running flawlessly for the last 2 years with an embedded version of pfsense 1.2. The errors I am receiving now occur with the original compact flash card that was used for the last 2 years as well as a brand new one from Sandisk and new units from R Data. It doesn't matter who's cf card I use…. all are 2gb... all are having the exact same issue. This CAN NOT be an issue with compact flash cards. It's happening to far too many people with unrelated hardware. Has anyone actually had success flashing and using the nano versions of pfsense 2.0?
In all cases the write process to these flash drives is completed without errors. In all cases, pfsense boots and runs through it's motions until it gets to the ad0 device which is the compact flash card.
I have tested these cards (all of them) on a win7 machine. I am able to partition and format at will, copy files to and from the flash drive and have confirmed integrity of the files once copied from the flash drive back to the hard drive.
I'm happy to provide any additional information/testing that might be requested to help narrow down this issue as it is without question a big time pain in the behind right now.
It should be noted, while it is not the desired configuration, I have reluctantly installed a hard drive on the same asus Pundit and have successfully loaded pfsense 2.0 i386. Pretty certain it's not a hardware issue.</sandisk>
-
There seems to be multiple different issues here, but the one that results in any kind of NID_NOT_FOUND READ errors like:
ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119 ad0: FAILURE - READ status=51 <ready,dsc,error>error=10 <nid_not_found>LBA=7813119</nid_not_found></ready,dsc,error></nid_not_found></ready,dsc,error>
is normal on newer SanDisk cards and safe to ignore. It has nothing to do with image size, you can put a 1 GB image on a 4 GB card and they still do that. From what I've been able to gather on that, the cards report they have a larger usable size than they do, and when the FreeBSD ATA code initializes it tries to read the end of the disk even if its partition is nowhere near that, which the CF is reporting doesn't actually exist, which is what that log message says.
"according to ATA-7 specification, Section 6.59.6 is: "IDNF shall be set to one if a user-accessible address could not be found. IDNF shall be set to one if an address outside of the range of user-accessible addresses is requested if command aborted is not returned." FreeBSD labels this bit as NID_NOT_FOUND"
-
Here are my results. Four brand new CF cards, two Sandisk Ultra 4GB and two Sandisk Extreme 2GB.
Test unit: Seokris Net 5501
Flash method: Unmounted drive from OSX, then did "gzcat pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz | dd of=/dev/disk4 bs=16k"
Sandisk Ultra CompactFlash 30MB/s 4GB - card 1 of 2
pfSense-2.0-RELEASE-4g-i386-nanobsd.img.gz = LBA errors
pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz = LBA errorsSandisk Ultra CompactFlash 30MB/s 4GB - card 2 of 2
pfSense-2.0-RELEASE-4g-i386-nanobsd.img.gz = LBA errors
pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz = LBA errorsSandisk Extreme III 2GB - card 1 of 2
pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz = No errors, all good!
Sandisk Extreme III 2GB - card 2 of 2
pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz = No errors, all good!
Other Observations
When flashing the 4GB image to the 4GB cards, dd returned the following when the flash complete: 'dd: /dev/disk4: end of device'. The card still booted, though with LBA errors.
The 2GB image did not return 'dd: /dev/disk4: end of device', however still gave LBA errors for some reason.Summary Of Findings
If you want to use a CF card with a Seokris net5501, make sure you get yourself a Sandisk Extreme III - and avoid Sandisk Ultra 4GB.
Hope this is useful for someone - cost me an afternoons work!
-
The 2GB image did not return 'dd: /dev/disk4: end of device', however still gave LBA errors for some reason.
That is likely because of what cmb mentioned in the post before yours - it's trying to access the last bit of the disk which the card claims exists by size but then returns an error when something actually tries to read it.
-
Yep it was the NID_NOT_FOUND errors that I was seeing.
Will this smaller image in the next release solve this particular problem?
JD
-
Not likely because that is the fault of the hardware in the CF. If the image size would have done anything, the 2GB image on the 4GB card would not have had any problems.
-
Yeah - I just re-read cmbs post that the NID error is 'safe to ignore'.
In my case, as the card was dd'd on a mac - and then inserted into a Seokris.
Is it possible that the errors are occurring because the Seokris / FreeBSD is actually unable to see a part of the disk which my OSX box could?
This might explain why FreeBSD is trying to access an address space on boot which is outside what it thinks is user-accessible?
Possible?
JD
-
Not likely, but the only way to know for sure would be to repeat the test using dd on FreeBSD or a Windows box with some other software.
If you have a USB card reader you can even do the dd from the pfsense box. Fetch it from the console with fetch or scp and then plug in the reader, will probably be da0 (check the system log), then just gzip -dc whatever.img.gz | dd of=/dev/da0 obs=64k
-
Hmm - I'm doing gzip -d pfSense-2.0-RELEASE-2g-i386-nanobsd.img.gz | dd of=/dev/da0 obs=64k from another pfsense box (Intel, local disks) and it's just coming back 0 bytes transferred.
It's def. on da0…
Any ideas?
JD
-
My fault, it's gzip -dc