Archive for the author ·



Review: “ISIS: Inside the Army of Terror”, Michael Weiss and Hassan Hassan

no comments

In their book “ISIS: Inside the Army of Terror” from early 2016, Michael Weiss and Hassan Hassan give detailed insight into the Islamic State, its origin, key members, alliances, critical battles, and strategy of terror. The story begins with the the early ties between Ayman Mohammed Rabie al-Zawahiri and Osama bin Laden in the 1990s, and the later split between them and the more radical and extreme Abu Musab al-Zarqawi. Their disagreement on who are their enemies, crucially whether it includes Muslims or not, has underlined the split between al-Qaeda and ISIS / Islamic State. In later chapters, the rise of the current leader, theology professor Abu Bakr al-Baghdad, is investigated. The book goes into great detail about several key battles in Iraq and Syria, and analyses positions and outcome. Finally, some of the terror attacks on civilians in Europe and the US is put in context.

Sunni vs. Shia

There are a few important take-aways from the book: The divide between Sunni and Shia Muslims is usually at the core of most of the conflicts. Crucially, the numbers goes a long way to explain the various positions: Word-wide, Sunnis are in majority at around 85–90% while 10–15% are Shia. However, in Iraq and Iran this is reversed, where 80% and 95% are Shia respectively. An important point is the fact that Saddam Hussein was Sunni, and his mostly Sunni minority Baath party ruled over the Shia majority. When US invaded and ended their rule and tried to create democracy, the stage was set for bitter conflict. Furthermore, Paul Bremer (presidential envoy to Iraq) fired the mostly Sunni Iraqi army, along with most other official positions. So around 2003 a large part of the previous Iraq elite was suddenly jobless, but with plenty of military experience and even weapons on their hands. al-Zarqawi exploited these fault lines to his fullest, and ignited the ensuing civil war.

A similar setup, but again reversed has been the background for the civil war in Syria. There, Bashar Hafez al-Assad and his party are Alawites, a branch of Shia, but in a minority at around 13%. When the spring revolutions in 2011 swept other Muslim countries, al-Assad pitted themselves as under attack by the Sunni (74%) majority. al-Assad’s regime has support from Iran and Hezbollah who are also Shia. The opposition in Syria has many factions, and ISIS has time and again proved that they are experts at driving a wedge between opposing forces to divide and conquer.

Enemy of my Enemy

From small tribes, to national organizations and rebel groups and all the way to international alliances, the relationships network is extremely complex. A graph like this hardly scratches the surface. Furthermore, alliances shift frequently, and often the short term strategy is “the enemy of mine enemy is my friend”. This can be seen going far back, and characterizes much of US and Russian involvement in the various conflicts: During the Cold War; the US backing of Iraq against Iran in 1979; later US attacks against Iraq; US backing of the Kurds. Iran and Russia have tended to back the opposite groups, and Iran in particular has now infiltrated much of the Shia resistance and politics in Iraq.

The book goes into detail on several of these fluid alliances, and looks at the decisive battles and opposing personalities. The point is made many times over that in order to understand the conflicts, one has to understand the tribal politics. At a higher level, the relationships are often more pragmatic: Although ISIS is waging war across Syria, and also against al-Assad forces, they have a business relationship in the oil trade, where ISIS is selling back oil to al-Assad’s regime from the oilfields they have captures. al-Assad benefits since ISIS also fights the rebels in Syria. The enemy of mine enemy is my friend.

Read it

Weiss and Hassan have done plenty of research and interviews for this book, and it shows through all the details revealed. They have also done a good job of explaining the background history, religious underpinnings, and political motivations for the parties involved in the conflict. However, it can get somewhat tedious to go through all the nitty-gritty, and the writing style can be trite with the occasional odd analogies.

Overall, the book is definitively worth a read if you are interested in the current conflict, want to understand the terror attacks. Regional and international politics become more clear with the information provided by this book.

Backblaze: SMART stats to predict hard drive failure

no comments

Over the years, Backblaze has published several interesting reports and statistics on their harddrive performance and failures. In their latest post, they look at which SMART metrics they monitor and react to. They say, “when the RAW value for one of these five attributes is greater than zero, we have a reason to investigate”.

SMART 5 Reallocated Sectors Count
SMART 187 Reported Uncorrectable Errors
SMART 188 Command Timeout
SMART 197 Current Pending Sector Count
SMART 198 Uncorrectable Sector Count

They go on to point out, that although a single one of those metrics might only indicate 30% to 40% probability of a failed drive, when combined the probability increases to 76%. Furthermore, looking at multiple failed values, and their rate of increase might also help determine if a drive is about to fail. A higher rate is usually worse. Finally, they note that the the SMART 189 – High Fly Writes is another good candidate to consider, and again when looking at the rate.

On a related note, here’s a note on Google’s data on their SSD failures.

Getting started with GitHub Pages and Jekyll

no comments

