I discover that Debian 9.5 is available as a "flasher" image and I am downloading that as I type this. My first BBB came with the Angstrom distribution, which was simply awful. My experiences with Debian, even back in 2014 were much better and it will be interesting so see what an up to date debian is like on the BBB.
I have my choice of the most up to date images, which run only from SD, as well as IoT images (which have no graphical desktop, and are what I want) or several images with a graphical desktop, which I simply ignore.I download BBB-blank-debian-9.5-iot-armhf-2018-10-07-4gb.img.xz which is 519 Mb in size. Can I flash this onto a BBB with only 2G of eMMC? Does the unit sitting on my desk have 2G or 4G? The hint is in the name (the -4gb) and indeed, when I run unxz on this, I get a 3.6G image. And I don't see any 2G images at all in the latest firmware collection, so the question is how much eMMC is on this card I am holding.
I dig up my USB to serial dongle, verify that it is /dev/ttyUSB0 and start picocom via:
picocom -b 115200 /dev/ttyUSB0This particular unit has U-Boot set up for diskless booting from when I was working with Xinu, so I can't just boot into linux and check partition sizes.
Apparently it is easy though, the sticker on the side will have a big "C" if it is a rev C unit with 4G of eMMC. Mine says "A5B" which means it is rev A apparently and has only 2G. All the rest of my units have "B" marked on them. This means that I will have to run a recent image from SD card, or find a different unit.
I do have two other units from an Ebay purchase in snazzy black metal cases. I open these up and see a Kingston KE4CN2H5A chip, and this is a 4G eMMC flash, so apparently these are rev C units and will work. No big "C" on the label. The silkscreen does say "element14" on this one, which is new to me, and may be indicative of a rev C unit.
I plug a 16G micro-SD card into my card reader and give the command:
dd if=BBB-blank-debian-9.5-iot-armhf-2018-10-07-4gb.img of=/dev/sdf bs=16MI dig out my 5V/2A power supply and connect it to the coaxial connector on the BBB. We continue to use the serial console to keep an eye on things. The SD card goes into the slot. We hold down the S2/"Boot" button (near the SD slot) while we plug in the power supply and continue to hold it down while we watch linux boot from the flasher SD card. As soon as the LED's begin to flash and linux begins to boot, we can let go of the S2 button. After some initialization, the lights go to a back and forth pattern while flashing takes place. There are lots of interesting messages on the console. It powers off when done.
If you want to look at all the messages from the flasher, here you go:
Once this finishes, I will be curious to see how much "disk space" is really required. Since I just want a minimal IoT system, it ought to be possible to fit it into 2G. How hard could it be to trim things down and set up a 2G flasher image?
I remove the SD card and hit the power button, and it boots from eMMC!
-Boot SPL 2018.09-00002-g0b54a51eee (Sep 10 2018 - 19:41:39 -0500) ... Debian GNU/Linux 9 beaglebone ttyS0 BeagleBoard.org Debian Image 2018-10-07 Support/FAQ: http://elinux.org/Beagleboard:BeagleBoneBlack_Debian default username:password is [debian:temppwd] beaglebone login:I use "sudo su" to become root and start looking around.
root@beaglebone:/home/debian# df Filesystem 1K-blocks Used Available Use% Mounted on udev 220136 0 220136 0% /dev tmpfs 49488 5376 44112 11% /run /dev/mmcblk1p1 3647540 1959908 1482628 57% / tmpfs 247436 0 247436 0% /dev/shm tmpfs 5120 4 5116 1% /run/lock tmpfs 247436 0 247436 0% /sys/fs/cgroup tmpfs 49484 0 49484 0% /run/user/1000The fact that we are using 57 percent of a 3.6G filesystem does suggest that we are just over the edge from what could fit on a 2G unit.
Also I am curious about what kernel drivers support the PRU in modern systems. Here is a list trimmed to only include those things that seem PRU related.
lsmod Module Size Used by pruss_soc_bus 16384 0 evdev 24576 1 uio_pdrv_genirq 16384 0 uio 20480 1 uio_pdrv_genirq pru_rproc 28672 0 pruss 16384 1 pru_rproc pruss_intc 16384 1 pru_rprocIt looks like a lot has changed from when I used to see only uio_pruss. This will take some looking into.
Enough for one day.
Tom's Computer Info / tom@mmto.org