c201.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1">
  6. <style type="text/css">
  7. @import url('../css/main.css');
  8. </style>
  9. <title>ASUS Chromebook C201</title>
  10. </head>
  11. <body>
  12. <div class="section">
  13. <h1 id="pagetop">ASUS Chromebook C201</h1>
  14. <p>
  15. This is a Chromebook, using the Rockchip RK3288 SoC. It uses
  16. an ARM CPU, and has free EC firmware (unlike some other laptops).
  17. More RK3288-based laptops will be added to libreboot at a later date.
  18. </p>
  19. <p>
  20. Paul Kocialkowski, a <a href="http://www.replicant.us/">Replicant</a> developer, ported this laptop to libreboot. Thank you, Paul!
  21. </p>
  22. <p>
  23. <b>More info will be added later, including build/installation instructions.
  24. The board is supported in libreboot, however, and has been confirmed to work.</b>
  25. </p>
  26. <p>
  27. Flashing instructions can be found at <a href="../install/index.html#flashrom">../install/index.html#flashrom</a>
  28. </p>
  29. <p>
  30. <a href="index.html">Back to previous index</a>.
  31. </p>
  32. </div>
  33. <div class="section">
  34. <ul>
  35. <li><a href="#googlesintent">Google's intent with CrOS devices</a></li>
  36. <li><a href="#os">Considerations about ChromeOS and free operating systems</a></li>
  37. <li><a href="#videoblobs">Caution: Video acceleration requires a non-free blob, software rendering can be used instead.</a></li>
  38. <li><a href="#wifiblobs">Caution: WiFi requires a non-free blob, a USB dongle can be used instead.</a></li>
  39. <li><a href="#ec">EC firmware is free software!</a></li>
  40. <li><a href="#microcode">No microcode!</a></li>
  41. <li><a href="#depthcharge">Depthcharge payload</a></li>
  42. <li><a href="#thescrew">Flash chip write protection: the screw</a></li>
  43. </ul>
  44. </div>
  45. <div class="section">
  46. <h1 id="googlesintent">Google's intent with CrOS devices</h1>
  47. <p>
  48. CrOS (Chromium OS/Chrome OS) devices, such as Chromebooks, were not designed with the intent of bringing more freedom to users.
  49. However, they run with a lot of free software at the boot software and embedded controller levels,
  50. since free software gives Google enough flexibility to optimize various aspects such as boot time
  51. and most importantly, to implement the CrOS security system, that involves various aspects of the software.
  52. Google does hire a lot of Coreboot developers, who are generally friendly to the free software movement
  53. and try to be good members of the free software community, by contributing code back.
  54. </p>
  55. <p>
  56. CrOS devices are designed (from the factory) to actually coax the user into using
  57. <a href="https://www.gnu.org/philosophy/who-does-that-server-really-serve.en.html">proprietary web services</a>
  58. (SaaSS) that invade the user's privacy (ChromeOS is literally just the Google Chrome browser when you boot up, itself proprietary
  59. and comes with proprietary add-ons like flash. It's only intended for SaaSS, not actual, real computing).
  60. Google is even a member of the <i>PRISM</i> program, as outlined
  61. by Edward Snowden. See notes about ChromeOS below. The libreboot project recommends
  62. that the user replace the default <i>ChromeOS</i> with a distribution that can be used in freedom,
  63. without invading the user's privacy.
  64. </p>
  65. <p>
  66. We also use a similar argument for the MacBook and the ThinkPads that are supported in libreboot.
  67. Those laptops are supported, in spite of Apple and Lenovo, companies which are actually <i>hostile</i>
  68. to the free software movement.
  69. </p>
  70. <p>
  71. <a href="#pagetop">Back to top of page</a>.
  72. </p>
  73. </div>
  74. <div class="section">
  75. <h1 id="os">Considerations about ChromeOS and free operating systems</h1>
  76. <p>
  77. This laptop comes preinstalled (from the factory) with Google ChromeOS. This is a GNU/Linux distribution, but it's not general purpose
  78. and it comes with proprietary software. It's designed for <i><a href="https://www.gnu.org/philosophy/who-does-that-server-really-serve.en.html">SaaSS</a></i>. Libreboot recommends that users of this laptop replace it with another distribution.
  79. </p>
  80. <h2>FSF endorsed distros</h2>
  81. <p>
  82. The FSF has a <a href="https://www.gnu.org/distros/free-distros.html">list of distributions</a> that are 100% free software.
  83. Only one of them is confirmed to work on ARM CrOS devices. Parabola looks hopeful: <a href="https://www.parabola.nu/news/parabola-supports-armv7/">https://www.parabola.nu/news/parabola-supports-armv7/</a>.
  84. </p>
  85. <p>
  86. The libreboot project would like to see all FSF-endorsed distro projects port to these laptops. This includes Trisquel, GuixSD and others.
  87. And ProteanOS. Maybe even LibreCMC. The more the merrier. We need them, badly.
  88. </p>
  89. <p>
  90. <b>We need these distributions to be ported as soon as possible.</b>
  91. </p>
  92. <p>
  93. <a href="#pagetop">Back to top of page</a>.
  94. </p>
  95. </div>
  96. <div class="section">
  97. <h1 id="videoblobs">Caution: Video acceleration requires a non-free blob, software rendering can be used instead.</h1>
  98. <p>
  99. The Tamil driver source code for the onboard Mali T GPU is not released. The developer has so-far withheld it. Until that is released, the only way to use video (in freedom) on this laptop is to not have video acceleration, by making sure not to install the relevant blob. Most tasks can still be performed without video acceleration, without any noticeable performance penalty.
  100. </p>
  101. <p>
  102. In practise, this means that certain things like games, blender and GNOME shell (or other fancy desktops) won't work well.
  103. The libreboot project recommends a lightweight desktop which does not need video acceleration, such as <i>XFCE</i> or <i>LXDE</i>.
  104. </p>
  105. <p>
  106. The Tamil developer wrote this blog post, which sheds light on the story: <a href="http://libv.livejournal.com/27461.html">http://libv.livejournal.com/27461.html,http://libv.livejournal.com/27461.html</a>.
  107. </p>
  108. <p>
  109. <a href="#pagetop">Back to top of page</a>.
  110. </p>
  111. </div>
  112. <div class="section">
  113. <h1 id="wifiblobs">Caution: WiFi requires a non-free blob, a USB dongle can be used instead.</h1>
  114. <p>
  115. These laptops have non-removeable (soldered on) WiFi chips, which require non-free firmware in the Linux kernel
  116. in order to work.
  117. </p>
  118. <p>
  119. The libreboot project recommends using an external USB wifi dongle that works
  120. with free software. See <a href="index.html#recommended_wifi">index.html#recommended_wifi</a>.
  121. </p>
  122. <p>
  123. There are 2 companies (endorsed by the Free Software Foundation, under their <i>Respects your Freedom</i>
  124. guidelines), that sell USB WiFi dongles guaranteed to work with free software (i.e. linux-libre kernel):
  125. </p>
  126. <ul>
  127. <li><a href="https://www.thinkpenguin.com/gnu-linux/penguin-wireless-n-usb-adapter-gnu-linux-tpe-n150usb">ThinkPenguin sells them</a> (company based in USA)</li>
  128. <li><a href="https://tehnoetic.com/tehnoetic-wireless-adapter-gnu-linux-libre-tet-n150">Tehnoetic sells them</a> (company based in Europe)</li>
  129. </ul>
  130. <p>
  131. These wifi dongles use the AR9271 (atheros) chipset, supported by
  132. the free <i>ath9k_htc</i> driver in the Linux kernel. They work in <i>linux-libre</i> too.
  133. </p>
  134. </div>
  135. <div class="section">
  136. <h1 id="ec">EC firmware is free software!</h1>
  137. <p>
  138. It's free software. Google provides the source. Build scripts will be added later, with EC sources
  139. provided in libreboot, and builds of the EC firmware.
  140. </p>
  141. <p>
  142. This is unlike the other current libreboot laptops (Intel based). In practise, you can
  143. (if you do without the video/wifi blobs, and replace ChromeOS with a distribution
  144. that respects your freedom) be more free when using one of these laptops.
  145. </p>
  146. <p>
  147. The libreboot FAQ briefly describes what an <i>EC</i> is:
  148. <a href="http://libreboot.org/faq/#firmware-ec">http://libreboot.org/faq/#firmware-ec</a>
  149. </p>
  150. </div>
  151. <div class="section">
  152. <h1 id="microcode">No microcode!</h1>
  153. <p>
  154. Unlike x86 (e.g. Intel/AMD) CPUs, ARM CPUs do not use microcode, not even built in.
  155. On the Intel/AMD based libreboot systems, there is still microcode in the CPU
  156. (not considered problematic by the FSF, provided that it is reasonably trusted
  157. to not be malicious, since it's part of the hardware and read-only), but we
  158. exclude microcode updates (volatile updates which are uploaded at boot time by the boot firmware,
  159. if present), which are proprietary software.
  160. </p>
  161. <p>
  162. On ARM CPUs, the instruction set is implemented in circuitry, without microcode.
  163. </p>
  164. <p>
  165. <a href="#pagetop">Back to top of page</a>.
  166. </p>
  167. </div>
  168. <div class="section">
  169. <h1 id="depthcharge">Depthcharge payload</h1>
  170. <p>
  171. These systems do not use the GRUB payload. Instead, they use a payload called depthcharge,
  172. which is common on CrOS devices. This is free software, maintained by Google.
  173. </p>
  174. </div>
  175. <div class="section">
  176. <h1 id="thescrew">Flash chip write protection: the screw</h1>
  177. <p>
  178. It's next to the flash chip. Unscrew it, and the flash chip is read-write. Screw it back in, and the flash chip is read-only.
  179. It's called the screw.
  180. </p>
  181. <p>
  182. <i>The screw</i> is accessible by removing other screws and gently prying off the upper shell, where the flash chip and the screw
  183. are then directly accessible. User flashing from software is possible, without having to externally re-flash, but the flash chip
  184. is SPI (SOIC-8 form factor) so you can also externally re-flash if you want to. In practise, you only need to externally re-flash
  185. if you brick the laptop; read <a href="../install/bbb_setup.html">../install/bbb_setup.html</a> for an example of how to set up
  186. an SPI programmer.
  187. </p>
  188. <p>
  189. Write protection is useful, because it prevents the firmware from being re-flashed by any malicious software that
  190. might become executed on your GNU/Linux system, as root. In other words, it can prevent a firmware-level <i>evil maid</i> attack. It's
  191. possible to write protect on all current libreboot systems, but CrOS devices make it easy. The screw is such a stupidly
  192. simple idea, which all designs should implement.
  193. </p>
  194. </div>
  195. <div class="section">
  196. <p>
  197. Copyright &copy; 2015 Leah Rowe &lt;info@minifree.org&gt;<br/>
  198. Permission is granted to copy, distribute and/or modify this document
  199. under the terms of the GNU Free Documentation License, Version 1.3
  200. or any later version published by the Free Software Foundation;
  201. with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts.
  202. A copy of the license can be found at <a href="../gfdl-1.3.txt">../gfdl-1.3.txt</a>
  203. </p>
  204. <p>
  205. Updated versions of the license (when available) can be found at
  206. <a href="https://www.gnu.org/licenses/licenses.html">https://www.gnu.org/licenses/licenses.html</a>
  207. </p>
  208. <p>
  209. UNLESS OTHERWISE SEPARATELY UNDERTAKEN BY THE LICENSOR, TO THE
  210. EXTENT POSSIBLE, THE LICENSOR OFFERS THE LICENSED MATERIAL AS-IS
  211. AND AS-AVAILABLE, AND MAKES NO REPRESENTATIONS OR WARRANTIES OF
  212. ANY KIND CONCERNING THE LICENSED MATERIAL, WHETHER EXPRESS,
  213. IMPLIED, STATUTORY, OR OTHER. THIS INCLUDES, WITHOUT LIMITATION,
  214. WARRANTIES OF TITLE, MERCHANTABILITY, FITNESS FOR A PARTICULAR
  215. PURPOSE, NON-INFRINGEMENT, ABSENCE OF LATENT OR OTHER DEFECTS,
  216. ACCURACY, OR THE PRESENCE OR ABSENCE OF ERRORS, WHETHER OR NOT
  217. KNOWN OR DISCOVERABLE. WHERE DISCLAIMERS OF WARRANTIES ARE NOT
  218. ALLOWED IN FULL OR IN PART, THIS DISCLAIMER MAY NOT APPLY TO YOU.
  219. </p>
  220. <p>
  221. TO THE EXTENT POSSIBLE, IN NO EVENT WILL THE LICENSOR BE LIABLE
  222. TO YOU ON ANY LEGAL THEORY (INCLUDING, WITHOUT LIMITATION,
  223. NEGLIGENCE) OR OTHERWISE FOR ANY DIRECT, SPECIAL, INDIRECT,
  224. INCIDENTAL, CONSEQUENTIAL, PUNITIVE, EXEMPLARY, OR OTHER LOSSES,
  225. COSTS, EXPENSES, OR DAMAGES ARISING OUT OF THIS PUBLIC LICENSE OR
  226. USE OF THE LICENSED MATERIAL, EVEN IF THE LICENSOR HAS BEEN
  227. ADVISED OF THE POSSIBILITY OF SUCH LOSSES, COSTS, EXPENSES, OR
  228. DAMAGES. WHERE A LIMITATION OF LIABILITY IS NOT ALLOWED IN FULL OR
  229. IN PART, THIS LIMITATION MAY NOT APPLY TO YOU.
  230. </p>
  231. <p>
  232. The disclaimer of warranties and limitation of liability provided
  233. above shall be interpreted in a manner that, to the extent
  234. possible, most closely approximates an absolute disclaimer and
  235. waiver of all liability.
  236. </p>
  237. </div>
  238. </body>
  239. </html>