The hacking of consumer electronics is a common practice that users perform to customize and modify their devices beyond what is typically possible. This activity has a long history, dating from the days of early computer, programming, and electronics hobbyists.
A notable case of the hacking of consumer electronics is jailbreaking of iOS devices or the rooting of Android phones, although many other electronics such as video game consoles are regularly hacked. While these methods allow unrestricted modification of an existing operating system installation, some third-party operating systems have been developed as a replacement to a device's default OS, such as Replicant and postmarketOS on cellphones, or DD-WRT and tomato on routers.
The process of consumer electronics hacking is usually accomplished through modification of the system software, either an operating system or firmware, but hardware modifications are not uncommon.
The legality of hacking consumer electronics has been challenged over the years, with an example of this being the cracking of encryption keys used in High-bandwidth Digital Content Protection, where detractors have been threatened under the basis of legal action. However, some companies have encouraged hardware hacking, such as Google's Nexus and Pixel series of smartphones.
Overview
Many modern consumer electronics run either an operating system or firmware. When this is stored in a mutable storage device, these files can be modified to add functionality to the operating system, or to replace it entirely.
Method
Multiple methods are used in order to successfully hack the target device, such as gaining shell access, gathering information about the device hardware and software, before using the obtained information to manipulate the operating system.[1]
Shell access
Getting access to a shell allows the user to run commands to interact with the operating system. Typically, a root shell is aimed for, which grants administrative privileges, to let the user modify operating system files.
On some Android devices, the bootloader is locked for security to prevent installation of other operating systems.[2] Unlocking it is required before another OS can be installed.
On Android devices, Fastboot (Odin mode on Samsung devices) allows flashing of operating systems onto storage.[3]
Das U-Boot is a bootloader commonly used in embedded devices such as routers and Chromebooks.
Getting information
Getting information on the device's hardware and software is vital because exploits can be identified, which is subsequently used to either gain shell access, port an operating system to the device, etc.
Manufacturer use of open source software
A lot of device manufacturers include open source software in their products.[4] When the software used is licensed under a copyleft license, a manufacturer is obliged to provide the source code of the open source components. An instance of this was when Naomi Wu requested the GPLv2 licensed source code of the Linux Kernel branch of a smartphone vendor.[5]
A good share of consumer devices run on a modified Linux kernel,[4] which is forked before applying device-specific changes.[6] Android is an example of OS which makes use of the Linux kernel.
Countermeasures
Device manufacturers often include countermeasures to hinder hardware hacking, one of which is the use of cryptography to prevent unauthorized code from being executed. For example, Nvidia graphics cards have signed firmware to prevent tampering or hacking.
Game consoles are often restricted in a way that may disallow unofficial games to be run on it (see Video game console § Licensing), and hacking is undertaken to allow unlicensed games to run on it, including pirated games.
Another reason is to allow features to be added, such as using the console as a multimedia player. An example of this is Xbox Media Player, which was made to allow pictures and movies to be shown on an Xbox.
Many wireless routers' firmware upgrade functions are not limited to accepting updates that have been signed by the device's manufacturer. As a result, open-source firmware replacements have been created for many devices, such as OpenWrt and DD-WRT.
Legality
iOS jailbreaking was often considered illegal in the United States until a recent[when?] ruling by the U.S. Copyright Office declaring that jailbreaking an iPhone or other mobile device would no longer violate copyright law.[17] However, simultaneously, there is ongoing prosecution against hackers of videogame consoles under anti-circumvention violations of the DMCA. A main complication, in many cases, is the profiting from selling jailbroken or rooted equipment as a value-added service. At least some accused deny these charges and claim only to be making back-ups of legally purchased games.[18][19]
In around 2010, the High-bandwidth Digital Content Protection encryption system, which encrypts data running between cable boxes, Blu-ray players, and other similar devices and displays was cracked, and a copy of the master key needed to decrypt HDCP protected streams was posted on the internet. Intel, which created and now licenses HDCP technology, has stated that HDCP is sufficient to keep most users from circumventing it, but indicated that it may threaten legal action against more determined users under the DMCA.[20]
Also in around 2010, on the issue of the hacking of its then new interactive game controller the Kinect, Microsoft initially condemned and threatened legal action against those who hacked it, but soon after, it reversed this position and instead stated that it had intentionally left the device open, and would in fact not prosecute those who modified it.[21]
^Paul, Matthias R. (2016-06-28) [2016-05-31]. "Casio College fx-80: which IC hides inside?". MoHPC - The Museum of HP Calculators. Archived from the original on 2023-08-11. Retrieved 2023-08-11. […] I own a modified Casio fx-180P with hyperbolic functions retrofitted. […] Comparing the functions of my fx-180P calculator with a friend's [fx-3500P or fx-3600P], I realized that although both calculators looked completely different and had a rather different keyboard arrangement, the functional assignments for each of the keys were the same. My fx-180P lacked a "hyp" key and the corresponding six functions […] This observation made me open the cases and […] reverse-engineer the PCB traces between the controller and the keyboard matrix, and add two wires to emulate the "missing" key […] I retrofitted a push button in a corner […] at the top of the case […]