Yesterday, I started my yearly Epic Desk Cleanout. This annual ritual is more about holding up a trash can and sweeping everything into it. I really clean, which includes cataloging all the random SD cards I've collected throughout the year.
data:image/s3,"s3://crabby-images/e6707/e6707b1af9f2c231394f442373bd9459d8665fef" alt="sdcards.jpg"
For SD cards, I'll typically "dd" the contents of the drive to a Linux box, then examine the data from a shell. This year, a lot of those SD cards are Raspberry Pi images. I end up with a file system dump that I need to examine:
data:image/s3,"s3://crabby-images/61693/6169357a689e8ff2a5055594ca0130253933d4a9" alt="screenshot0.png"
Fortunately, the "fdisk" utility on Linux can read from a physical device, or from a data dump file:
data:image/s3,"s3://crabby-images/dacc6/dacc622ea5e108512cda793f02b7a0bd96d6e9a1" alt="screenshot1.png"
Here, "fdisk" reveals a few important tidbits about the binary image:
- The sector size (512 bytes)
- The partitions in the disk image including file system types
- The starting offset in sectors for the file systems
Using the sector size (512 bytes) and the start sector for the Linux file system (264192), we can use a little shell-fu to calculate the number of bytes to the beginning of the file system:
data:image/s3,"s3://crabby-images/bd4de/bd4de4b564b1e3e398ca782bf6a5f2a131da5d9e" alt="screenshot2_(1).png".png)
The Linux filesystem is 135,266,304 bytes into the pi.img file. Next, we create a mount point (I use "mnt" from my current directory, but you can use any unused directory) and mount the image, specifying the number of offset bytes to the Linux partition:
data:image/s3,"s3://crabby-images/3b6de/3b6de1c5a2b597d67cc23052a122908735347980" alt="screenshot3".png)
Now it's just a matter of changing to the "mnt" directory, and exploring the data.
1 SD drive down...1,978 to go.