In the beginning, there were static HTML pages, TABLE-tags, and FTP; later came dynamic sites, WordPress and other Content Management Systems; but now we are back to static pages again, albeit templated. So goes Quinn Supplee’s narrative of the move to Jekyll, Markdown and Liquid based static sites. Add in GitHub for free hosting, and it makes a very compelling offering for a small site run by tech savvy people. It’s not your web sites for dummies solution.

Enabling web page hosting from a Github repository is quick, as explained here. And setting a custom domain is a single setting on Github, and additional setting up your domain DNS. The Github Settings panel have a default example site template generator, so with that you’ll have some pages to look at in few clicks. Now you can download the generated files, modify and upload with standard git commands. (Replace username/repository with your own names).

git clone
git commit
git push

Github uses Jekell to statically generate the site, and this requires a special file and directory structure. It is of course possible to experiment with the files directly on Github, however it might be easier to edit and compile locally. For that, a local install of Jekyll and relevant dependencies and tools is required.

sudo apt-get install ruby ruby-dev rubygems-integration nodejs ruby-mkrf
sudo gem install jekyll jekyll-docs jekyll-feed jekyll-paginate bundler minima iconv

On older Debian (7 – Wheezy) or Ubuntu (14.04) distributions, the ruby packages where versioned incorrectly, so the 2.0 version is required for the ruby package and gem binary.

sudo apt-get install ruby2.0 ruby2.0-dev rubygems-integration nodejs ruby-mkrf
sudo gem2.0 install jekyll jekyll-docs jekyll-feed jekyll-paginate bundler minima iconv

With that in place, you can generate a new blank site, and make Jekyll serve it locally on . Of course, the final destination would be the Github repository.

jekyll new test --skip-bundle
cd test
jekyll serve

For more advanced options and functions, the Jekyll documentation is good. There are some Jekeyll based example sites here. In particular, Patrick Mckinley’s pagination example with source looks interesting.

Samsung boasts about its SSDs

Comments Off

In a few recent articles at Tom’s Hardware, Paul Alcorn has summarized the latest roadmap and product visions from Samsung, including an upcoming new form factor to replace the Intel M.2 connector and QLC (Quad Layer Cell) SSD that could reach 100 TB drives. Finally, Chris Ramseyer takes a look at the new Samsung 960 EVO and 960 Pro NVMe drives.

Some developments are clear: More data will be stacked in a smaller space, through 3D NAND, 16 bits QLC (Quad Layer Cell), and more dies stacked on top of each other. This will all result in lower prices per byte of storage. Obviously, it makes no sense to include a spinning disk in a laptop anymore, but the holy grail is the data center. There things are not so clear-cut. According to Alcorn’s article, Facebook is experimenting with QLC drives which could reach 100 TB. But there is of course no mention of price.

What’s interesting, is that the newer drives, which use the new NVMe based M.2 controller has reset the downwards price trend. In one of the slides, Samsung points out that SSD storage is now at 36 US cents per GB. However, the latest 960 series are almost double that, at 64 cents. (512 GB for $329; 1 TB for $629; 2 TB for $1299). In comparison, the Seagate Archive 8 TB drives cells for $249 now, is 1/20 of that, at 3 cents per GB.

In other words, Samsung has traded the 4x to 6x increase in read / write speed on the NVMe controllers for a doubling in SSD storage price. Now, Alcorn points out that there might be some margin to shave off there. Samsung has almost half the world market on both SSD drive and total SSD capacity shipments right now, but the competition is ramping up. That we will see lower prices per byte on SSD in the next year is a given.

Comments Off

Add-on development for Kodi

Comments Off

On the heels of the QNAP NAS setup notes, here’s a fun integration with my home automation system for living room lights.

The idea is to send the same commands from the Kodi app as the custom Android app does to the Arduino controlled relays. Before the movie starts, the lights go off. I’ll skip the details of that code, but point to a few useful pages to get started. It’s simple.

The Kodi Add-on documentation is good. To get started, you need at least two files: The addon.xml configuration, and your Python script, e.g. These have to be in a directory on the format (more in the linked documentation) and zip-ed in a ZIP file which does not use use compression, as seen below. This zip-file can now be copied to the NAS, and installed from Kodi.
zip -0 -r script.myaddon

One gottcha is that the addon.xml file cannot contain a final new-line. At least some people have reported that causing a install error.

For an easy way to get started, look at the Hello World add-on example, as well as its source code. It doesn’t get easier than that.

Comments Off

Securing a Postfix mail server – TLS transport encryption

Comments Off

I previously discussed SPF and DKIM setup for the Postfix mail server. Here’s some notes on TLS transport encryption. (Although, maybe those articles should have come in opposite order).

Using a self-signed certificate (which should be fine for small scale usage), setup is rather easy and straight forward. Creating the keys and certificats boils down to these instructions, copied from here. (Similar instructions here).

