# Blog OS (VGA Text Mode) [![Build Status](https://github.com/phil-opp/blog_os/workflows/Build%20Code/badge.svg?branch=post-03)](https://github.com/phil-opp/blog_os/actions?query=workflow%3A%22Build+Code%22+branch%3Apost-03) This repository contains the source code for the [VGA Text Mode][post] post of the [Writing an OS in Rust](https://os.phil-opp.com) series. [post]: https://os.phil-opp.com/vga-text-mode/ **Check out the [master branch](https://github.com/phil-opp/blog_os) for more information.** ## Building This project requires a nightly version of Rust because it uses some unstable features. At least nightly _2020-07-15_ is required for building. You might need to run `rustup update nightly --force` to update to the latest nightly even if some components such as `rustfmt` are missing it. You can build the project by running: ``` cargo build ``` To create a bootable disk image from the compiled kernel, you need to install the [`bootimage`] tool: [`bootimage`]: https://github.com/rust-osdev/bootimage ``` cargo install bootimage ``` After installing, you can create the bootable disk image by running: ``` cargo bootimage ``` This creates a bootable disk image in the `target/x86_64-blog_os/debug` directory. Please file an issue if you have any problems. ## Running You can run the disk image in [QEMU] through: [QEMU]: https://www.qemu.org/ ``` cargo run ``` [QEMU] and the [`bootimage`] tool need to be installed for this. You can also write the image to an USB stick for booting it on a real machine. On Linux, the command for this is: ``` dd if=target/x86_64-blog_os/debug/bootimage-blog_os.bin of=/dev/sdX && sync ``` Where `sdX` is the device name of your USB stick. **Be careful** to choose the correct device name, because everything on that device is overwritten. ## License Licensed under either of - Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) - MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) at your option. Note that this only applies to this git branch, other branches might be licensed differently. ### Contribution Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.