xref: /spdk/scripts/env_dpdk/check_dpdk_pci_api.sh (revision a61399316d94a0ce38008c17c4a2742fe213ec64)
144290e13STomasz Zawadzki#!/usr/bin/env bash
244290e13STomasz Zawadzki#  SPDX-License-Identifier: BSD-3-Clause
344290e13STomasz Zawadzki#  Copyright (C) 2022 Intel Corporation
444290e13STomasz Zawadzki#  All rights reserved.
544290e13STomasz Zawadzki#
644290e13STomasz Zawadzki
744290e13STomasz Zawadzkiscriptdir=$(readlink -f "$(dirname "$0")")
844290e13STomasz Zawadzkirootdir=$(readlink -f "$scriptdir/../..")
944290e13STomasz Zawadzkisource "$rootdir/scripts/common.sh"
1044290e13STomasz Zawadzki
1144290e13STomasz Zawadzkiset -e
1244290e13STomasz Zawadzkishopt -s extglob
1344290e13STomasz Zawadzki
1444290e13STomasz Zawadzkimode=${1:-check} # check or fix
1544290e13STomasz Zawadzki
1644290e13STomasz Zawadzki# By default verify headers matching the DPDK submodule
1744290e13STomasz Zawadzkidpdk_dir=${2:-"$rootdir/dpdk"}
1844290e13STomasz Zawadzkidpdk_ver=$(< "$dpdk_dir/VERSION")
1944290e13STomasz Zawadzki
2044290e13STomasz Zawadzkienv_path="$rootdir/lib/env_dpdk"
2144290e13STomasz Zawadzkitracked_versions=("$env_path/"+([0-9]).+([0-9])/*.h)
2244290e13STomasz Zawadzkitracked_versions=("${tracked_versions[@]#"$env_path/"}")
2344290e13STomasz Zawadzkitracked_versions=("${tracked_versions[@]%/*}")
2444290e13STomasz Zawadzki
2544290e13STomasz Zawadzki# The DPDK PCI API tracking started with DPDK 22.11, all prior versions will use DPDK 22.07 headers
2644290e13STomasz Zawadzkitarget_ver="22.07"
2744290e13STomasz Zawadzkiwhile read -r ver; do
2844290e13STomasz Zawadzki	ge "$dpdk_ver" "$ver" && target_ver=$ver && break
2944290e13STomasz Zawadzkidone < <(printf "%s\n" "${tracked_versions[@]}" | sort -Vru)
3044290e13STomasz Zawadzki
3144290e13STomasz Zawadzkiecho "Checking DPDK PCI API from $dpdk_ver against $target_ver ..."
3244290e13STomasz Zawadzki
3344290e13STomasz Zawadzkitarget_headers=("$env_path/$target_ver/"*.h)
3444290e13STomasz Zawadzkitarget_headers=("${target_headers[@]##*/}")
3544290e13STomasz Zawadzki
3644290e13STomasz Zawadzki# The includes should point to headers in SPDK tree rather than system ones.
3744290e13STomasz Zawadzkiuse_local_includes="-e "
3844290e13STomasz Zawadzkifor header in "${target_headers[@]}"; do
3944290e13STomasz Zawadzki	use_local_includes+="s/#include <$header>/#include \"$header\"/g;"
4044290e13STomasz Zawadzkidone
4144290e13STomasz Zawadzki
4244290e13STomasz Zawadzkifor header in "${target_headers[@]}"; do
4344290e13STomasz Zawadzki	dpdk_file="$dpdk_dir/$(git -C "$dpdk_dir" ls-files "*/$header")"
4444290e13STomasz Zawadzki
4544290e13STomasz Zawadzki	# Patch DPDK header with any workarounds necessary
4644290e13STomasz Zawadzki	patch_file="$scriptdir/$target_ver/$header.patch"
4744290e13STomasz Zawadzki	if [[ -s $patch_file ]]; then
4844290e13STomasz Zawadzki		dpdk_header=$(patch -s "$dpdk_file" "$patch_file" -o - | sed "$use_local_includes")
4944290e13STomasz Zawadzki	else
5044290e13STomasz Zawadzki		dpdk_header=$(sed "$use_local_includes" "$dpdk_file")
5144290e13STomasz Zawadzki	fi
5244290e13STomasz Zawadzki
5344290e13STomasz Zawadzki	spdk_file="$env_path/$target_ver/$header"
5444290e13STomasz Zawadzki	if ! single_diff=$(diff -u "$spdk_file" <(echo "$dpdk_header")); then
5544290e13STomasz Zawadzki		header_diff+="$single_diff\n"
5644290e13STomasz Zawadzki	fi
5744290e13STomasz Zawadzkidone
5844290e13STomasz Zawadzki
5944290e13STomasz Zawadzkiif [[ -z "$header_diff" ]]; then
6044290e13STomasz Zawadzki	echo "No differences in headers found."
6144290e13STomasz Zawadzki	exit 0
6244290e13STomasz Zawadzkifi
6344290e13STomasz Zawadzki
6444290e13STomasz Zawadzkiif [[ "$mode" == "check" ]]; then
6544290e13STomasz Zawadzki	cat <<- CHECK
6644290e13STomasz Zawadzki		$(echo -e "$header_diff")
6744290e13STomasz Zawadzki
6844290e13STomasz Zawadzki		Differences in DPDK and internal SPDK headers found.
6944290e13STomasz Zawadzki		For changes that do not affect the API, please use 'fix' as \$1 to this script.
70*a6139931STomasz Zawadzki		If API was changed, please create "$env_path/${dpdk_ver%.*}/" with appropriate headers.
7144290e13STomasz Zawadzki
7244290e13STomasz Zawadzki	CHECK
7344290e13STomasz Zawadzkielif [[ "$mode" == "fix" ]]; then
7444290e13STomasz Zawadzki	echo -e "$header_diff" | patch -d "$env_path/$target_ver/"
7544290e13STomasz Zawadzki	echo "Fixed differences between DPDK and internal SPDK headers."
7644290e13STomasz Zawadzkielse
7744290e13STomasz Zawadzki	echo "Incorrect \$1 passed, please use 'check' or 'fix'."
7844290e13STomasz Zawadzki	exit 1
7944290e13STomasz Zawadzkifi
80