1. Computers
  2. Display Drivers
  3. Graphics Cards
  4. Memory
  5. Motherboards
  6. Processors
  7. Software
  8. Storage
  9. Operating Systems


Facebook RSS Twitter Twitter Google Plus


Phoronix Test Suite

OpenBenchmarking.org

UEFI Makes It Easy To Boot Rust Applications

Operating Systems

Published on 20 November 2013 12:16 AM EST
Written by Michael Larabel in Operating Systems
33 Comments

While (U)EFI is frowned upon by many Linux users due to the security disaster known as Secure Boot or other UEFI compatibility problems with running Linux on systems, there are a few benefits.

One of the benefits to UEFI is that it makes it easier to create a bootable application / operating system -- much easier than the BIOS days. Mozilla's Rust programming language can now even be used for booting to such workloads written entirely in the new programming language. Rust is the safe, concurrent language that came out of research at Mozilla and only reached an alpha state in 2012, but is now up to version 0.8 and can host bootable programs.

Eric Holk wrote on his blog about the ease of use in making a bootable system with UEFI. He went on to make a "Hello World" example running off UEFI in this language partially inspired by C.

Eric began his blog post by explaining, "The thing that surprises me most about UEFI is that it now appears possible to boot your machine without ever writing a single line of assembly language. Booting used to require this tedious process of starting out in 16-bit real mode, then transitioning into 32-bit protected mode and then doing it all over again to get into 64-bit mode. UEFI firmwares, on the other hand, will happily load an executable file that you give it and run your code in 64-bit mode from the start. Your startup function receives a pointer to some functions that give you basic console support, as well as an API to access richer features."

Check out his application to learn more about booting with UEFI or the example Rust program that's hosted on GitHub as Boot2Rust.

About The Author
Michael Larabel is the principal author of Phoronix.com and founded the web-site in 2004 with a focus on enriching the Linux hardware experience and being the largest web-site devoted to Linux hardware reviews, particularly for products relevant to Linux gamers and enthusiasts but also commonly reviewing servers/workstations and embedded Linux devices. Michael has written more than 10,000 articles covering the state of Linux hardware support, Linux performance, graphics hardware drivers, and other topics. Michael is also the lead developer of the Phoronix Test Suite, Phoromatic, and OpenBenchmarking.org automated testing software. He can be followed via and or contacted via .
Latest Articles & Reviews
  1. Khronos Group Announces Vulkan, OpenCL 2.1, SPIR-V
  2. Samsung 850 EVO SSD Linux Benchmarks
  3. Kubuntu 15.04 Is Turning Out Quite Nice, Good Way To Try Out The Latest KDE
  4. 5-Way Linux Distribution Comparison On The Core i3 NUC
  5. OCZ ARC 100 Linux SSD Benchmarks
  6. Lenovo ThinkPad X1 Carbon Works Great As A Linux Ultrabook
Latest Linux News
  1. NVIDIA Announces Shield Set-Top Gaming Box
  2. Valve Launches $49 Steam Link, SteamOS-Powered Streaming Device
  3. Valve Announces Source 2, It's Going To Be Free To Content Developers
  4. Gitorious Gets Acquired By GitLab
  5. Unity 5.0 Brings PhysX 3.3, WebGL Preview, Animation System Work
  6. Linux 4.0-rc2 Kernel Released After Delay Due To Intel DRM Driver
  7. Linux 3.19 Officially Lands For Ubuntu 15.04
  8. Clutter Now Supports Quad-Buffer Stereo Displays, Mir Backend
  9. Pricing Details On The Alleged MJ Ubuntu Tablet Design
  10. Understanding The Linux Kernel's BPF In-Kernel Virtual Machine
Most Viewed News This Week
  1. More Proof That Allwinner Is Violating The GPL
  2. The Tremendous Features Of Fedora 22
  3. Krita 2.9 Released, Their Biggest Release Ever
  4. A Single UEFI Executable With The Linux Kernel, Initrd & Command Line
  5. Xfce 4.12 Released After Nearly Three Years Of Work
  6. LLVM 3.6 & Clang 3.6 Deliver More Features, Complete C++14 Support
  7. Firefox 36 Brings Full HTTP/2 Support
  8. ALSA 1.0.29 Released
%%CLICK_URL_UNESC%%