openssl genrsa -out rootCA.key 2048
openssl req -x509 -new -nodes -key rootCA.key -days 1024 -out rootCA.pem
openssl genrsa -out device.key 2048
openssl req -new -key device.key -out device.csr
openssl x509 -req -in device.csr -CA rootCA.pem -CAkey rootCA.key -CAcreateserial -out device.crt -days 500

Modifying /etc/postfix/, you might end up with something like this, assuming you’ve copied the keys as indicated by the linked article.
smtp_use_tls = yes
smtpd_use_tls = yes
smtp_tls_note_starttls_offer = yes
smtpd_tls_security_level = may
smtpd_tls_ask_ccert = yes
smtpd_tls_security_level = may
smtpd_tls_loglevel = 1
smtpd_tls_received_header = yes
smtpd_tls_session_cache_timeout = 3600s
tls_random_source = dev:/dev/urandom
smtpd_tls_key_file = /usr/share/ssl/certs/postfix/device.key
smtpd_tls_cert_file = /usr/share/ssl/certs/postfix/device.crt
smtpd_tls_CAfile = /usr/share/ssl/certs/postfix/rootCA.pem

Once all the changes are made, restart postfix:
service postfix restart

Now you can verify the setup with telnet:
telnet 25

This should yield:
220 Ready to start TLS

Another way to confirm the setup is to send an email to a account, and observe the lock status icon on the header field drop-down, explained in detail here.

Finally, the official Postfix documentation and notes on authentication (older doc) might come in handy.

Comments Off

QNAP NAS and autofs auto mount

Comments Off

After considering multiple options to cover a HTPC and a NAS, I finally went with the combined “living room” QNAP HS-251+ NAS earlier this year. I’ll leave the reviews to other sites, and just summarize the main features:

  • 2 bay 3.5″ or 2.5″ HDD or SSD
  • Intel Celeron 2GHz Quad core; 2 GB DDR3 RAM
  • 2x 1Gb RJ-45 ports; 2x USB 2.0; 2x USB 3.0
  • 1x HDMI
  • Fan-less
  • Simple remote control
  • Multiple in-house and external apps
  • Good support for Kodi (aka. XBMC)
  • Linux based 32-bit OS, with most common tools and network services available, including SSHD, NFS, SMB, FTPS, rsync.


Setting up NFS shares on the NAS side is straight forward through the web based UI under “Control Panel”. You probably want to create one or more users which match your own client (e.g. laptop) user, and possibly also related group. All this can be achieved through the UI, however, for setting specific user IDs, SSH into the NAS (using the admin account) and edit /etc/passwd and /etc/group. If the IDs are changed, you’ll also have to update /mnt/HDA_ROOT/.config/nfssetting.

david:x:1001:8008:Linux User,,david,:/share/homes/david:/bin/sh
john:x:1000:8008:Linux User,,john,:/share/homes/john:/bin/sh


The reason for changing the user or group IDs manually might be to match existing IDs on the client machines. In that case, you might also have to provide this option, to make those IDs are actually used by the NAS. This setting is not permanent, so if the NAS is restarted frequently, you might consider a start-up script solution.
echo N > /sys/module/nfs/parameters/nfs4_disable_idmapping

The two relevant configuration files for the NFS setup on the NAS are /etc/exports and /mnt/HDA_ROOT/.config/nfssetting. They will be automatically configured by the UI, however some manual tweaking might be needed. I ended up with something like this, for two machines (with DNS names”laptop”, “desktop” – you can also use IP address) and two shares (“pictures”, “video”). The user (UID) and group (GID) ids will match what’s seen in the /etc/passwd and /etc/group files above.


"/share/CACHEDEV1_DATA/pictures" laptop(rw,async,no_subtree_check,insecure,no_root_squash) desktop(rw,async,no_subtree_check,insecure,no_root_squash)
"/share/CACHEDEV1_DATA/video" laptop(rw,async,no_subtree_check,insecure,no_root_squash) desktop(rw,async,no_subtree_check,insecure,no_root_squash)

"/share/CACHEDEV1_DATA/Public" *(rw,async,no_root_squash,insecure)
Version = 4.2.0
/share/CACHEDEV1_DATA/Public = FALSE
/share/CACHEDEV1_DATA/pictures = TRUE
/share/CACHEDEV1_DATA/video = TRUE
/share/CACHEDEV1_DATA/Public = *
/share/CACHEDEV1_DATA/pictures = laptop,desktop
/share/CACHEDEV1_DATA/video = laptop,desktop
/share/CACHEDEV1_DATA/Public = rw
/share/CACHEDEV1_DATA/pictures = rw,rw
/share/CACHEDEV1_DATA/video = rw,rw
/share/CACHEDEV1_DATA/Public = no_root_squash
/share/CACHEDEV1_DATA/pictures = no_root_squash,no_root_squash
/share/CACHEDEV1_DATA/video = no_root_squash,no_root_squash
/share/CACHEDEV1_DATA/Public = 65534
/share/CACHEDEV1_DATA/pictures = 1001,1000
/share/CACHEDEV1_DATA/video = 1001,1000
/share/CACHEDEV1_DATA/Public = 65534
/share/CACHEDEV1_DATA/pictures = 8008,8008
/share/CACHEDEV1_DATA/video = 8008,8008

