diff options
author | Vencislav Atanasov <user890104@freemyipod.org> | 2017-05-01 22:57:01 +0300 |
---|---|---|
committer | Franklin Wei <git@fwei.tk> | 2019-07-26 20:20:07 -0400 |
commit | 321de68b216400d3542e34d9c64c4aa261e60341 (patch) | |
tree | eb56fac2d60ee1e3b2ddd7a1b32f0a9e94be5807 /tools/Vagrantfile | |
parent | 4e357167b5b92bbdf152c9c04e2620c134165bc5 (diff) | |
download | rockbox-321de68b216400d3542e34d9c64c4aa261e60341.tar.gz rockbox-321de68b216400d3542e34d9c64c4aa261e60341.zip |
Add Vagrant configuration for creating a development VM
Vagrant is an application that automates creation and provisioning of a virtual
machine for development. The config here creates an Ubuntu 16.04 LTS machine,
updates it, downloads and installs the toolchains for sh, m68k and arm,
mingw-w64, SDL (for Windows simulators) and other packages needed for building
Rockbox.
It works fine for building a Windows simulator and compiling iPod classic
binaries. It should be possible to make the other build types, too.
MIPS toolchain fails to build, ARM-APP is not tested because the files download
very slow on my connection. Please test if it works for you, and let me know.
Quick start: download and install Vagrant and VirtualBox for your operating
system, make sure VT-x / AMD-V is enabled in your BIOS/EFI setup, open a
shell in rockbox/tools and input the command "vagrant up"
Change-Id: Ief5476ab066663a4db7e85404b25d2d781d90532
Diffstat (limited to 'tools/Vagrantfile')
-rw-r--r-- | tools/Vagrantfile | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/tools/Vagrantfile b/tools/Vagrantfile new file mode 100644 index 0000000000..18f4e22cc9 --- /dev/null +++ b/tools/Vagrantfile | |||
@@ -0,0 +1,90 @@ | |||
1 | # -*- mode: ruby -*- | ||
2 | # vi: set ft=ruby : | ||
3 | |||
4 | # All Vagrant configuration is done below. The "2" in Vagrant.configure | ||
5 | # configures the configuration version (we support older styles for | ||
6 | # backwards compatibility). Please don't change it unless you know what | ||
7 | # you're doing. | ||
8 | Vagrant.configure("2") do |config| | ||
9 | # The most common configuration options are documented and commented below. | ||
10 | # For a complete reference, please see the online documentation at | ||
11 | # https://docs.vagrantup.com. | ||
12 | |||
13 | # Every Vagrant development environment requires a box. You can search for | ||
14 | # boxes at https://atlas.hashicorp.com/search. | ||
15 | config.vm.box = "ubuntu/xenial64" | ||
16 | |||
17 | # Disable automatic box update checking. If you disable this, then | ||
18 | # boxes will only be checked for updates when the user runs | ||
19 | # `vagrant box outdated`. This is not recommended. | ||
20 | # config.vm.box_check_update = false | ||
21 | |||
22 | # Create a forwarded port mapping which allows access to a specific port | ||
23 | # within the machine from a port on the host machine. In the example below, | ||
24 | # accessing "localhost:8080" will access port 80 on the guest machine. | ||
25 | # config.vm.network "forwarded_port", guest: 80, host: 8080 | ||
26 | |||
27 | # Create a private network, which allows host-only access to the machine | ||
28 | # using a specific IP. | ||
29 | # config.vm.network "private_network", ip: "192.168.33.10" | ||
30 | |||
31 | # Create a public network, which generally matched to bridged network. | ||
32 | # Bridged networks make the machine appear as another physical device on | ||
33 | # your network. | ||
34 | # config.vm.network "public_network" | ||
35 | |||
36 | # Share an additional folder to the guest VM. The first argument is | ||
37 | # the path on the host to the actual folder. The second argument is | ||
38 | # the path on the guest to mount the folder. And the optional third | ||
39 | # argument is a set of non-required options. | ||
40 | # config.vm.synced_folder "../data", "/vagrant_data" | ||
41 | config.vm.synced_folder "..", "/rockbox" | ||
42 | |||
43 | # Provider-specific configuration so you can fine-tune various | ||
44 | # backing providers for Vagrant. These expose provider-specific options. | ||
45 | # Example for VirtualBox: | ||
46 | # | ||
47 | config.vm.provider "virtualbox" do |vb| | ||
48 | # # Display the VirtualBox GUI when booting the machine | ||
49 | # vb.gui = true | ||
50 | # | ||
51 | # # Customize the amount of memory on the VM: | ||
52 | # vb.memory = "1024" | ||
53 | vb.name = "rockbox-dev" | ||
54 | end | ||
55 | # | ||
56 | # View the documentation for the provider you are using for more | ||
57 | # information on available options. | ||
58 | |||
59 | # Define a Vagrant Push strategy for pushing to Atlas. Other push strategies | ||
60 | # such as FTP and Heroku are also available. See the documentation at | ||
61 | # https://docs.vagrantup.com/v2/push/atlas.html for more information. | ||
62 | # config.push.define "atlas" do |push| | ||
63 | # push.app = "YOUR_ATLAS_USERNAME/YOUR_APPLICATION_NAME" | ||
64 | # end | ||
65 | |||
66 | # Enable provisioning with a shell script. Additional provisioners such as | ||
67 | # Puppet, Chef, Ansible, Salt, and Docker are also available. Please see the | ||
68 | # documentation for more information about their specific syntax and use. | ||
69 | # config.vm.provision "shell", inline: <<-SHELL | ||
70 | # apt-get update | ||
71 | # apt-get install -y apache2 | ||
72 | # SHELL | ||
73 | config.vm.provision "shell" do |s| | ||
74 | s.name = "provision" | ||
75 | s.inline = "/rockbox/tools/vagrant/provision.sh" | ||
76 | end | ||
77 | |||
78 | config.vm.provision "shell", privileged: false do |s| | ||
79 | s.name = "provision-nonprivileged" | ||
80 | s.inline = "/rockbox/tools/vagrant/provision-nonprivileged.sh" | ||
81 | end | ||
82 | |||
83 | config.vm.provision "shell", run: "always" do |s| | ||
84 | s.name = "startup" | ||
85 | s.inline = "/rockbox/tools/vagrant/startup.sh" | ||
86 | end | ||
87 | |||
88 | # Other options | ||
89 | config.vm.hostname = "rockbox-dev" | ||
90 | end | ||