-
Notifications
You must be signed in to change notification settings - Fork 547
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'master' into dasn_eni_fwd
- Loading branch information
Showing
58 changed files
with
3,675 additions
and
176 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,187 @@ | ||
#!/bin/bash -e | ||
|
||
# Generate configuration | ||
|
||
# NOTE: 'PLATFORM' and 'HWSKU' environment variables are set | ||
# in the Dockerfile so that they persist for the life of the container | ||
|
||
ln -sf /usr/share/sonic/device/$PLATFORM /usr/share/sonic/platform | ||
ln -sf /usr/share/sonic/device/$PLATFORM/$HWSKU /usr/share/sonic/hwsku | ||
|
||
SWITCH_TYPE=switch | ||
PLATFORM_CONF=platform.json | ||
if [[ $HWSKU == "DPU-2P" ]]; then | ||
SWITCH_TYPE=dpu | ||
PLATFORM_CONF=platform-dpu-2p.json | ||
fi | ||
|
||
pushd /usr/share/sonic/hwsku | ||
|
||
# filter available front panel ports in lanemap.ini | ||
[ -f lanemap.ini.orig ] || cp lanemap.ini lanemap.ini.orig | ||
for p in $(ip link show | grep -oE "eth[0-9]+" | grep -v eth0); do | ||
grep ^$p: lanemap.ini.orig | ||
done > lanemap.ini | ||
|
||
# filter available sonic front panel ports in port_config.ini | ||
[ -f port_config.ini.orig ] || cp port_config.ini port_config.ini.orig | ||
grep ^# port_config.ini.orig > port_config.ini | ||
for lanes in $(awk -F ':' '{print $2}' lanemap.ini); do | ||
grep -E "\s$lanes\s" port_config.ini.orig | ||
done >> port_config.ini | ||
|
||
popd | ||
|
||
[ -d /etc/sonic ] || mkdir -p /etc/sonic | ||
|
||
# Note: libswsscommon requires a dabase_config file in /var/run/redis/sonic-db/ | ||
# Prepare this file before any dependent application, such as sonic-cfggen | ||
mkdir -p /var/run/redis/sonic-db | ||
cp /etc/default/sonic-db/database_config.json /var/run/redis/sonic-db/ | ||
|
||
SYSTEM_MAC_ADDRESS=$(ip link show eth0 | grep ether | awk '{print $2}') | ||
sonic-cfggen -t /usr/share/sonic/templates/init_cfg.json.j2 -a "{\"system_mac\": \"$SYSTEM_MAC_ADDRESS\", \"switch_type\": \"$SWITCH_TYPE\"}" > /etc/sonic/init_cfg.json | ||
|
||
if [[ -f /usr/share/sonic/virtual_chassis/default_config.json ]]; then | ||
sonic-cfggen -j /etc/sonic/init_cfg.json -j /usr/share/sonic/virtual_chassis/default_config.json --print-data > /tmp/init_cfg.json | ||
mv /tmp/init_cfg.json /etc/sonic/init_cfg.json | ||
fi | ||
|
||
if [ -f /etc/sonic/config_db.json ]; then | ||
sonic-cfggen -j /etc/sonic/init_cfg.json -j /etc/sonic/config_db.json --print-data > /tmp/config_db.json | ||
mv /tmp/config_db.json /etc/sonic/config_db.json | ||
else | ||
# generate and merge buffers configuration into config file | ||
if [ -f /usr/share/sonic/hwsku/buffers.json.j2 ]; then | ||
sonic-cfggen -k $HWSKU -p /usr/share/sonic/device/$PLATFORM/$PLATFORM_CONF -t /usr/share/sonic/hwsku/buffers.json.j2 > /tmp/buffers.json | ||
buffers_cmd="-j /tmp/buffers.json" | ||
fi | ||
if [ -f /usr/share/sonic/hwsku/qos.json.j2 ]; then | ||
sonic-cfggen -j /etc/sonic/init_cfg.json -t /usr/share/sonic/hwsku/qos.json.j2 > /tmp/qos.json | ||
qos_cmd="-j /tmp/qos.json" | ||
fi | ||
|
||
sonic-cfggen -p /usr/share/sonic/device/$PLATFORM/$PLATFORM_CONF -k $HWSKU --print-data > /tmp/ports.json | ||
# change admin_status from up to down; Test cases dependent | ||
sed -i "s/up/down/g" /tmp/ports.json | ||
sonic-cfggen -j /etc/sonic/init_cfg.json $buffers_cmd $qos_cmd -j /tmp/ports.json --print-data > /etc/sonic/config_db.json | ||
fi | ||
|
||
sonic-cfggen -t /usr/share/sonic/templates/copp_cfg.j2 > /etc/sonic/copp_cfg.json | ||
|
||
if [ "$HWSKU" == "Mellanox-SN2700" ]; then | ||
cp /usr/share/sonic/hwsku/sai_mlnx.profile /usr/share/sonic/hwsku/sai.profile | ||
elif [ "$HWSKU" == "DPU-2P" ]; then | ||
cp /usr/share/sonic/hwsku/sai_dpu_2p.profile /usr/share/sonic/hwsku/sai.profile | ||
fi | ||
|
||
mkdir -p /etc/swss/config.d/ | ||
|
||
rm -f /var/run/rsyslogd.pid | ||
|
||
supervisorctl start rsyslogd | ||
|
||
supervisord_cfg="/etc/supervisor/conf.d/supervisord.conf" | ||
chassisdb_cfg_file="/usr/share/sonic/virtual_chassis/default_config.json" | ||
chassisdb_cfg_file_default="/etc/default/sonic-db/default_chassis_cfg.json" | ||
host_template="/usr/share/sonic/templates/hostname.j2" | ||
db_cfg_file="/var/run/redis/sonic-db/database_config.json" | ||
db_cfg_file_tmp="/var/run/redis/sonic-db/database_config.json.tmp" | ||
|
||
if [ -r "$chassisdb_cfg_file" ]; then | ||
echo $(sonic-cfggen -j $chassisdb_cfg_file -t $host_template) >> /etc/hosts | ||
else | ||
chassisdb_cfg_file="$chassisdb_cfg_file_default" | ||
echo "10.8.1.200 redis_chassis.server" >> /etc/hosts | ||
fi | ||
|
||
supervisorctl start redis-server | ||
|
||
start_chassis_db=`sonic-cfggen -v DEVICE_METADATA.localhost.start_chassis_db -y $chassisdb_cfg_file` | ||
if [[ "$HOSTNAME" == *"supervisor"* ]] || [ "$start_chassis_db" == "1" ]; then | ||
supervisorctl start redis-chassis | ||
fi | ||
|
||
conn_chassis_db=`sonic-cfggen -v DEVICE_METADATA.localhost.connect_to_chassis_db -y $chassisdb_cfg_file` | ||
if [ "$start_chassis_db" != "1" ] && [ "$conn_chassis_db" != "1" ]; then | ||
cp $db_cfg_file $db_cfg_file_tmp | ||
update_chassisdb_config -j $db_cfg_file_tmp -d | ||
cp $db_cfg_file_tmp $db_cfg_file | ||
fi | ||
|
||
if [ "$conn_chassis_db" == "1" ]; then | ||
if [ -f /usr/share/sonic/virtual_chassis/coreportindexmap.ini ]; then | ||
cp /usr/share/sonic/virtual_chassis/coreportindexmap.ini /usr/share/sonic/hwsku/ | ||
|
||
pushd /usr/share/sonic/hwsku | ||
|
||
# filter available front panel ports in coreportindexmap.ini | ||
[ -f coreportindexmap.ini.orig ] || cp coreportindexmap.ini coreportindexmap.ini.orig | ||
for p in $(ip link show | grep -oE "eth[0-9]+" | grep -v eth0); do | ||
grep ^$p: coreportindexmap.ini.orig | ||
done > coreportindexmap.ini | ||
|
||
popd | ||
fi | ||
fi | ||
|
||
/usr/bin/configdb-load.sh | ||
|
||
if [ "$HWSKU" = "brcm_gearbox_vs" ]; then | ||
supervisorctl start gbsyncd | ||
supervisorctl start gearsyncd | ||
fi | ||
|
||
supervisorctl start syncd | ||
|
||
supervisorctl start portsyncd | ||
|
||
supervisorctl start orchagent | ||
|
||
supervisorctl start coppmgrd | ||
|
||
supervisorctl start neighsyncd | ||
|
||
supervisorctl start fdbsyncd | ||
|
||
supervisorctl start teamsyncd | ||
|
||
supervisorctl start fpmsyncd | ||
|
||
supervisorctl start teammgrd | ||
|
||
supervisorctl start vrfmgrd | ||
|
||
supervisorctl start portmgrd | ||
|
||
supervisorctl start intfmgrd | ||
|
||
supervisorctl start vlanmgrd | ||
|
||
supervisorctl start zebra | ||
|
||
supervisorctl start mgmtd | ||
|
||
supervisorctl start staticd | ||
|
||
supervisorctl start buffermgrd | ||
|
||
supervisorctl start nbrmgrd | ||
|
||
supervisorctl start vxlanmgrd | ||
|
||
supervisorctl start sflowmgrd | ||
|
||
supervisorctl start natmgrd | ||
|
||
supervisorctl start natsyncd | ||
|
||
supervisorctl start tunnelmgrd | ||
|
||
supervisorctl start fabricmgrd | ||
|
||
# Start arp_update when VLAN exists | ||
VLAN=`sonic-cfggen -d -v 'VLAN.keys() | join(" ") if VLAN'` | ||
if [ "$VLAN" != "" ]; then | ||
supervisorctl start arp_update | ||
fi |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,7 +7,7 @@ on: | |
branches: | ||
- 'master' | ||
- '202[0-9][0-9][0-9]' | ||
pull_request_target: | ||
pull_request: | ||
branches: | ||
- 'master' | ||
- '202[0-9][0-9][0-9]' | ||
|
@@ -16,7 +16,7 @@ on: | |
jobs: | ||
analyze: | ||
name: Analyze | ||
runs-on: ubuntu-20.04 | ||
runs-on: ubuntu-22.04 | ||
permissions: | ||
actions: read | ||
contents: read | ||
|
@@ -50,15 +50,14 @@ jobs: | |
libnl-genl-3-dev \ | ||
libnl-route-3-dev \ | ||
libnl-nf-3-dev \ | ||
libyang-dev \ | ||
libzmq3-dev \ | ||
libzmq5 \ | ||
swig3.0 \ | ||
libpython2.7-dev \ | ||
swig \ | ||
libpython3-dev \ | ||
libgtest-dev \ | ||
libgmock-dev \ | ||
libboost1.71-dev \ | ||
libboost-serialization1.71-dev \ | ||
libboost-dev \ | ||
libboost-serialization-dev \ | ||
dh-exec \ | ||
doxygen \ | ||
cdbs \ | ||
|
@@ -69,7 +68,8 @@ jobs: | |
uuid-dev \ | ||
libjansson-dev \ | ||
nlohmann-json3-dev \ | ||
python \ | ||
build-essential \ | ||
devscripts \ | ||
stgit | ||
- if: matrix.language == 'cpp' | ||
|
@@ -79,7 +79,7 @@ jobs: | |
git clone https://github.com/sonic-net/sonic-swss-common | ||
pushd sonic-swss-common | ||
./autogen.sh | ||
dpkg-buildpackage -rfakeroot -us -uc -b -j$(nproc) | ||
dpkg-buildpackage -rfakeroot -us -uc -b -Pnoyangmod,nopython2 -j$(nproc) | ||
popd | ||
dpkg-deb -x libswsscommon_${SWSSCOMMON_VER}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libswsscommon-dev_${SWSSCOMMON_VER}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
|
@@ -115,31 +115,33 @@ jobs: | |
cd .. | ||
git clone https://github.com/sonic-net/sonic-buildimage | ||
pushd sonic-buildimage/src/libnl3 | ||
git clone https://github.com/thom311/libnl libnl3-${LIBNL3_VER} | ||
dget -u https://deb.debian.org/debian/pool/main/libn/libnl3/libnl3_${LIBNL3_VER}-${LIBNL3_REV}.dsc | ||
pushd libnl3-${LIBNL3_VER} | ||
git checkout tags/libnl${LIBNL3_VER//./_} | ||
git checkout -b sonic | ||
git init | ||
git config --local user.name $USER | ||
git config --local user.email [email protected] | ||
git add -f * | ||
git commit -qm "initial commit" | ||
stg init | ||
stg import -s ../patch/series | ||
git config --local --unset user.name | ||
git config --local --unset user.email | ||
ln -s ../debian debian | ||
dpkg-buildpackage -rfakeroot -us -uc -b -j$(nproc) | ||
DPKG_GENSYMBOLS_CHECK_LEVEL=0 dpkg-buildpackage -rfakeroot -us -uc -b -j$(nproc) | ||
popd | ||
dpkg-deb -x libnl-3-200_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-3-dev_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-genl-3-200_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-genl-3-dev_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-route-3-200_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-route-3-dev_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-nf-3-200_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-nf-3-dev_${LIBNL3_VER}-${LIBNL3_REV}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-3-200_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-3-dev_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-genl-3-200_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-genl-3-dev_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-route-3-200_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-route-3-dev_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-nf-3-200_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
dpkg-deb -x libnl-nf-3-dev_${LIBNL3_VER}-${LIBNL3_REV_SONIC}_amd64.deb $(dirname $GITHUB_WORKSPACE) | ||
popd | ||
env: | ||
LIBNL3_VER: "3.5.0" | ||
LIBNL3_REV: "1" | ||
LIBNL3_VER: "3.7.0" | ||
LIBNL3_REV: "0.2" | ||
LIBNL3_REV_SONIC: "0.2+b1sonic1" | ||
|
||
- if: matrix.language == 'cpp' | ||
name: Build repository | ||
|
Oops, something went wrong.