After making any changes to the NFS config, restart the service:
/etc/init.d/nfs restart

Client side and autofs

On the client, e.g. laptop or desktop, you’d want to point your NFS mount configuration to the shares created above. However, since either NAS or more likely personal machine will be rebooted, it is useful to configure this through autofs instead of the traditional /etc/fstab config. That way, the shares will be mounted and re-mounted on demand. It will also avoid long waits at boot and shutdown of the client machines.

First, make sure the NFS and autofs packages are installed:
apt-get install portmap nfs-common autofs cifs-utils

Edit /etc/auto.master and add the following line, which specify local mount point, and specific configuration files. Note that that has to match with your setup, so you might want to change the names here. As long as the /mnt directory and config file match, you can use whatever names you like.

/mnt/qnap /etc/auto.qnap

The share specific configuration is then added in the file referenced above. It assumes you’ve named the shares on the NAS “pictures” and “video”. It also assumes the DNS name of the NAS is “qnap” (or you can use an IP here). Finally, it assumes that the shared group is called “foobar”, which should match the GID 8008 above. That GID should also be present on the client machine.

pictures -fstype=nfs,rw,soft,tcp,nolock,gid=foobar qnap:/pictures
video -fstype=nfs,rw,soft,tcp,nolock,gid=foobar qnap:/video

Finally, after making changes to the NFS / autofs confg, restart the service:
/etc/init.d/autofs restart

Comments Off

Privacy attacks and government surveillance continue

Comments Off

At the Symantec Government Symposium on Tuesday, FBI director James Comey said he “can’t resist talking about encryption and going dark”, and will continue an “adult” discussion into 2017. What’s stopping him now, seems to be the media attention on the presidential election. He continued “The challenge we face is that the advent of default, ubiquitous strong encryption is making more and more of the room we are charged to investigate dark”. Referring to device encryption on iPhones and Android phones, as well as Whatsapp, etc.

Meanwhile in Europe, French and German politicians have seized on the recent fear of violence to push similar rhetoric. Last week French Interior Minister Bernard Cazeneuve and German Interior Minister Thomas de Maizière said that “they will push for a Europe-wide law requiring tech companies to provide law enforcement agencies with access to encrypted messages when necessary”. Cazeneuve said, “We propose that the EU Commission studies the possibility of a legislative act introducing rights and obligations for operators to force them to remove illicit content or decrypt messages as part of investigations, whether or not they are based in Europe”. The “our law” should universal thinking, in other words.

The “crypto wars” are as hot as ever, and even though the latest communication technology offerings have made it easier for everybody to stay private, it is clear that the Western surveillance states will not give up without a fight.

Comments Off

Hand soldering Surface Mount Components

Comments Off

I recently got a $3 practice board for soldering SMD devices. It comes with components of various sizes, including resistors in 1206, 0805, and 0603 sizes; 1206 didoes; SOT-23 transistors; and a SOP14 chip. The board itself has no purpose, and only the resistors and didoes are actually connected. Given that the goal of this was to practice soldering, I’m happy with the outcome, as seen in the pictures below.

As can be seen, the 100 Ω resistors (“101″) are 1206 (3.2 x 1.6 mm); 82 Ω (“820″) are 0805 (2.0 x 1.25 mm); and 750 Ω (“751″) are 0603 (1.6 x 0.8 mm).

Some requirements and observations on hand soldering:

  • Soldering hygiene is paramount: The tip always has to be speckless; the solder has to be clean and untouched (cut off its tip if necessary).
  • Visual magnification is required to see what you are doing. Both a tweezer with a magnifying class and a pair of magnifying eye glasses are required.
  • A thin solder, preferably 0.5mm.
  • A thin solder tip.
  • Extreme patience is a must.

As opposed to through-hole soldering, SMD hand-soldering requires a flawless process every time. The tip always has to be clean and wet; so the sponge must always be clean to avoid picking up solder bits. Nothing must be in the way of the working area, including the solder iron wire. The components must be ready and almost in place. A typical iteration of my personal beginner’s technique went something like this:

  1. Remove old solder from the sponge.
  2. Clean and wet the solder tip: First with the iron cleaner; then on the sponge; wet with a bit of solder; clean on the sponge.
  3. Inspect the solder tip under a magnifying glass. It should be shiny and without spots or old soler. Repeat step 1 if necessary. 
  4. Put the solder tip down on one of the board pads, and move the solder in to add a bit of solder. Repeat for more solder points.
  5. If the solder starts to bubble, repeat the cleaning steps.
  6. Add solder to the tip before putting it back in its holder. 
  7. Open the SMD strip to push out one or two components.
  8. Using a magnifying glass and tweezer, orient the component in almost the correct location, right next to the pre-soldered pad from step 4.
  9. Clean and prepare the soldering tip.
  10. Hold the component down with the tweezer + magnifying glass.
  11. Heat the solder from step 4, and push in the component into its correct position.
  12. Without moving the tweezer, remove the solder iron.
  13. Repeat for more components.
  14. Add solder to the tip before putting it back in its holder. 
  15. Clean and prepare the soldering tip.
  16. Both hands are required, so use a handless magnifier, e.g. the magnifying glasses linked above.
  17. Heat the other side of the component (or solder pad) placed on the board.
  18. Carefully come in with the solder. Try to make it melt by touching the pad on the board, rather than the solder tip.
  19. If the solder starts to bubble, repeat the cleaning steps.
  20. Repeat for more components.
  21. Add solder to the tip before putting it back in its holder.

