dev.dpdk.org archive mirror
 help / color / mirror / Atom feed
From: Chris Wright <chrisw-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
To: Thomas Monjalon
	<thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
Cc: dev-VfR2kkLFssw@public.gmane.org
Subject: Re: [PATCH 03/16] pkg: add recipe for RPM
Date: Mon, 24 Feb 2014 08:52:08 -0800	[thread overview]
Message-ID: <20140224165208.GF27503@x220.localdomain> (raw)
In-Reply-To: <1391529271-24606-4-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>

* Thomas Monjalon (thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org) wrote:
> Packages can be built with:
> 	RPM_BUILD_NCPUS=8 rpmbuild -ta dpdk-1.5.2r2.tar.gz
> 
> There are packages for runtime, static libraries and development.
> Once devel package installed, it can be used like this:
> 	make -C /usr/share/dpdk/examples/helloworld RTE_SDK=/usr/share/dpdk
> 
> Signed-off-by: Thomas Monjalon <thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
> ---
>  pkg/rpm.spec |  143 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

This should be dpdk.spec

>  1 file changed, 143 insertions(+)
>  create mode 100644 pkg/rpm.spec
> 
> diff --git a/pkg/rpm.spec b/pkg/rpm.spec
> new file mode 100644
> index 0000000..d806d55
> --- /dev/null
> +++ b/pkg/rpm.spec
> @@ -0,0 +1,143 @@
> +Name: dpdk
> +Version: 1.5.2r1
> +Release: 1

Just wanted to be sure the NVR properly increases.  I verified using
"rpmdev-vercmp" and it looks fine.

> +Packager: packaging-pdR9zngts4EAvxtiuMwx3w@public.gmane.org
> +URL: http://dpdk.org
> +Source: http://dpdk.org/browse/dpdk/snapshot/dpdk-%{version}.tar.gz
> +
> +Summary: Intel(r) Data Plane Development Kit
> +Group: System Environment/Libraries
> +License: BSD and LGPLv2 and GPLv2
> +
> +ExclusiveArch: i686, x86_64
> +%define target %{_arch}-default-linuxapp-gcc

What is this for?

> +%define machine default
> +
> +BuildRequires: kernel-devel, kernel-headers, doxygen
> +
> +%description
> +Dummy main package. Make only subpackages.

I think the core package should have the .so, the -devel package w/
headers, and no -static package.  Including a .a file is discouraged in
Fedora:

https://fedoraproject.org/wiki/Packaging:Guidelines#Packaging_Static_Libraries

because if you need to update the archive, e.g. for a security fix,
applications linked w/ the static library will not get fixed w/out a
rebuild.

> +%package core-runtime

perhaps just 'runtime'

> +Summary: Intel(r) Data Plane Development Kit core for runtime
> +%description core-runtime
> +Intel(r) DPDK runtime includes kernel modules, core libraries and tools.
> +testpmd application allows to test fast packet processing environments
> +on x86 platforms. For instance, it can be used to check that environment
> +can support fast path applications such as 6WINDGate, pktgen, rumptcpip, etc.
> +More libraries are available as extensions in other packages.
> +
> +%package core-static
> +Requires: %{name}-core-runtime
> +Summary: Intel(r) Data Plane Development Kit core as static libraries
> +%description core-static
> +Intel(r) DPDK static provides static version of the core libraries
> +for fast packet processing on x86 platforms.
> +More libraries are available as extensions in other packages.

We drop this

> +%package core-devel

name this devel

> +Requires: %{name}-core-static
> +Summary: Intel(r) Data Plane Development Kit core for development
> +%description core-devel
> +Intel(r) DPDK devel is a set of makefiles, headers, examples and documentation
> +for fast packet processing on x86 platforms.
> +More libraries are available as extensions in other packages.

Often it's just headers, but makefile, examples, etc are quite useful
for showing how to develop a dpdk app

> +# debuginfo packaging is broken
> +%define debug_package %{nil}

Can you add a better comment why it's broken?

> +%define destdir %{buildroot}%{_prefix}
> +%define moddir  /lib/modules/%(uname -r)/extra
> +%define datadir %{_datadir}/%{name}
> +%define docdir  %{_docdir}/%{name}
> +
> +%prep
> +%setup -q
> +
> +%build
> +make O=%{target} T=%{target} config

Did you try to update the build system to output into $RPM_BUILD_ROOT
directly?  It's much preferred compared to the cp/rmdir below

