-
Notifications
You must be signed in to change notification settings - Fork 93
/
Dockerfile
166 lines (155 loc) · 6.61 KB
/
Dockerfile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
###
# STM32F4-Discovery Build and Test Environment Dockerfile
#
# VERSION 1.1.0
# DOCKER_VERSION 1.1.2
# AUTHOR Iztok Starc <i****.s****@gmail.com>
# DESCRIPTION This Dockerfile is used to build and test Environment for the STM32F4-Discovery board.
# The Dockerfile is based on the ubuntu 14.04 LTS image from the official repository.
#
# More info:
# - http://istarc.wordpress.com/
# - https://github.com/istarc/stm32
# - https://registry.hub.docker.com/u/istarc/stm32/
###
# Usage
#
#
#
# I provide already built image based on this Dockerfile and you may pull it from the repository (1).
# Alternatively, you may use this Dockerfile to build the image yourself (2).
#
#
#
# 1. Pull the image from the repository
#
# 1.1 Prerequisites:
#
# docker --version
# Docker version 1.1.0 # Issues with version < 1.1.0
# # Install Docker by following instructions at https://docs.docker.com/
#
# 1.2 Basic Usage:
#
# sudo docker pull istarc/stm32
# CONTAINER_ID=$(sudo docker run -P -d --privileged=true istarc/stm32)
# # Other run options:
# # CONTAINER_ID=$(sudo docker run -P -d istarc/stm32) # /wo deploy capability
# # sudo docker run -P -i -t istarc/stm32 /bin/bash # Interactive mode
# sudo docker stop $CONTAINER_ID
# # Stop and remove all containers
# # sudo docker stop $(sudo docker ps -a -q)
# # sudo docker rm $(sudo docker ps -a -q)
# # Remove all untagged images
# # sudo docker rmi $(sudo docker images | grep "^<none>" | awk '{print $3}')
#
# 1.3 Build Existing Projects:
#
# ssh -p $(sudo docker port $CONTAINER_ID 22 | cut -d ':' -f2) admin@localhost
# Enter password: admin
# cd ~/stm32/
# make clean
# make -j4
#
# 1.4 Deploy Existing Project:
#
# ssh -p $(sudo docker port $CONTAINER_ID 22 | cut -d ':' -f2) admin@localhost
# Enter password: admin
# cd ~/stm32/examples/Template.mbed
# make clean
# make -j4
# sudo make deploy
#
# 1.5 Test Build Existing Projects via Buildbot:
#
# firefox http://localhost:$(sudo docker port $CONTAINER_ID 8010 | cut -d ':' -f2)
# Login U: admin P: admin (Upper right corner)
# Click: Waterfall -> test-build-local -> [Use default options] -> Force Build
# # Test builds examples in /home/admin/stm32/examples
# Click: Waterfall -> test-build-repo -> [Use default options] -> Force Build
# # Test builds examples from the https://github.com/istarc/stm32.git repository
# Check: Waterfall -> F5 to Refresh
#
# 1.6 More info:
# - http://istarc.wordpress.com
# - https://github.com/istarc/stm32
#
#
#
# 2. Build the image
#
# This is alternative to "1. Pull the image from the repository".
#
# 2.1 Prerequisites:
#
# docker --version
# Docker version 1.1.0 # Issues with version < 1.1.0
# # Install Docker by following instructions at https://docs.docker.com/
#
# 2.2 Install software dependencies
#
# cd ~
# sudo docker pull ubuntu
# wget https://raw.githubusercontent.com/istarc/stm32/master/Dockerfile
#
# 2.3 Build the image
#
# sudo docker build -t istarc/stm32 - < Dockerfile
#
# 2.4 Usage: see 1.2 - 1.6
###
# Docker script
#
# 1. Initial docker image
from ubuntu:14.04
# 2. Install dependancies
# 2.1 Install platform dependancies
run export DEBIAN_FRONTEND=noninteractive
run sudo mv /etc/apt/sources.list /etc/apt/sources.list.old
run sudo echo 'deb mirror://mirrors.ubuntu.com/mirrors.txt trusty main restricted universe multiverse' >> /etc/apt/sources.list
run sudo echo 'deb mirror://mirrors.ubuntu.com/mirrors.txt trusty-updates main restricted universe multiverse' >> /etc/apt/sources.list
run sudo echo 'deb mirror://mirrors.ubuntu.com/mirrors.txt trusty-backports main restricted universe multiverse' >> /etc/apt/sources.list
run sudo echo 'deb mirror://mirrors.ubuntu.com/mirrors.txt trusty-security main restricted universe multiverse' >> /etc/apt/sources.list
run sudo apt-get update -q
run sudo apt-get install -y supervisor sudo ssh openssh-server software-properties-common vim wget openssl
# The above is required to execute add-apt-repository
run sudo add-apt-repository -y ppa:terry.guo/gcc-arm-embedded
run sudo apt-get update -q
# 2.2 Install project dependancies
# 2.2.1 GCC ARM
run sudo apt-cache policy gcc-arm-none-eabi
run sudo apt-get install -y build-essential git openocd gcc-arm-none-eabi qemu-system-arm symlinks expect
# 2.2.2 Buildbot
run sudo apt-get install -y buildbot buildbot-slave
# 2.2.3 OpenOCD build dependancies
run sudo apt-get install -y libtool libftdi-dev libusb-1.0-0-dev automake pkg-config texinfo
# 2.2.4 Clone and init stm32 repository
run mkdir -p /home/admin
run cd /home/admin; git clone https://github.com/istarc/stm32.git # --depth 1
run cd /home/admin/stm32; git submodule update --init # --depth 1
# 3. Add user admin with password "admin"
run useradd -s /bin/bash -m -d /home/admin -p $(openssl passwd -1 admin) admin
run sed -Ei 's/adm:x:4:/admin:x:4:admin/' /etc/group
run sed -Ei 's/(\%admin ALL=\(ALL\) )ALL/\1 NOPASSWD:ALL/' /etc/sudoers
# 4. Setup ssh server
run mkdir -p /var/run/sshd
run /bin/echo -e "[program:sshd]\ncommand=/usr/sbin/sshd -D\n" > /etc/supervisor/conf.d/sshd.conf
expose 22
# 5. Setup buildbot master and workers
run mkdir -p /home/admin/stm32bb
run buildbot create-master /home/admin/stm32bb/master
run cp /home/admin/stm32/test/buildbot/master/master.cfg /home/admin/stm32bb/master/master.cfg
run buildslave create-slave /home/admin/stm32bb/slave localhost:9989 arm-none-eabi pass-MonkipofPaj1
run /bin/echo -e "[program:buildmaster]\ncommand=twistd --nodaemon --no_save -y buildbot.tac\ndirectory=/home/admin/stm32bb/master\nuser=admin\n" > /etc/supervisor/conf.d/buildbot.conf
run /bin/echo -e "[program:buildworker]\ncommand=twistd --nodaemon --no_save -y buildbot.tac\ndirectory=/home/admin/stm32bb/slave\nuser=admin\n" >> /etc/supervisor/conf.d/buildbot.conf
expose 8010
# 6. Build & Install OpenOCD from repository
# run cd /home/admin; git clone git://openocd.git.sourceforge.net/gitroot/openocd/openocd # Not Reliable
run cd /home/admin; git clone --depth 1 https://github.com/ntfreak/openocd.git
run cd /home/admin/openocd; ./bootstrap; ./configure --enable-maintainer-mode --disable-option-checking --disable-werror --prefix=/opt/openocd --enable-dummy --enable-usb_blaster_libftdi --enable-ep93xx --enable-at91rm9200 --enable-presto_libftdi --enable-usbprog --enable-jlink --enable-vsllink --enable-rlink --enable-stlink --enable-arm-jtag-ew; make; make install
# 7. Post-install
# 7.1 Setup folder & file privileges
run chown -R admin:admin /home/admin
run chmod o+rx /home
# 7.2 Commands to be executed when docker container starts
cmd ["/usr/bin/supervisord", "-n"]