As this suggests, the cleaning can get repetitive, however it’s absolutely necessary to make this work. As the wetting and cleaning might actually waste quite a bit of solder, a tip refresher paste might be useful. The one at DX is sold out, but AliExpress has the same.

If it wasn’t clear already, this is hand-soldering at a rookie level. For professional techniques, better look elsewhere.

Comments Off

Review: “Blackwater: The Rise of the World’s Most Powerful Mercenary Army”, Jeremy Scahill

Comments Off

In journalist Jeremy Scahill’s exposé of the American private mercenary company Blackwater, he documents its origin, its founder Eric Princ’s life and family history, the early start as a North Carolina military and police training facility, later involvement in the wars in Afghanistan and Iraq, its close political and military ties, and several of the controversial and deadly contracts and missions, including the infamous Fallujah ambush, Najaf siege, Blackwater 61 plane crash. He goes on to investigate some of the characters involved with the company, some right out dangerous like Cofer Black from CIA; while other more comically incompetent like Pentagon’s Inspector General Joseph Schmitz.

As an investigation and documented history of the company and its conduct, Scahill has done an extraordinary job in revealing all the details. Albeit it can get somewhat long when every bullet fired is included in the narration, as almost seems to be the case with the Najaf siege. Further details of the preceding contracts, and following lawsuits of wrongful death paints a picture of a company shrouded in secrecy and with deep far-right political and military connections.

It is perhaps in revealing these connections the book raises above a mere critic of the private mercenary company, and shines light on the power brokers of Washington and Pentagon. It is not a coincidence that the same names and the same circles always repeat: Donald Rumsfeld set the stage for privatization of the military; always working closely with Paul Wolfowitz. Of course Dick Cheney is there; as well as Scooter Libby. On the military and intelligence side, Paul Bremer (Presidential Envoy to Iraq) and Cofer Black (CIA) move through the revolving doors multiple times. Tying much of it together are the Council for National Policy (CNP) organization and the influential Project for the New American Century (PNAC), which William Kristol (son of Irving Kristol) and Robert Kagan founded. CNP in particular acts as a meeting point between conservative politicians, donors and activists. Here the Prince family huddles with prominent neoconservatism like Jerry Falwell (evangelical Southern Baptist pastor), Gary Bauer (1999 presidential nominee), Wayne LaPierre (NRA), and more. The focal points center around conservative politics, Christian evangelical and to some degree Judaist religion, and aggressive military foreign policy. As Scahill’s book shows, the military industrial complex is not an abstract entity or idea; rather it is a surprisingly small network of public and private figures who yield immense political and military power.

Scahill book is well worth a read, to gain insight into the private side of the US military industrial complex, its incredible cash-flow, and deep connections. Although he is clearly skeptical of both the mercenary company and several of the political figures involved, his presentation is factual objective and well written.

Comments Off

DealExtreme orders

Comments Off

Comments Off

ESP8266 galore

Comments Off

More than a year ago, I tried out the ESP8266, but didn’t get very far. The scene and products have evolved a lot since then, and today it’s as easy to use and develop with the ESP8266 as with the Arduino. Some shields are also coming online, although there are no common form factors yet.

DealExtreme stocks a number of different boards and chips. Among them, the most interesting are the various boards from Wemos. They have a two form factors: The “D1″, a rather large board which matches the Arduino Uno layout and header pins; and the neat and small “D1 min” at only 34×25 mm. What makes the latter very appealing, is a range of small shields which stack on top of each other, just like the old Arduino.

There are already several interesting shields available from Wemos. Including a temperature sensor; 64×48 pixel OLED display; 220 V relay; motor driver; SD card; battery connector; single button; single LED; and a DIY “proto board”. These are not available from DX, and are best ordered from Wemo’s AliExpress shop. Please note, the ones linked here do not have the header pins soldered, so a bit of manual soldering work is required.


Comments Off

Storage prices

Comments Off

As predicted in January, there have indeed been a number of exciting releases and announcements so far this year: Samsung finally launched their 15TB SSD; Intel brought 16nm TLC SSD to market; SanDisk (now owned by Western Digital) continue to launch faster larger SD cards; and a new large and heavy 8 TB USB 3.1 C external drive from Seagate was just made available.

