numam-dpdk/drivers/common/mlx5/linux
David Marchand 1094dd940e cleanup compat header inclusions
With symbols going though experimental/stable stages, we accumulated
a lot of discrepancies about inclusion of the rte_compat.h header.

Some headers are including it where unneeded, while others rely on
implicit inclusion.

Fix unneeded inclusions:
$ git grep -l include..rte_compat.h |
  xargs grep -LE '__rte_(internal|experimental)' |
  xargs sed -i -e '/#include..rte_compat.h/d'

Fix missing inclusion, by inserting rte_compat.h before the first
inclusion of a DPDK header:
$ git grep -lE '__rte_(internal|experimental)' |
  xargs grep -L include..rte_compat.h |
  xargs sed -i -e \
    '0,/#include..\(rte_\|.*pmd.h.$\)/{
      s/\(#include..\(rte_\|.*pmd.h.$\)\)/#include <rte_compat.h>\n\1/
    }'

Fix missing inclusion, by inserting rte_compat.h after the last
inclusion of a non DPDK header:
$ for file in $(git grep -lE '__rte_(internal|experimental)' |
  xargs grep -L include..rte_compat.h); do
    tac $file > $file.$$
    sed -i -e \
      '0,/#include../{
        s/\(#include..*$\)/#include <rte_compat.h>\n\n\1/
      }' $file.$$
    tac $file.$$ > $file
    rm $file.$$
  done

Fix missing inclusion, by inserting rte_compat.h after the header guard:
$ git grep -lE '__rte_(internal|experimental)' |
  xargs grep -L include..rte_compat.h |
  xargs sed -i -e \
    '0,/#define/{
      s/\(#define .*$\)/\1\n\n#include <rte_compat.h>/
    }'

And finally, exclude rte_compat.h itself.
$ git checkout lib/eal/include/rte_compat.h

At the end of all this, we have a clean tree:
$ git grep -lE '__rte_(internal|experimental)' |
  xargs grep -L include..rte_compat.h
buildtools/check-symbols.sh
devtools/checkpatches.sh
doc/guides/contributing/abi_policy.rst
doc/guides/rel_notes/release_20_11.rst
lib/eal/include/rte_compat.h

Signed-off-by: David Marchand <david.marchand@redhat.com>
Acked-by: Bruce Richardson <bruce.richardson@intel.com>
Acked-by: Andrew Rybchenko <andrew.rybchenko@oktetlabs.ru>
2022-11-15 08:39:14 +01:00
..
meson.build common/mlx5: move build config initialization and check 2022-10-30 15:55:46 +01:00
mlx5_common_auxiliary.c bus/auxiliary: make driver-only headers private 2022-09-23 16:14:34 +02:00
mlx5_common_os.c bus/pci: make driver-only headers private 2022-09-23 16:14:34 +02:00
mlx5_common_os.h cleanup compat header inclusions 2022-11-15 08:39:14 +01:00
mlx5_common_verbs.c common/mlx5: add global MR cache create function 2021-10-21 15:57:24 +02:00
mlx5_glue.c common/mlx5: add glue functions for hardware steering 2022-10-26 13:33:32 +02:00
mlx5_glue.h common/mlx5: add glue functions for hardware steering 2022-10-26 13:33:32 +02:00
mlx5_nl.c common/mlx5: add Netlink event helpers 2022-03-01 16:54:03 +01:00
mlx5_nl.h cleanup compat header inclusions 2022-11-15 08:39:14 +01:00