Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

merge with master #10

Merged
merged 121 commits into from
Aug 22, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
121 commits
Select commit Hold shift + click to select a range
7aefa18
Download newer version (8.23.0-2) of rsyslog from jessie-backports in…
jleveque Aug 10, 2018
3c3c19e
[lldp]: LLDP is misbehaving if netlink messages were lost due to timi…
zhenggen-xu Aug 10, 2018
36e9ad5
[devices]: update submodule platform/nephos/sonic-platform-modules-in…
simonJi2018 Aug 10, 2018
ae84318
[Mellanox] Update hw-management service config (#1914)
andriymoroz-mlnx Aug 10, 2018
9e2ceb7
[sonic-platform-common] Update submodule (#1915)
jleveque Aug 11, 2018
4d701ad
[baseimage]: update base image from jessie to stretch
lguohan Sep 5, 2017
ff1f508
[baseimage]: use debian 4.9.0-3 kernel
lguohan Sep 1, 2017
b6af83c
[baseimage]: upgrade initramfs to 0.130
lguohan Sep 1, 2017
72d70e9
[baseimage]: install systemd-sysv in the base image
lguohan Sep 2, 2017
f64ffe8
[baseimage]: build root filesystem via overlay fs instead of aufs
lguohan Sep 2, 2017
dabbe63
[baseimage]: Disable consistent network device naming
lguohan Sep 3, 2017
b03e974
[baseimage]: let docker in base image use overlay fs instead of aufs
lguohan Sep 5, 2017
376cabe
[baseimage]: update igb driver to 5.3.5.10
lguohan Sep 3, 2017
87ec4f1
[docker-syncd]: install kmod in docker-syncd-brcm without prompt
lguohan Sep 5, 2017
8d43f3b
[sonic-slave]: add deps for build initramfs 0.130
lguohan Sep 9, 2017
8c72d8c
[build]: insert overlay kmod for base image build
lguohan Sep 13, 2017
a87da7b
[build]: build stretch-based sonic slave docker
lguohan Sep 23, 2017
a719293
[build]: sonic-slave-stretch- sha both Dockerfile and Dockerfile.user
lguohan Sep 26, 2017
540a87a
[opennsl]: use opennsl kernel module based on kernel 4.9.0-3
lguohan Sep 5, 2017
5d1a7a1
[temp]: disable building platform drivers tempoerarily
lguohan Sep 3, 2017
23c3bfe
[kernel]: fix linux-headers common deb file name
lguohan Nov 6, 2017
a0280dd
update build instructions
lguohan Nov 6, 2017
2449faf
[kernel]: update kernel submodule and remove standalone igb driver
lguohan Dec 6, 2017
0e141a5
[baseimage]: install acl package
lguohan Dec 11, 2017
0827ed3
[baseimage]: install tacacs dependencies
lguohan Dec 11, 2017
9aebe09
[Mellanox]: Upgrade MFT package to 4.8.26 (#3)
marian-pritsak Dec 27, 2017
cd1d1b1
[Mellanox]: Update recipe for hw-management (#4)
marian-pritsak Dec 30, 2017
13c83ac
[platform]: enable platform driver for dell s6000 (#5)
lguohan Jan 3, 2018
35ab7a6
[kernel]: upgrade linux kernel to 4.9.0-5 (4.9.65-3+deb9u2) (#8)
lguohan Jan 10, 2018
5ae64e7
[ixgbe]: compile and install ixgbe to 4.9.0-5 kernel
lguohan Jan 10, 2018
f9c5783
[mellanox]: Adapt to new hw-management package (#12)
marian-pritsak Jan 26, 2018
9801ba9
[devices]: enable platform modules for various platforms
lguohan Feb 12, 2018
759edc9
[dell]: update to stretch-kernel based dell modules
lguohan Feb 13, 2018
f489bea
[platform]: incorporate sonic-platform-modules-cel into sonic buildim…
lguohan Feb 16, 2018
ec9dc57
[devices]: enable sonic-platform-modules-cel
lguohan Feb 16, 2018
025dad0
[celestica] change to use lm75 standard driver (#19)
pwisutti Feb 28, 2018
4142d7f
[Delta]: Modify delta-ag9032v1 driver for kernel 4.9 (#20)
nealtai Mar 1, 2018
0edb380
[build]: add stretch target to build in stretch docker
lguohan Mar 1, 2018
5364926
[build]: build initramfs, libwrap, tacacs packages under stretch docker
lguohan Mar 1, 2018
689bbd2
[broadcom]: update opennsl module to 3.4.1.11-1
lguohan Mar 3, 2018
91891af
[bug fix]: fix delta ag9032v1 driver compilation. disable ag9064
lguohan Mar 3, 2018
0d2ffd8
[baseimage]: move update initramfs to later stage
lguohan Mar 5, 2018
764a7ed
[device]: Enable arista drivers for sonic-linux-kernel 4.9 (#21)
Staphylo Mar 27, 2018
cbf204b
[device]: add the new platform ag9064 (#23)
Mar 27, 2018
d50332f
[devices]: Added new Mellanox MSN2010 platform (#24)
Apr 2, 2018
244aaca
[devices]: disable compiling ag9064 and ag5648
lguohan Apr 6, 2018
b53fa5e
[devices]: Modified and fixed delta ag5648 modules. (#30)
StanleyCi Apr 14, 2018
c77ddbc
[devices]: modified and fixed delta ag9064 modules (#28)
Apr 14, 2018
420f003
[mellanox]: fix SAI build makefile (#29)
mykolaf Apr 14, 2018
0fb3882
[devices]: disable compiling ag9064 and ag5648
lguohan Apr 6, 2018
6a0909e
[baseimage]: Add derived package to initramfs-tools (#33)
yurypm Apr 18, 2018
0f0e7ab
Add support 4.9 support for 7260CX3 (#34)
Staphylo Apr 27, 2018
145aa4f
[delta]: Enable ag5648, et-6248brb, ag9064 and fix the build error o…
StanleyCi May 2, 2018
ecfca8b
[devices]: DellEMC new platform support for z9264f - 64x100 (#26)
Jun 22, 2018
f7c16e3
[devices]: change celestica platform modules version back to 0.6
lguohan Jul 10, 2018
39b0e80
[device] Update arista driver submodule (#38)
yurypm Jul 14, 2018
16e16f5
[Mellanox]: Update recipe for hw-management (#4)
marian-pritsak Dec 30, 2017
46b0847
[baseimage]: use original stretch bash in the base image
lguohan Jul 30, 2018
a32b741
[kernel]: update sonic linux kernel submodule
lguohan Jul 30, 2018
b8a01dc
[build]: add .gitignore for cel, delta and inventec
lguohan Aug 5, 2018
8e0f1f5
[celestica]: update dx010 fan driver to support fault alarm
lguohan Aug 5, 2018
7d13479
[celestica]: Add dx010 gpio sysfs exported when platform modules load.
lguohan Aug 5, 2018
3021e4e
[devices]: add celstica haliburton
lguohan Aug 5, 2018
aa2e340
[broadcom]: build broadcom kernel modules from gpl source codes
lguohan Aug 7, 2018
5d46e05
[devices]: move platform modules of accton, ingrasys, mitac, quanta i…
lguohan Aug 8, 2018
0338379
[devices]: enable ingress and ariata devices on barefoot platform
lguohan Aug 8, 2018
678d4d4
[mellanox]: Update SDK pointer (#41)
Aug 10, 2018
6a3c05f
[mellanox]: Update recipe for hw-mgmt according to latest changes (#40)
Aug 10, 2018
be0328a
Update arista-drivers submodules (#42)
Staphylo Aug 10, 2018
002bff4
[baseimage]: use rsyslog in baseimage from stretch repo
lguohan Aug 11, 2018
4005975
[submodules]: update submodule for platform modules dell, s6000 and k…
lguohan Aug 11, 2018
88ea503
[doc]: update build instruction for debian stretch build
lguohan Aug 11, 2018
7f7a2a0
[sshd]: regenerate ssh key if ssh_host_rsa_key is not present
lguohan Aug 11, 2018
66ffca2
[kernel]: set default option to build kernel
lguohan Aug 11, 2018
1533bc5
[dockerbase]: use libwrarp0 7.6.q-26 in docker base
lguohan Aug 12, 2018
8910c7e
update .gitignore
lguohan Aug 12, 2018
9e37d50
Merge pull request #1335 from lguohan/stretch
lguohan Aug 12, 2018
6246b16
[doc]: update build instruction for debian stretch
lguohan Aug 12, 2018
d761630
Fix potential blackholing/looping traffic when link-local was used an…
zhenggen-xu Aug 12, 2018
58db7f1
[device & platform] led and transceiver deamon for inventec switch d7…
klhaung Aug 12, 2018
eefd3f4
[platform]: update centec platform drivers and sai (#1702)
yangbashuang Aug 13, 2018
add2444
[barefoot]: build platform modules for bfn, bfn-montara, wnc-osw1800
lguohan Aug 13, 2018
647af39
[build]: create empty /var/lib/docker if needed (#1920)
lguohan Aug 13, 2018
f3ca7c4
[rsyslog]: use # to separate container name and program name in syslo…
lguohan Aug 13, 2018
0cd4ef0
[socat]: build socat with readline (#1919)
lguohan Aug 13, 2018
9047edc
[platform]: move dell platform modules into buildimage repo
lguohan Aug 13, 2018
859d0e1
[bcmsh]: add inactivity timeout for bcmsh (default 300 seconds) (#1921)
lguohan Aug 13, 2018
40bb27c
Simplify script to install docker (#1925)
qiluo-msft Aug 14, 2018
e15cf2d
[build]: print error message when use root or sudo to build. (#1923)
lguohan Aug 14, 2018
4547d9a
[nephos]: build platform modules in debian stretch docker
lguohan Aug 14, 2018
cdc2717
[submodule update]: sonic-quagga. Add dscp flag settings (#1926)
pavel-shirshov Aug 14, 2018
746ad96
[mellanox]: Fix post stop action in swss service template (#1928)
Aug 14, 2018
6918a22
[Inventec] Add D7264 platform support (#1675)
Aug 14, 2018
c4e2f3e
[mellanox]: Update hw-mgmt service with the stop action (#1929)
Aug 14, 2018
f0d4a07
[submodule] update snmpagent pointer (#1930)
mykolaf Aug 15, 2018
9f54545
Added picocom and pexpect to base image, for use in consutil (#1935)
cawand Aug 16, 2018
7d27660
[common]: Update sonic-swss-common submodule (#1934)
Aug 16, 2018
c1e17c3
[mellanox]: Fix qos.json.j2: apply qos config for active ports (#1932)
stepanblyschak Aug 16, 2018
38f3eba
[kernel]: upgrade kernel to 4.9.0-7 (4.9.110-3+deb9u1) (#1922)
lguohan Aug 16, 2018
cd9c5e7
Allow similar devices configs sharing (#1933)
stepanblyschak Aug 16, 2018
fd5bce5
[device/dx010] configuration port index start from 1 (#1927)
pphuchar Aug 16, 2018
986a857
[mellanox]: Fix problem with system EEPROM in "hw-mgmt" (#1938)
Aug 16, 2018
a8ccf58
[build]: Makefile: make new step "make stretch" optional (#1936)
yxieca Aug 16, 2018
86205b8
[devices/a7050]: Separate ECN/WRED profile per queue to maintain a co…
wendani Aug 17, 2018
ec8a7f5
[broadcom]: fix delay to load led proc init (#1940)
lguohan Aug 17, 2018
5a17a04
[mlnx-platform] enhancement for xcvrd implementation on mlnx platform…
keboliu Aug 17, 2018
c059d99
[baseimage]: install picocom 3.1 in base image (#1943)
lguohan Aug 17, 2018
f499254
[swsssdk]: update DBInterface submodule (#1942)
keboliu Aug 17, 2018
f05ee30
[sai]: upgrade SAI to version 1.3.3 (#1944)
lguohan Aug 17, 2018
98082d5
[baseimage]: Download picocom version 3.1-2 from stretch-backports; N…
jleveque Aug 18, 2018
4aa3f7a
[mellanox]: Fix system EEPROM for MSN2740 platform (#1950)
Aug 20, 2018
e7ef637
[config-bcm] move broadcom config files to device folder (#1947)
yxieca Aug 20, 2018
9413fa9
[interfaces]: Move IP/MTU information from interfaces file into datab…
Aug 20, 2018
d9527ec
[utilities]: Update sonic-utilities submodule (#1949)
Aug 20, 2018
4546905
[kernel]: upgrade kernel to 4.9.0-7 (4.9.110-3+deb9u2) (#1955)
qiluo-msft Aug 21, 2018
c692d2d
[baseimage]: Build specific revision of initramfs-tools (#1957)
qiluo-msft Aug 21, 2018
450cb04
[utilities]: Update sonic-utilities submodule (#1956)
Aug 21, 2018
788b20e
[arista]: Fix mount point discovery in boot0 for overlayfs (#1959)
Staphylo Aug 21, 2018
a01791e
[vs-test]: support python docker 3.5.0 (#1958)
lguohan Aug 21, 2018
de0e892
[arista] Fix arista-convertfs script (#1961)
yurypm Aug 21, 2018
d7be9a4
[kernel]: Update sonic-linux-kernel pointer (#1964)
Staphylo Aug 22, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ fs.*
target/
*.deb
*.changes
*.buildinfo

# Subdirectories in src
src/hiredis/*
Expand Down
25 changes: 4 additions & 21 deletions .gitmodules
100755 → 100644
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
[submodule "sonic-linux-kernel"]
path = src/sonic-linux-kernel
url = https://github.com/Azure/sonic-linux-kernel
branch = stretch
[submodule "sonic-sairedis"]
path = src/sonic-sairedis
url = https://github.com/Azure/sonic-sairedis
Expand Down Expand Up @@ -35,30 +36,15 @@
[submodule "src/sonic-utilities"]
path = src/sonic-utilities
url = https://github.com/Azure/sonic-utilities
[submodule "platform/broadcom/sonic-platform-modules-s6000"]
path = platform/broadcom/sonic-platform-modules-s6000
url = https://github.com/Azure/sonic-platform-modules-s6000
[submodule "platform/broadcom/sonic-platform-modules-arista"]
path = platform/broadcom/sonic-platform-modules-arista
url = https://github.com/aristanetworks/sonic
[submodule "platform/broadcom/sonic-platform-modules-dell"]
path = platform/broadcom/sonic-platform-modules-dell
url = https://github.com/Azure/sonic-platform-modules-dell
[submodule "platform/broadcom/sonic-platform-modules-ingrasys"]
path = platform/broadcom/sonic-platform-modules-ingrasys
url = https://github.com/Ingrasys-sonic/sonic-platform-modules-ingrasys
[submodule "src/sonic-platform-common"]
path = src/sonic-platform-common
url = https://github.com/Azure/sonic-platform-common
[submodule "src/sonic-platform-daemons"]
path = src/sonic-platform-daemons
url = https://github.com/Azure/sonic-platform-daemons
[submodule "platform/broadcom/sonic-platform-modules-accton"]
path = platform/broadcom/sonic-platform-modules-accton
url = https://github.com/edge-core/sonic-platform-modules-accton.git
[submodule "platform/broadcom/sonic-platform-modules-cel"]
path = platform/broadcom/sonic-platform-modules-cel
url = https://github.com/celestica-Inc/sonic-platform-modules-cel.git
[submodule "src/sonic-frr/frr"]
path = src/sonic-frr/frr
url = https://github.com/FRRouting/frr.git
Expand All @@ -71,12 +57,9 @@
[submodule "platform/nephos/sonic-platform-modules-ingrasys"]
path = platform/nephos/sonic-platform-modules-ingrasys
url = https://github.com/Ingrasys-sonic/sonic-platform-modules-ingrasys-nephos.git
[submodule "platform/broadcom/sonic-platform-modules-quanta"]
path = platform/broadcom/sonic-platform-modules-quanta
url = https://github.com/QuantaSwitchONIE/sonic-platform-modules-quanta.git
[submodule "platform/broadcom/sonic-platform-modules-mitac"]
path = platform/broadcom/sonic-platform-modules-mitac
url = https://github.com/MiTAC-EBU/sonic-platform-modules-mitac.git
[submodule "platform/barefoot/sonic-platform-modules-arista"]
path = platform/barefoot/sonic-platform-modules-arista
url = https://github.com/aristanetworks/sonic
[submodule "platform/mellanox/hw-management/hw-mgmt"]
path = platform/mellanox/hw-management/hw-mgmt
url = https://github.com/Mellanox/hw-mgmt/
139 changes: 14 additions & 125 deletions Makefile
Original file line number Diff line number Diff line change
@@ -1,131 +1,20 @@
###############################################################################
## Wrapper for starting make inside sonic-slave container
#
# Supported parameters:
#
# * PLATFORM: Specific platform we wish to build images for.
# * BUILD_NUMBER: Desired version-number to pass to the building-system.
# * ENABLE_DHCP_GRAPH_SERVICE: Enables get-graph service to fetch minigraph files
# through http.
# * SHUTDOWN_BGP_ON_START: Sets admin-down state for all bgp peerings after restart.
# * ENABLE_PFCWD_ON_START: Enable PFC Watchdog (PFCWD) on server-facing ports
# * by default for TOR switch.
# * SONIC_ENABLE_SYNCD_RPC: Enables rpc-based syncd builds.
# * USERNAME: Desired username -- default at rules/config
# * PASSWORD: Desired password -- default at rules/config
# * KEEP_SLAVE_ON: Keeps slave container up after building-process concludes.
# * SOURCE_FOLDER: host path to be mount as /var/$(USER)/src, only effective when KEEP_SLAVE_ON=yes
# * SONIC_BUILD_JOBS: Specifying number of concurrent build job(s) to run
# * KERNEL_PROCURE_METHOD: Specifying method of obtaining kernel Debian package: download or build
#
###############################################################################
# SONiC make file

SHELL = /bin/bash

USER := $(shell id -un)
PWD := $(shell pwd)

# Remove lock file in case previous run was forcefully stopped
$(shell rm -f .screen)

MAKEFLAGS += -B

SLAVE_BASE_TAG = $(shell sha1sum sonic-slave/Dockerfile | awk '{print substr($$1,0,11);}')
SLAVE_TAG = $(shell cat sonic-slave/Dockerfile.user sonic-slave/Dockerfile | sha1sum | awk '{print substr($$1,0,11);}')
SLAVE_BASE_IMAGE = sonic-slave-base
SLAVE_IMAGE = sonic-slave-$(USER)

DOCKER_RUN := docker run --rm=true --privileged \
-v $(PWD):/sonic \
-w /sonic \
-e "http_proxy=$(http_proxy)" \
-e "https_proxy=$(https_proxy)" \
-i$(if $(TERM),t,)

DOCKER_BASE_BUILD = docker build --no-cache \
-t $(SLAVE_BASE_IMAGE) \
--build-arg http_proxy=$(http_proxy) \
--build-arg https_proxy=$(https_proxy) \
sonic-slave && \
docker tag $(SLAVE_BASE_IMAGE):latest $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG)

DOCKER_BUILD = docker build --no-cache \
--build-arg user=$(USER) \
--build-arg uid=$(shell id -u) \
--build-arg guid=$(shell id -g) \
--build-arg hostname=$(shell echo $$HOSTNAME) \
-t $(SLAVE_IMAGE) \
-f sonic-slave/Dockerfile.user \
sonic-slave && \
docker tag $(SLAVE_IMAGE):latest $(SLAVE_IMAGE):$(SLAVE_TAG)

SONIC_BUILD_INSTRUCTION := make \
-f slave.mk \
PLATFORM=$(PLATFORM) \
BUILD_NUMBER=$(BUILD_NUMBER) \
ENABLE_DHCP_GRAPH_SERVICE=$(ENABLE_DHCP_GRAPH_SERVICE) \
SHUTDOWN_BGP_ON_START=$(SHUTDOWN_BGP_ON_START) \
SONIC_ENABLE_PFCWD_ON_START=$(ENABLE_PFCWD_ON_START) \
ENABLE_SYNCD_RPC=$(ENABLE_SYNCD_RPC) \
PASSWORD=$(PASSWORD) \
USERNAME=$(USERNAME) \
SONIC_BUILD_JOBS=$(SONIC_BUILD_JOBS) \
KERNEL_PROCURE_METHOD=$(KERNEL_PROCURE_METHOD) \
HTTP_PROXY=$(http_proxy) \
HTTPS_PROXY=$(https_proxy) \
SONIC_ENABLE_SYSTEM_TELEMETRY=$(ENABLE_SYSTEM_TELEMETRY)

.PHONY: sonic-slave-build sonic-slave-bash init reset

.DEFAULT_GOAL := all
NOSTRETCH ?= 0

%::
@docker inspect --type image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) not found. Building... ; \
$(DOCKER_BASE_BUILD) ; }
@docker inspect --type image $(SLAVE_IMAGE):$(SLAVE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_IMAGE):$(SLAVE_TAG) not found. Building... ; \
$(DOCKER_BUILD) ; }
ifeq "$(KEEP_SLAVE_ON)" "yes"
ifdef SOURCE_FOLDER
@$(DOCKER_RUN) -v $(SOURCE_FOLDER):/var/$(USER)/src $(SLAVE_IMAGE):$(SLAVE_TAG) bash -c "$(SONIC_BUILD_INSTRUCTION) $@; /bin/bash"
else
@$(DOCKER_RUN) $(SLAVE_IMAGE):$(SLAVE_TAG) bash -c "$(SONIC_BUILD_INSTRUCTION) $@; /bin/bash"
endif
else
@$(DOCKER_RUN) $(SLAVE_IMAGE):$(SLAVE_TAG) $(SONIC_BUILD_INSTRUCTION) $@
@echo "+++ --- Making $@ --- +++"
ifeq ($(NOSTRETCH), 0)
BLDENV=stretch make -f Makefile.work stretch
endif
make -f Makefile.work $@

sonic-slave-build :
$(DOCKER_BASE_BUILD)
$(DOCKER_BUILD)

sonic-slave-bash :
@docker inspect --type image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) not found. Building... ; \
$(DOCKER_BASE_BUILD) ; }
@docker inspect --type image $(SLAVE_IMAGE):$(SLAVE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_IMAGE):$(SLAVE_TAG) not found. Building... ; \
$(DOCKER_BUILD) ; }
@$(DOCKER_RUN) -t $(SLAVE_IMAGE):$(SLAVE_TAG) bash

showtag:
@echo $(SLAVE_IMAGE):$(SLAVE_TAG)
@echo $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG)

init :
@git submodule update --init --recursive
@git submodule foreach --recursive '[ -f .git ] && echo "gitdir: $$(realpath --relative-to=. $$(cut -d" " -f2 .git))" > .git'
stretch:
@echo "+++ Making $@ +++"
ifeq ($(NOSTRETCH), 0)
BLDENV=stretch make -f Makefile.work stretch
endif

reset :
@echo && echo -n "Warning! All local changes will be lost. Proceed? [y/N]: "
@read ans && \
if [ $$ans == y ]; then \
git clean -xfdf; \
git reset --hard; \
git submodule foreach --recursive git clean -xfdf; \
git submodule foreach --recursive git reset --hard; \
git submodule update --init --recursive;\
else \
echo "Reset aborted"; \
fi
clean reset init configure showtag sonic-slave-build sonic-slave-bash :
@echo "+++ Making $@ +++"
make -f Makefile.work $@
147 changes: 147 additions & 0 deletions Makefile.work
Original file line number Diff line number Diff line change
@@ -0,0 +1,147 @@
###############################################################################
## Wrapper for starting make inside sonic-slave container
#
# Supported parameters:
#
# * PLATFORM: Specific platform we wish to build images for.
# * BUILD_NUMBER: Desired version-number to pass to the building-system.
# * ENABLE_DHCP_GRAPH_SERVICE: Enables get-graph service to fetch minigraph files
# through http.
# * SHUTDOWN_BGP_ON_START: Sets admin-down state for all bgp peerings after restart.
# * ENABLE_PFCWD_ON_START: Enable PFC Watchdog (PFCWD) on server-facing ports
# * by default for TOR switch.
# * SONIC_ENABLE_SYNCD_RPC: Enables rpc-based syncd builds.
# * USERNAME: Desired username -- default at rules/config
# * PASSWORD: Desired password -- default at rules/config
# * KEEP_SLAVE_ON: Keeps slave container up after building-process concludes.
# * SOURCE_FOLDER: host path to be mount as /var/$(USER)/src, only effective when KEEP_SLAVE_ON=yes
# * SONIC_BUILD_JOBS: Specifying number of concurrent build job(s) to run
# * KERNEL_PROCURE_METHOD: Specifying method of obtaining kernel Debian package: download or build
#
###############################################################################

SHELL = /bin/bash

USER := $(shell id -un)
PWD := $(shell pwd)

ifeq ($(USER), root)
$(error Add your user account to docker group and use your user account to make. root or sudo are not supported!)
endif

# Remove lock file in case previous run was forcefully stopped
$(shell rm -f .screen)

MAKEFLAGS += -B

ifeq ($(BLDENV), stretch)
SLAVE_BASE_TAG = $(shell sha1sum sonic-slave-stretch/Dockerfile | awk '{print substr($$1,0,11);}')
SLAVE_TAG = $(shell cat sonic-slave-stretch/Dockerfile.user sonic-slave-stretch/Dockerfile | sha1sum | awk '{print substr($$1,0,11);}')
SLAVE_BASE_IMAGE = sonic-slave-stretch-base
SLAVE_IMAGE = sonic-slave-stretch-$(USER)
SLAVE_DIR = sonic-slave-stretch
else
SLAVE_BASE_TAG = $(shell sha1sum sonic-slave/Dockerfile | awk '{print substr($$1,0,11);}')
SLAVE_TAG = $(shell cat sonic-slave/Dockerfile.user sonic-slave/Dockerfile | sha1sum | awk '{print substr($$1,0,11);}')
SLAVE_BASE_IMAGE = sonic-slave-base
SLAVE_IMAGE = sonic-slave-$(USER)
SLAVE_DIR = sonic-slave
endif

INSMOD_OVERLAY := sudo modprobe overlay
DOCKER_RUN := docker run --rm=true --privileged \
-v $(PWD):/sonic \
-w /sonic \
-e "http_proxy=$(http_proxy)" \
-e "https_proxy=$(https_proxy)" \
-i$(if $(TERM),t,)

DOCKER_BASE_BUILD = docker build --no-cache \
-t $(SLAVE_BASE_IMAGE) \
--build-arg http_proxy=$(http_proxy) \
--build-arg https_proxy=$(https_proxy) \
$(SLAVE_DIR) && \
docker tag $(SLAVE_BASE_IMAGE):latest $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG)

DOCKER_BUILD = docker build --no-cache \
--build-arg user=$(USER) \
--build-arg uid=$(shell id -u) \
--build-arg guid=$(shell id -g) \
--build-arg hostname=$(shell echo $$HOSTNAME) \
-t $(SLAVE_IMAGE) \
-f $(SLAVE_DIR)/Dockerfile.user \
$(SLAVE_DIR) && \
docker tag $(SLAVE_IMAGE):latest $(SLAVE_IMAGE):$(SLAVE_TAG)

SONIC_BUILD_INSTRUCTION := make \
-f slave.mk \
PLATFORM=$(PLATFORM) \
BUILD_NUMBER=$(BUILD_NUMBER) \
ENABLE_DHCP_GRAPH_SERVICE=$(ENABLE_DHCP_GRAPH_SERVICE) \
SHUTDOWN_BGP_ON_START=$(SHUTDOWN_BGP_ON_START) \
SONIC_ENABLE_PFCWD_ON_START=$(ENABLE_PFCWD_ON_START) \
ENABLE_SYNCD_RPC=$(ENABLE_SYNCD_RPC) \
PASSWORD=$(PASSWORD) \
USERNAME=$(USERNAME) \
SONIC_BUILD_JOBS=$(SONIC_BUILD_JOBS) \
KERNEL_PROCURE_METHOD=$(KERNEL_PROCURE_METHOD) \
HTTP_PROXY=$(http_proxy) \
HTTPS_PROXY=$(https_proxy) \
SONIC_ENABLE_SYSTEM_TELEMETRY=$(ENABLE_SYSTEM_TELEMETRY)

.PHONY: sonic-slave-build sonic-slave-bash init reset

.DEFAULT_GOAL := all

%::
@docker inspect --type image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) not found. Building... ; \
$(DOCKER_BASE_BUILD) ; }
@docker inspect --type image $(SLAVE_IMAGE):$(SLAVE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_IMAGE):$(SLAVE_TAG) not found. Building... ; \
$(DOCKER_BUILD) ; }
@$(INSMOD_OVERLAY)
ifeq "$(KEEP_SLAVE_ON)" "yes"
ifdef SOURCE_FOLDER
@$(DOCKER_RUN) -v $(SOURCE_FOLDER):/var/$(USER)/src $(SLAVE_IMAGE):$(SLAVE_TAG) bash -c "$(SONIC_BUILD_INSTRUCTION) $@; /bin/bash"
else
@$(DOCKER_RUN) $(SLAVE_IMAGE):$(SLAVE_TAG) bash -c "$(SONIC_BUILD_INSTRUCTION) $@; /bin/bash"
endif
else
@$(DOCKER_RUN) $(SLAVE_IMAGE):$(SLAVE_TAG) $(SONIC_BUILD_INSTRUCTION) $@
endif

sonic-slave-build :
$(DOCKER_BASE_BUILD)
$(DOCKER_BUILD)

sonic-slave-bash :
@docker inspect --type image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG) not found. Building... ; \
$(DOCKER_BASE_BUILD) ; }
@docker inspect --type image $(SLAVE_IMAGE):$(SLAVE_TAG) &> /dev/null || \
{ echo Image $(SLAVE_IMAGE):$(SLAVE_TAG) not found. Building... ; \
$(DOCKER_BUILD) ; }
@$(INSMOD_OVERLAY)
@$(DOCKER_RUN) -t $(SLAVE_IMAGE):$(SLAVE_TAG) bash

showtag:
@echo $(SLAVE_IMAGE):$(SLAVE_TAG)
@echo $(SLAVE_BASE_IMAGE):$(SLAVE_BASE_TAG)

init :
@git submodule update --init --recursive
@git submodule foreach --recursive '[ -f .git ] && echo "gitdir: $$(realpath --relative-to=. $$(cut -d" " -f2 .git))" > .git'

reset :
@echo && echo -n "Warning! All local changes will be lost. Proceed? [y/N]: "
@read ans && \
if [ $$ans == y ]; then \
git clean -xfdf; \
git reset --hard; \
git submodule foreach --recursive git clean -xfdf; \
git submodule foreach --recursive git reset --hard; \
git submodule update --init --recursive;\
else \
echo "Reset aborted"; \
fi
10 changes: 8 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,11 @@ To build SONiC installer image and docker images, run the following commands:
# Execute make configure once to configure ASIC
make configure PLATFORM=[ASIC_VENDOR]

make
# build debian stretch required targets (optional)
BLDENV=stretch make stretch

# build SONiC image
make all

**NOTE**:

Expand All @@ -80,11 +84,13 @@ The SONiC installer contains all docker images needed. SONiC uses one image for
For Broadcom ASIC, we build ONIE and EOS image. EOS image is used for Arista devices, ONIE image is used for all other Broadcom ASIC based devices.

make configure PLATFORM=broadcom
# build debian stretch required targets
BLDENV=stretch make stretch
# build ONIE image
make target/sonic-broadcom.bin
# build EOS image
make target/sonic-aboot-broadcom.swi

You may find the rules/config file useful. It contains configuration options for the build process, like adding more verbosity or showing dependencies, username and password for base image etc.

Every docker image is built and saved to target/ directory.
Expand Down
Loading