mirror of
https://github.com/vyos/vyos-build.git
synced 2025-10-01 20:28:40 +02:00
Intel: T6847: provide common build script for Out-Of-Tree drivers
Use one build script to rule all the Intel Git based drivers.
This commit is contained in:
parent
ae3a66c3f3
commit
2c61c15656
@ -18,8 +18,7 @@
|
|||||||
# Intel Driver source
|
# Intel Driver source
|
||||||
i40e-*/
|
i40e-*/
|
||||||
igb-*/
|
igb-*/
|
||||||
ethernet-linux-ixgbe/
|
ethernet-linux-*/
|
||||||
ixgbevf-*/
|
|
||||||
vyos-intel-*/
|
vyos-intel-*/
|
||||||
vyos-linux-firmware*/
|
vyos-linux-firmware*/
|
||||||
kernel-vars
|
kernel-vars
|
||||||
|
|||||||
@ -1,105 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
CWD=$(pwd)
|
|
||||||
KERNEL_VAR_FILE=${CWD}/kernel-vars
|
|
||||||
|
|
||||||
if ! dpkg-architecture -iamd64; then
|
|
||||||
echo "Intel ixgbevf is only buildable on amd64 platforms"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -f ${KERNEL_VAR_FILE} ]; then
|
|
||||||
echo "Kernel variable file '${KERNEL_VAR_FILE}' does not exist, run ./build_kernel.sh first"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
. ${KERNEL_VAR_FILE}
|
|
||||||
|
|
||||||
url="https://sourceforge.net/projects/e1000/files/ixgbevf%20stable/4.18.9/ixgbevf-4.18.9.tar.gz"
|
|
||||||
|
|
||||||
cd ${CWD}
|
|
||||||
|
|
||||||
DRIVER_FILE=$(basename ${url} | sed -e s/tar_0/tar/)
|
|
||||||
DRIVER_DIR="${DRIVER_FILE%.tar.gz}"
|
|
||||||
DRIVER_NAME="ixgbevf"
|
|
||||||
DRIVER_VERSION=$(echo ${DRIVER_DIR} | awk -F${DRIVER_NAME} '{print $2}' | sed 's/^-//')
|
|
||||||
DRIVER_VERSION_EXTRA=""
|
|
||||||
|
|
||||||
# Build up Debian related variables required for packaging
|
|
||||||
DEBIAN_ARCH=$(dpkg --print-architecture)
|
|
||||||
DEBIAN_DIR="${CWD}/vyos-intel-${DRIVER_NAME}_${DRIVER_VERSION}_${DEBIAN_ARCH}"
|
|
||||||
DEBIAN_CONTROL="${DEBIAN_DIR}/DEBIAN/control"
|
|
||||||
DEBIAN_POSTINST="${CWD}/vyos-intel-ixgbevf.postinst"
|
|
||||||
|
|
||||||
# Fetch Intel driver source from SourceForge
|
|
||||||
if [ -e ${DRIVER_FILE} ]; then
|
|
||||||
rm -f ${DRIVER_FILE}
|
|
||||||
fi
|
|
||||||
curl -L -o ${DRIVER_FILE} ${url}
|
|
||||||
if [ "$?" -ne "0" ]; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Unpack archive
|
|
||||||
if [ -d ${DRIVER_DIR} ]; then
|
|
||||||
rm -rf ${DRIVER_DIR}
|
|
||||||
fi
|
|
||||||
mkdir -p ${DRIVER_DIR}
|
|
||||||
tar -C ${DRIVER_DIR} --strip-components=1 -xf ${DRIVER_FILE}
|
|
||||||
|
|
||||||
cd ${DRIVER_DIR}/src
|
|
||||||
if [ -z $KERNEL_DIR ]; then
|
|
||||||
echo "KERNEL_DIR not defined"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# See https://lore.kernel.org/lkml/f90837d0-810e-5772-7841-28d47c44d260@intel.com/
|
|
||||||
echo "I: remove pci_enable_pcie_error_reporting() code no longer present in Kernel"
|
|
||||||
sed -i '/.*pci_disable_pcie_error_reporting(pdev);/d' ixgbevf_main.c
|
|
||||||
sed -i '/.*pci_enable_pcie_error_reporting(pdev);/d' ixgbevf_main.c
|
|
||||||
|
|
||||||
echo "I: Compile Kernel module for Intel ${DRIVER_NAME} driver"
|
|
||||||
make KSRC=${KERNEL_DIR} INSTALL_MOD_PATH=${DEBIAN_DIR} INSTALL_FW_PATH=${DEBIAN_DIR} -j $(getconf _NPROCESSORS_ONLN) install
|
|
||||||
|
|
||||||
if [ "x$?" != "x0" ]; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f ${DEBIAN_DIR}.deb ]; then
|
|
||||||
rm ${DEBIAN_DIR}.deb
|
|
||||||
fi
|
|
||||||
|
|
||||||
# build Debian package
|
|
||||||
echo "I: Building Debian package vyos-intel-${DRIVER_NAME}"
|
|
||||||
cd ${CWD}
|
|
||||||
|
|
||||||
# Sign generated Kernel modules
|
|
||||||
${CWD}/sign-modules.sh ${DEBIAN_DIR}
|
|
||||||
|
|
||||||
# delete non required files which are also present in the kernel package
|
|
||||||
# und thus lead to duplicated files
|
|
||||||
find ${DEBIAN_DIR} -name "modules.*" | xargs rm -f
|
|
||||||
|
|
||||||
echo "#!/bin/sh" > ${DEBIAN_POSTINST}
|
|
||||||
echo "/sbin/depmod -a ${KERNEL_VERSION}${KERNEL_SUFFIX}" >> ${DEBIAN_POSTINST}
|
|
||||||
|
|
||||||
fpm --input-type dir --output-type deb --name vyos-intel-${DRIVER_NAME} \
|
|
||||||
--version ${DRIVER_VERSION} --deb-compression gz \
|
|
||||||
--maintainer "VyOS Package Maintainers <maintainers@vyos.net>" \
|
|
||||||
--description "Vendor based driver for Intel ${DRIVER_NAME}" \
|
|
||||||
--depends linux-image-${KERNEL_VERSION}${KERNEL_SUFFIX} \
|
|
||||||
--license "GPL2" -C ${DEBIAN_DIR} --after-install ${DEBIAN_POSTINST}
|
|
||||||
|
|
||||||
# echo "I: Cleanup ${DRIVER_NAME} source"
|
|
||||||
# cd ${CWD}
|
|
||||||
# if [ -e ${DRIVER_FILE} ]; then
|
|
||||||
# rm -f ${DRIVER_FILE}
|
|
||||||
# fi
|
|
||||||
# if [ -d ${DRIVER_DIR} ]; then
|
|
||||||
# rm -rf ${DRIVER_DIR}
|
|
||||||
# fi
|
|
||||||
# if [ -d ${DEBIAN_DIR} ]; then
|
|
||||||
# rm -rf ${DEBIAN_DIR}
|
|
||||||
# fi
|
|
||||||
# if [ -f ${DEBIAN_POSTINST} ]; then
|
|
||||||
# rm -f ${DEBIAN_POSTINST}
|
|
||||||
# fi
|
|
||||||
@ -3,7 +3,7 @@ CWD=$(pwd)
|
|||||||
KERNEL_VAR_FILE=${CWD}/kernel-vars
|
KERNEL_VAR_FILE=${CWD}/kernel-vars
|
||||||
|
|
||||||
if ! dpkg-architecture -iamd64; then
|
if ! dpkg-architecture -iamd64; then
|
||||||
echo "Intel ixgbe is only buildable on amd64 platforms"
|
echo "Intel drivers only buildable on amd64 platforms"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -19,24 +19,24 @@ if [ -z $KERNEL_DIR ]; then
|
|||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
cd ${CWD}/ethernet-linux-ixgbe
|
DRIVER_NAME=$1
|
||||||
|
cd ${CWD}/ethernet-linux-${DRIVER_NAME}
|
||||||
if [ -d .git ]; then
|
if [ -d .git ]; then
|
||||||
git clean --force -d -x
|
git clean --force -d -x
|
||||||
git reset --hard origin/main
|
git reset --hard origin/main
|
||||||
fi
|
fi
|
||||||
|
|
||||||
DRIVER_NAME="ixgbe"
|
|
||||||
DRIVER_VERSION=$(git describe | sed s/^v//)
|
DRIVER_VERSION=$(git describe | sed s/^v//)
|
||||||
|
|
||||||
# Build up Debian related variables required for packaging
|
# Build up Debian related variables required for packaging
|
||||||
DEBIAN_ARCH=$(dpkg --print-architecture)
|
DEBIAN_ARCH=$(dpkg --print-architecture)
|
||||||
DEBIAN_DIR="${CWD}/vyos-intel-${DRIVER_NAME}_${DRIVER_VERSION}_${DEBIAN_ARCH}"
|
DEBIAN_DIR="${CWD}/vyos-intel-${DRIVER_NAME}_${DRIVER_VERSION}_${DEBIAN_ARCH}"
|
||||||
DEBIAN_CONTROL="${DEBIAN_DIR}/DEBIAN/control"
|
DEBIAN_CONTROL="${DEBIAN_DIR}/DEBIAN/control"
|
||||||
DEBIAN_POSTINST="${CWD}/vyos-intel-ixgbe.postinst"
|
DEBIAN_POSTINST="${CWD}/vyos-intel-${DRIVER_NAME}.postinst"
|
||||||
|
|
||||||
# See https://vyos.dev/T6155
|
# See https://vyos.dev/T6155
|
||||||
# See https://vyos.dev/T6162
|
# See https://vyos.dev/T6162
|
||||||
PATCH_DIR=${CWD}/patches/ixgbe
|
PATCH_DIR=${CWD}/patches/${DRIVER_NAME}
|
||||||
if [ -d $PATCH_DIR ]; then
|
if [ -d $PATCH_DIR ]; then
|
||||||
for patch in $(ls ${PATCH_DIR})
|
for patch in $(ls ${PATCH_DIR})
|
||||||
do
|
do
|
||||||
@ -131,10 +131,12 @@ def build_package(package: dict, dependencies: list) -> None:
|
|||||||
create_tarball(f'{package["name"]}-{package["commit_id"]}', f'{package["name"]}')
|
create_tarball(f'{package["name"]}-{package["commit_id"]}', f'{package["name"]}')
|
||||||
elif package['build_cmd'] == 'build_intel_qat':
|
elif package['build_cmd'] == 'build_intel_qat':
|
||||||
build_intel_qat()
|
build_intel_qat()
|
||||||
|
elif package['build_cmd'] == 'build_intel_igb':
|
||||||
|
build_intel(package['name'], package['commit_id'], package['scm_url'])
|
||||||
elif package['build_cmd'] == 'build_intel_ixgbe':
|
elif package['build_cmd'] == 'build_intel_ixgbe':
|
||||||
build_intel_ixgbe(package['commit_id'], package['scm_url'])
|
build_intel(package['name'], package['commit_id'], package['scm_url'])
|
||||||
elif package['build_cmd'] == 'build_intel_ixgbevf':
|
elif package['build_cmd'] == 'build_intel_ixgbevf':
|
||||||
build_intel_ixgbevf()
|
build_intel(package['name'], package['commit_id'], package['scm_url'])
|
||||||
elif package['build_cmd'] == 'build_mellanox_ofed':
|
elif package['build_cmd'] == 'build_mellanox_ofed':
|
||||||
build_mellanox_ofed()
|
build_mellanox_ofed()
|
||||||
elif package['build_cmd'] == 'build_realtek_r8152':
|
elif package['build_cmd'] == 'build_realtek_r8152':
|
||||||
@ -215,16 +217,11 @@ def build_intel_qat():
|
|||||||
run(['./build-intel-qat.sh'], check=True)
|
run(['./build-intel-qat.sh'], check=True)
|
||||||
|
|
||||||
|
|
||||||
def build_intel_ixgbe(commit_id, scm_url):
|
def build_intel(driver_name: str, commit_id: str, scm_url: str):
|
||||||
"""Build Intel IXGBE"""
|
"""Build Intel driver from Git repository"""
|
||||||
repo_dir = Path('ethernet-linux-ixgbe')
|
repo_dir = Path(f'ethernet-linux-{driver_name}')
|
||||||
clone_or_update_repo(repo_dir, scm_url, commit_id)
|
clone_or_update_repo(repo_dir, scm_url, commit_id)
|
||||||
run(['./build-intel-ixgbe.sh'], check=True)
|
run(['./build-intel-nic.sh', driver_name], check=True)
|
||||||
|
|
||||||
|
|
||||||
def build_intel_ixgbevf():
|
|
||||||
"""Build Intel IXGBEVF"""
|
|
||||||
run(['./build-intel-ixgbevf.sh'], check=True)
|
|
||||||
|
|
||||||
|
|
||||||
def build_mellanox_ofed():
|
def build_mellanox_ofed():
|
||||||
|
|||||||
@ -42,6 +42,12 @@ commit_id = ""
|
|||||||
scm_url = ""
|
scm_url = ""
|
||||||
build_cmd = "build_intel_qat"
|
build_cmd = "build_intel_qat"
|
||||||
|
|
||||||
|
[[packages]]
|
||||||
|
name = "igb"
|
||||||
|
commit_id = "v5.18.7"
|
||||||
|
scm_url = "https://github.com/intel/ethernet-linux-igb"
|
||||||
|
build_cmd = "build_intel_igb"
|
||||||
|
|
||||||
[[packages]]
|
[[packages]]
|
||||||
name = "ixgbe"
|
name = "ixgbe"
|
||||||
commit_id = "v6.0.5"
|
commit_id = "v6.0.5"
|
||||||
@ -50,8 +56,8 @@ build_cmd = "build_intel_ixgbe"
|
|||||||
|
|
||||||
[[packages]]
|
[[packages]]
|
||||||
name = "ixgbevf"
|
name = "ixgbevf"
|
||||||
commit_id = ""
|
commit_id = "v5.0.2"
|
||||||
scm_url = ""
|
scm_url = "http://github.com/intel/ethernet-linux-ixgbevf"
|
||||||
build_cmd = "build_intel_ixgbevf"
|
build_cmd = "build_intel_ixgbevf"
|
||||||
|
|
||||||
[[packages]]
|
[[packages]]
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user