> From: Stephen Hemminger [mailto:step...@networkplumber.org]
> Sent: Thursday, 10 August 2023 19.03
> 
> On Thu, 10 Aug 2023 18:49:09 +0200
> Thomas Monjalon <tho...@monjalon.net> wrote:
> 
> > 10/08/2023 18:35, Bruce Richardson:
> > > On Thu, Aug 10, 2023 at 07:48:39AM -0700, Stephen Hemminger wrote:
> > > > On Thu, 10 Aug 2023 15:34:43 +0200
> > > > Thomas Monjalon <tho...@monjalon.net> wrote:
> > > >
> > > > > 03/08/2023 15:36, David Marchand:
> > > > > > On Wed, Aug 2, 2023 at 2:32 PM Bruce Richardson
> > > > > > <bruce.richard...@intel.com> wrote:
> > > > > > >
> > > > > > > As previously announced, DPDK 23.11 will require a C11
> supporting
> > > > > > > compiler and will use the C11 standard in all builds.
> > > > > > >
> > > > > > > Forcing use of the C standard, rather than the standard with
> > > > > > > GNU extensions, means that some posix definitions which are
> not in
> > > > > > > the C standard are unavailable by default. We fix this by
> ensuring
> > > > > > > the correct defines or cflags are passed to the components
> that
> > > > > > > need them.
> > > > > > >
> > > > > > > Signed-off-by: Bruce Richardson <bruce.richard...@intel.com>
> > > > > > > Acked-by: Morten Brørup <m...@smartsharesystems.com>
> > > > > > > Acked-by: Tyler Retzlaff <roret...@linux.microsoft.com>
> > > > > > Tested-by: Ali Alnubani <alia...@nvidia.com>
> > > > > >
> > > > > > The CI results look good.
> > > > > >
> > > > > > Applied, thanks!
> > > > >
> > > > > The compiler support is updated, that's fine.
> > > > > Should we go further and document some major Linux distributions?
> > > > > One concern is to make clear RHEL 7 is not supported anymore.
> > > > > Should it be a release note?
> > > > >
> > >
> > > Well, DPDK currently is still building fine on Centos 7 for me, so
> let's
> > > hold off on claiming anything until it's definitely broken.
> > >
> > > > >
> > > >
> > > > Should be addressed in linux/sys_reqs.rst as well as deprecation
> notice.
> > > > Also, is it possible to add automated check in build for compiler
> version?
> > >
> > > I'd be a little careful about what we claim, and I think current docs
> are
> > > accurate vs our original plans. What we didn't plan to support was
> the GCC
> > > and Clang compiler versions in RHEL 7, but if one installs an updated
> GCC,
> > > for example, the build should be fine on RHEL 7.
> > >
> > > Now, though, we are having to re-evaluate our use of stdatomics,
> which
> > > means we may not actually break RHEL 7 compatibility after all. We'll
> have
> > > to "watch this space" as the saying goes!
> > >
> > > Overall, I think the approach of build-time checks is the best, but
> not
> > > for specific versions, but instead for capabilities. If/when we add
> support
> > > for stdatomics to DPDK builds on Linux/BSD, at that point we put in
> the
> > > initial compiler checks a suitable check for them being present and
> output
> > > a suitable error if not found.

Exactly. Capabilities checks is the right way to go when cross compiling.

> >
> > OK looks good
> 
> Note: RHEL 7 official end of maintenance support is not until June 2024.
> 

It was agreed to abandon RHEL 7, mainly driven by the need for C11 stdatomic.h, 
which is not supported by the GCC C compiler included with RHEL 7. So it pains 
me to admit that Stephen has a valid point here, after it turned out that the 
GCC g++ is not C11 compatible.

Regardless, I think that DPDK 23.11 support for RHEL 7 should be limited to 
"might work on RHEL 7", rather than guaranteed support for RHEL 7 (which would 
require DPDK CI to resume testing on RHEL 7).

IIRC, there was also the argument that DPDK 23.11 LTS support ends after June 
2024.

Here's another argument for abandoning RHEL 7: RHEL 7 uses Linux Kernel 3.10. 
Although DPDK requires Linux Kernel >= 4.14, we promise backwards compatibility 
for RHEL/CentOS 7. Do we really still want to do that? (Note: RHEL 8 uses Linux 
Kernel 4.18.)

While we're discussing the Linux Kernel version required... Is it documented 
anywhere why a specific Linux Kernel version is required by DPDK? Or more 
specifically: Is it documented anywhere which DPDK features require which 
specific Linux Kernel versions?

Reply via email to