> +sed -ri 's,(RTE_MACHINE=).*,\1%{machine},' %{target}/.config
> +sed -ri 's,(RTE_APP_TEST=).*,\1n,'         %{target}/.config
> +sed -ri 's,(RTE_BUILD_SHARED_LIB=).*,\1y,' %{target}/.config
> +make O=%{target} %{?_smp_mflags}
> +cp %{target}/lib/*.so %{target}
> +sed -ri 's,(RTE_BUILD_SHARED_LIB=).*,\1n,' %{target}/.config
> +make O=%{target} %{?_smp_mflags}
> +make O=%{target} doc
> +
> +%install
> +rm -rf %{buildroot}
> +make           O=%{target}     DESTDIR=%{destdir}

Why make again (IOW, why not in %build section)?

> +mkdir -p                               %{buildroot}%{moddir}
> +mv    %{destdir}/%{target}/kmod/*.ko   %{buildroot}%{moddir}

Normally I'd use install command (-d will create directories)

> +rmdir %{destdir}/%{target}/kmod
> +mkdir -p                               %{buildroot}%{_sbindir}
> +ln -s %{datadir}/tools/igb_uio_bind.py %{buildroot}%{_sbindir}/igb_uio_bind
> +mkdir -p                               %{buildroot}%{_bindir}
> +mv    %{destdir}/%{target}/app/testpmd %{buildroot}%{_bindir}
> +rmdir %{destdir}/%{target}/app
> +mv    %{destdir}/%{target}/include     %{buildroot}%{_includedir}
> +mv    %{destdir}/%{target}/lib         %{buildroot}%{_libdir}
> +mv    %{destdir}/%{target}/*.so        %{buildroot}%{_libdir}
> +mkdir -p                               %{buildroot}%{docdir}
> +mv    %{destdir}/%{target}/doc/*       %{buildroot}%{docdir}
> +rmdir %{destdir}/%{target}/doc
> +mkdir -p                               %{buildroot}%{datadir}
> +mv    %{destdir}/%{target}/.config     %{buildroot}%{datadir}/config
> +mv    %{destdir}/%{target}             %{buildroot}%{datadir}
> +mv    %{destdir}/mk                    %{buildroot}%{datadir}
> +cp -a            examples              %{buildroot}%{datadir}
> +cp -a            tools                 %{buildroot}%{datadir}
> +ln -s            %{datadir}/config     %{buildroot}%{datadir}/%{target}/.config
> +ln -s            %{_includedir}        %{buildroot}%{datadir}/%{target}/include
> +ln -s            %{_libdir}            %{buildroot}%{datadir}/%{target}/lib
> +
> +%files core-runtime
> +%dir %{datadir}
> +%{datadir}/config
> +%{datadir}/tools
> +%{moddir}/*
> +%{_sbindir}/*
> +%{_bindir}/*
> +%{_libdir}/*.so
> +
> +%files core-static
> +%{_libdir}/*.a
> +
> +%files core-devel
> +%{_includedir}/*
> +%{datadir}/mk
> +%{datadir}/%{target}
> +%{datadir}/examples
> +%doc %{docdir}

  parent reply	other threads:[~2014-02-24 16:52 UTC|newest]

Thread overview: 52+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-02-04 15:54 [PATCH 00/16] recipes for RPM packages Thomas Monjalon
     [not found] ` <1391529271-24606-1-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-04 15:54   ` [PATCH 01/16] tools: rename pci_unbind script Thomas Monjalon
     [not found]     ` <1391529271-24606-2-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-24 16:03       ` Chris Wright
     [not found]         ` <20140224160342.GB27503-SwUeJysX96B82hYKe6nXyg@public.gmane.org>
2014-03-20 17:06           ` Thomas Monjalon
2014-02-04 15:54   ` [PATCH 02/16] virtio: rename library Thomas Monjalon
     [not found]     ` <1391529271-24606-3-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-24 16:05       ` Chris Wright
     [not found]         ` <20140224160510.GC27503-SwUeJysX96B82hYKe6nXyg@public.gmane.org>
2014-03-20 17:06           ` Thomas Monjalon
2014-02-04 15:54   ` [PATCH 03/16] pkg: add recipe for RPM Thomas Monjalon
     [not found]     ` <1391529271-24606-4-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-24 16:29       ` Chris Wright
2014-02-24 16:52       ` Chris Wright [this message]
     [not found]         ` <20140224165208.GF27503-SwUeJysX96B82hYKe6nXyg@public.gmane.org>
2014-04-02  9:01           ` Thomas Monjalon
2014-04-02 11:11             ` Thomas Graf
2014-02-26 13:07       ` Thomas Graf
     [not found]         ` <530DE720.6090804-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2014-02-26 16:19           ` Chris Wright
2014-04-02  9:53           ` Thomas Monjalon
2014-04-02 11:04             ` Thomas Graf
2014-04-02 11:29             ` Neil Horman
2014-02-04 15:54   ` [vmxnet3-usermap PATCH 04/16] pmd: add make help Thomas Monjalon
     [not found]     ` <1391529271-24606-5-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-24 18:17       ` Chris Wright
     [not found]         ` <20140224181706.GB10251-SwUeJysX96B82hYKe6nXyg@public.gmane.org>
2014-03-26 21:59           ` Thomas Monjalon
2014-02-04 15:54   ` [vmxnet3-usermap PATCH 05/16] pmd: allow to build outside of the source directory Thomas Monjalon
     [not found]     ` <1391529271-24606-6-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-24 18:13       ` Chris Wright
     [not found]         ` <20140224181347.GA10251-SwUeJysX96B82hYKe6nXyg@public.gmane.org>
2014-03-26 21:59           ` Thomas Monjalon
2014-02-04 15:54   ` [vmxnet3-usermap PATCH 06/16] pmd: allow to install lib and doc Thomas Monjalon
     [not found]     ` <1391529271-24606-7-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-26 22:00       ` Thomas Monjalon
2014-02-04 15:54   ` [vmxnet3-usermap PATCH 07/16] pkg: add recipe for RPM Thomas Monjalon
     [not found]     ` <1391529271-24606-8-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-02-26 13:22       ` Thomas Graf
     [not found]         ` <530DEA9C.8060101-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2014-04-02 10:08           ` Thomas Monjalon
2014-04-02 11:07             ` Thomas Graf
2014-02-04 15:54   ` [virtio-net-pmd PATCH 08/16] pmd: fix initialization of Tx queue header Thomas Monjalon
     [not found]     ` <1391529271-24606-9-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:23       ` Olivier MATZ
     [not found]         ` <5333E00C.3090806-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  9:34           ` Thomas Monjalon
2014-02-04 15:54   ` [virtio-net-pmd PATCH 09/16] mk: minor fixes Thomas Monjalon
     [not found]     ` <1391529271-24606-10-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:26       ` Olivier MATZ
     [not found]         ` <5333E0B0.30704-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  9:35           ` Thomas Monjalon
2014-02-04 15:54   ` [virtio-net-pmd PATCH 10/16] mk: allow to build outside of the source directory Thomas Monjalon
     [not found]     ` <1391529271-24606-11-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:31       ` Olivier MATZ
     [not found]         ` <5333E1C9.4020607-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  9:35           ` Thomas Monjalon
2014-02-04 15:54   ` [virtio-net-pmd PATCH 11/16] mk: allow to install lib and doc Thomas Monjalon
     [not found]     ` <1391529271-24606-12-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:32       ` Olivier MATZ
     [not found]         ` <5333E215.3020103-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  9:35           ` Thomas Monjalon
2014-02-04 15:54   ` [virtio-net-pmd PATCH 12/16] pkg: add recipe for RPM Thomas Monjalon
2014-02-04 15:54   ` [memnic PATCH 13/16] pmd: rename doc when installing Thomas Monjalon
     [not found]     ` <1391529271-24606-14-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:36       ` Olivier MATZ
     [not found]         ` <5333E2F3.6060503-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27 10:29           ` Thomas Monjalon
2014-02-04 15:54   ` [memnic PATCH 14/16] pmd: fix doc uninstalling Thomas Monjalon
     [not found]     ` <1391529271-24606-15-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:45       ` Olivier MATZ
     [not found]         ` <5333E521.6050202-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27 10:30           ` Thomas Monjalon
2014-02-04 15:54   ` [memnic PATCH 15/16] pmd: remove useless makefile variables Thomas Monjalon
     [not found]     ` <1391529271-24606-16-git-send-email-thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27  8:45       ` Olivier MATZ
     [not found]         ` <5333E53F.2050209-pdR9zngts4EAvxtiuMwx3w@public.gmane.org>
2014-03-27 10:30           ` Thomas Monjalon
2014-02-04 15:54   ` [memnic PATCH 16/16] pkg: add recipe for RPM Thomas Monjalon

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20140224165208.GF27503@x220.localdomain \
    --to=chrisw-h+wxahxf7alqt0dzr+alfa@public.gmane.org \
    --cc=dev-VfR2kkLFssw@public.gmane.org \
    --cc=thomas.monjalon-pdR9zngts4EAvxtiuMwx3w@public.gmane.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).