On the list below, there are also a few changes, including some new 8 TB disks from Western Digital. Prices are coming down a bit, but also due to currency fluctuations. Several 8 TB spinning disks are now very competitively priced.

SSD drives are also coming down in price, and starting last year, more drives are now becoming cheaper per byte than optical media. That is of course mainly due to the fact that there has been no development in the latter technology, however, it’s a milestone worth noting since the next is in fact price parity with certain spinning disks. Where the gap has been 10x for the last decade (and still is for the cheapest HDD), it is now closing in more rapidly. Between the cheapest SSD byte and most expensive HDD byte the factor is now 3x-4x.

Media Type Product Capacity Price CHF Price Euros Euros / GB GBs / Euro
HDD-SMR Seagate ARCHIVE HDD 8TB 8000 GB 259.00 237.61 0.03 33.67
External 3.5 Western Digital Elements Desktop 4TB, USB3 4000 GB 132.00 121.10 0.03 33.03
HDD Seagate Desktop 4TB 4000 GB 133.00 122.02 0.03 32.78
SMR External 3.5 Seagate Backup Plus Desktop 8TB 8000 GB 269.00 246.79 0.03 32.42
External 3.5 Western Digital My Book 4TB, USB3 4000 GB 135.00 123.85 0.03 32.30
External 3.5 Western Digital My Book 8TB, USB3 8000 GB 274.00 251.38 0.03 31.82
External 3.5 Western Digital My Book 6TB, USB3 6000 GB 209.00 191.74 0.03 31.29
HDD Western Digital Green 3TB 3000 GB 106.00 97.25 0.03 30.85
HDD Western Digital Green 4TB 4000 GB 148.00 135.78 0.03 29.46
External 3.5 Western Digital My Book 3TB, USB3 3000 GB 115.00 105.50 0.04 28.43
External 3.5 Western Digital Elements Desktop 3TB, USB3 3000 GB 116.00 106.42 0.04 28.19
HDD Western Digital Red 3TB 3000 GB 120.00 110.09 0.04 27.25
HDD Western Digital Red 4TB 4000 GB 165.00 151.38 0.04 26.42
HDD-He Western Digital Red 8TB 8000 GB 339.00 311.01 0.04 25.72
HDD Western Digital Green 2TB 2000 GB 84.80 77.80 0.04 25.71
HDD Western Digital Green 6TB 6000 GB 255.00 233.94 0.04 25.65
HDD Western Digital Red 5TB 5000 GB 214.00 196.33 0.04 25.47
HDD Western Digital Red 6TB 6000 GB 259.00 237.61 0.04 25.25
External 2.5 Western Digital Elements Portable 2TB, USB3 2000 GB 91.00 83.49 0.04 23.96
External 2.5 Western Digital My Passport Ultra 3TB, USB3 3000 GB 142.00 130.28 0.04 23.03
HDD Western Digital Red 2TB 2000 GB 99.00 90.83 0.05 22.02
External 2.5 Western Digital My Passport Ultra 2TB, USB3 2000 GB 99.00 90.83 0.05 22.02
External 2.5 Western Digital Elements Portable 1TB, USB3 1000 GB 64.00 58.72 0.06 17.03
HDD-He Hitachi Ultrastar He6 6TB 6000 GB 436.00 400.00 0.07 15.00
External 2.5 Western Digital My Passport Ultra 1TB, USB3 1000 GB 73.00 66.97 0.07 14.93
Blu-ray Verbatim BD-R SL 10 @ 25GB 250 GB 19.00 17.43 0.07 14.34
HDD-He Hitachi Ultrastar He8 8TB 8000 GB 724.00 664.22 0.08 12.04
DVD-R Verbatim 16x DVD-R 100 @ 4,7GB 470 GB 46.00 42.20 0.09 11.14
Blu-ray Verbatim BD-R DL 10 @ 50GB 500 GB 51.90 47.61 0.10 10.50
DVD+R DL Verbatim 8x DVD+R DL 50 @ 8,5GB 425 GB 71.00 65.14 0.15 6.52
DVD+R DL Verbatim 8x DVD+R DL 25 @ 8,5GB 213 GB 39.00 35.78 0.17 5.94
SSD Crucial BX200 SSD, MLC, 480GB 480 GB 125.00 114.68 0.24 4.19
SSD Crucial BX200 SSD, MLC, 240GB 240 GB 69.10 63.39 0.26 3.79
SSD Crucial MX200 SSD, MLC, 1000GB 1000 GB 288.00 264.22 0.26 3.78
SSD Samsung SSD 850 EVO Basic, TLC, 1TB 1000 GB 299.00 274.31 0.27 3.65
SSD Crucial MX200 SSD, MLC, 500GB 500 GB 155.00 142.20 0.28 3.52
SSD Samsung SSD 850 EVO Basic, TLC, 500GB 500 GB 166.00 152.29 0.30 3.28
SSD Crucial BX100 SSD, MLC, 1000GB 1000 GB 339.00 311.01 0.31 3.22
SSD Crucial BX100 SSD, MLC, 500GB 500 GB 181.00 166.06 0.33 3.01
USB Flash SanDisk Ultra, USB 3.0, 256GB 256 GB 96.90 88.90 0.35 2.88
SSD Samsung SSD 850 EVO Basic, TLC, 250GB 250 GB 99.00 90.83 0.36 2.75
SSD Crucial MX200 SSD, MLC, 250GB 250 GB 99.30 91.10 0.36 2.74
USB Flash SanDisk Cruzer Edge Flash Drive 64GB 64 GB 25.80 23.67 0.37 2.70
SSD Samsung SSD 850 Pro, MLC, 1024GB 1024 GB 436.00 400.00 0.39 2.56
USB Flash SanDisk Ultra, USB 3.0, 64GB 64 GB 28.80 26.42 0.41 2.42
SSD Samsung SSD 850 Pro, MLC, 512GB 512 GB 241.00 221.10 0.43 2.32
CD-R Verbatim CD-R 100 @ 700MB 70 GB 34.50 31.65 0.45 2.21
microSDXC SanDisk Ultra Premium microSDXC 90MB/s, 200GB 200 GB 99.00 90.83 0.45 2.20
SSD Samsung SSD 850 Pro, MLC, 256GB 256 GB 134.00 122.94 0.48 2.08
USB Flash SanDisk Cruzer Edge Flash Drive 32GB 32 GB 17.10 15.69 0.49 2.04
SDXC SanDisk Extreme Pro SDXC UHS-I, Class 10/UHS 3, 95/90MB/s, 256GB 256 GB 144.00 132.11 0.52 1.94
USB Flash SanDisk Ultra, USB 3.0, 32B 32 GB 19.50 17.89 0.56 1.79
SDXC SanDisk Extreme Pro SDXC UHS-I, Class 10/UHS 3, 95/90MB/s, 128GB 128 GB 79.10 72.57 0.57 1.76
SSD Samsung SSD 850 EVO Basic, TLC, 120GB 120 GB 79.00 72.48 0.60 1.66
SSD-NVM-M.2 Samsung SSD 950 Pro, M.2 2280, MLC, 2500/1500MB/s, 512GB 512 GB 359.00 329.36 0.64 1.55
SDXC SanDisk Extreme Pro SDXC UHS-I, Class 10/UHS 3, 95/90MB/s, 512GB 512 GB 371.00 340.37 0.66 1.50
SSD Samsung SSD 850 Pro, MLC, 128GB 128 GB 97.40 89.36 0.70 1.43
SSD-NVM-M.2 Samsung SSD 950 Pro, M.2 2280, MLC, 2200/900MB/s, 256GB 256 GB 195.00 178.90 0.70 1.43
USB Flash SanDisk Cruzer Edge Flash Drive 16GB 16 GB 12.90 11.83 0.74 1.35
microSDXC SanDisk Extreme Pro microSDXC, Class 10, 90/95MB/s, 64GB 64 GB 52.00 47.71 0.75 1.34
SDXC SanDisk Extreme Pro SDXC UHS-I, Class 10/UHS 1, 95/90MB/s, 64GB 64 GB 55.00 50.46 0.79 1.27
SDHC SanDisk Extreme Pro SDHC UHS-I, Class 10/UHS 1, 95/90MB/s, 32GB 32 GB 33.00 30.28 0.95 1.06
Compact Flash SanDisk Extreme 120MB/s, UDMA 7, 64GB 64 GB 75.00 68.81 1.08 0.93
USB Flash SanDisk Cruzer Edge Flash Drive 8GB 8 GB 10.90 10.00 1.25 0.80
Compact Flash SanDisk Extreme Pro 160MB/s, UDMA 7, 128GB 128 GB 175.00 160.55 1.25 0.80
Compact Flash SanDisk Extreme Pro 160MB/s, UDMA 7, 256GB 256 GB 351.00 322.02 1.26 0.79
Compact Flash SanDisk Extreme Pro 160MB/s, UDMA 7, 64GB 64 GB 98.50 90.37 1.41 0.71
Compact Flash SanDisk Extreme 120MB/s, UDMA 7, 32GB 32 GB 52.30 47.98 1.50 0.67
SDHC SanDisk Extreme Pro SDHC UHS-I, Class 10/UHS 1, 95/90MB/s, 16GB 16 GB 27.00 24.77 1.55 0.65
SDXC SanDisk Extreme Pro SDXC UHS-II, UHS 3, 280/250MB/s, 64GB 64 GB 116.00 106.42 1.66 0.60
Compact Flash SanDisk Extreme Pro 160MB/s, UDMA 7, 32GB 32 GB 59.10 54.22 1.69 0.59
SDHC SanDisk Extreme Pro SDHC UHS-II, UHS 3, 280/250MB/s, 32GB 32 GB 75.10 68.90 2.15 0.46
Compact Flash SanDisk Extreme 120MB/s, UDMA 7, 16GB 16 GB 39.20 35.96 2.25 0.44
SDHC SanDisk Extreme Pro SDHC UHS-II, UHS 3, 280/250MB/s, 16GB 16 GB 49.70 45.60 2.85 0.35

Exchange rate: 1 Euro = 1.090000 CHF.

Comments Off

DIY Arduino Debug Shield

Comments Off

Debugging with LEDs; it’s probably even more primitive than debugging with printf statements. However, to get a very immediate feedback on what’s happening, or which pins are in use, it can be useful. So what better way then than a ~$2 homemade shield to pop on top of your existing project.

DealExtreme supplies all the parts needed: A versatile prototyping shield board with holes and wires in sensible locations; a bag of assorted LEDs; resistors; and header pins. (The board and headers in this project used 6x and 8x header pins, to fit with the older Duemilanove. The Uno another other boards have slightly different pin layouts, so plan ahead).

Now, I’m not an expert at soldering, nor product design, but this shield does the job, and already helped in programming my next project. Lesson learnt: Lay out the components all the way before heading off with the iron. I should have gone with the 3mm LEDs all the way. Or, maybe surface mount could have worked. Next time.

Comments Off

Hello World! from the UG-2864 “OEL Display Module” / SSD1306

Comments Off

There is a wide range of cute small OLED (organic LED, aka. Organic Electro-Luminescence) display modules around. Adafruit has a range, the same or similar can also be found all over eBay and Amazon, and of course from DealExtreme. They are available in modules for the Arduino, Raspberry Pi, or other micro controllers. Some are based on basic DATA, CONTROL, LOCK interfaces, while others implement the SPI or I2C bus protocols. The OLED makes for a bright high contrast wide viewing angle screen. Most are monochrome, while a few come with 16 bit colors.

I got the $7 0.96 inch 128*64 pixel I2C version from Deal Extreme. It is indeed small, but also very nice and sharp. Even small fonts are easily readable. It was easy to get up and working with the Arduino UNO, although with a few gotchas to watch out for. The I2C interface makes it very easy to hook up, with only two wires in addition to power (5V and ground).

For background, this GeekOnFire page goes into detail about the memory addressing and low level commands. Further details can be found in the Univision Technology display (UG-2864HLBEG01, UG-2864HSWEG01) and Solomon Systech driver chip (SSD1306) data sheets. See also this note which compares the SPI and I2C protocols.

Scan and Detect

There are also multiple drivers and graphics libraries around, some of which are available directly through the Arduino IDE Library Manager. I’ll go through the details below, but before we get there, make sure the module is hooked up correctly and detected. See the Arduino Wire library reference for which pins to hook up. It varies based on Arduino board and version.

Note, for the Arduino Uno, the pins are Analog 4 and Analog 5.

Once plugged in, copy the sketch from this simple I2C Scanner, and upload. Open the Serial Monitor, and observe something like “I2C device found at address 0x3C“.

Take great care to note the exact address. It might be either 0x3C or 0x3D, and the libraries below will have to be modified accordingly.


The U8glib library supports a long list of different LEDs. It is available directly from within the Arduino IDE Library Manager by searching for “U8glib”. Once installed, open the Examples list, and try the “HelloWorld” example.

However, before uploading, you need to uncomment the correct display. In my case, it was around line 90, and looked like:

U8GLIB_SSD1306_128X64 u8g(U8G_I2C_OPT_NONE|U8G_I2C_OPT_DEV_0); // I2C / TWI

Once uploaded, the display should show “Hello World!”. Also try out the other examples, like the GraphicsTest, but make sure to always uncomment the correct initialization line.


The Adafruit library focuses on the displays they offer, and comes in two parts, the SSD1306 driver and the Adafruit Gfx library. Searching for “Adafruit SSD1306″ and “Adafruit gfx” in the Arduino IDE Library Manager should give perfect hits.

The Adafruit driver and examples take some custom modifications before they work, though. First, in the file Adafruit_SSD1306/Adafruit_SSD1306.h, make sure the following lines are uncommented and correct according to the display you have (see the scanner section above). Make sure the other similar lines above or below are commented out.

#define SSD1306_I2C_ADDRESS 0x3C

#define SSD1306_128_64

Secondly, in the ssd1306_128x64_i2c example sketch, again make sure that the address is defined correctly, according to what the scanner said. Within the setup() method, you will see this line, which you might have to modify:

display.begin(SSD1306_SWITCHCAPVCC, 0x3C);


Finally, the GeekOnFire library is yet another easy wait to get started with the OLED display. It is not available in the Arduino Library Manager, but can just as easily be downloaded from their site, and installed from the Arduino IDE through its ZIP file.

As with the Adafruit library, the I2C address has to be modified, and a similar initialization line can be found within the setup() method of their examples:


Comments Off