[oe] [meta-oe][PATCH] parted_1.8.6.bb: add parted that not GPLv3

Martin Jansa martin.jansa at gmail.com
Mon Aug 31 17:58:44 UTC 2015


On Mon, Jul 06, 2015 at 09:51:34AM +0800, Lei Maohui wrote:
> In oe-core,the parted is GPLv3,so add parted-1.8.6 which is not GPLv3.
> 
> Signed-off-by: Lei Maohui <leimaohui at cn.fujitsu.com>
> ---
>  .../parted-1.8.6/1000parted-1.8.6-warnings1.patch  | 11 ++++
>  .../1001parted-1.8.6-notransname1.patch            | 39 ++++++++++++++
>  .../1002parted-1.8.6-off-by-one1.patch             | 25 +++++++++
>  .../1003parted-1.8.6-primary-boundary1.patch       | 12 +++++
>  .../parted-1.8.6/1004parted-1.8.6-xvd1.patch       | 50 +++++++++++++++++
>  .../1005parted-1.8.6-devmapper-header1.patch       | 13 +++++
>  .../parted/parted-1.8.6/7000no_effect_macro1.patch | 11 ++++
>  .../parted/parted-1.8.6/ui.c-fix-build-error.patch | 26 +++++++++
>  meta-oe/recipes-extended/parted/parted_1.8.6.bb    | 62 ++++++++++++++++++++++
>  9 files changed, 249 insertions(+)
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1000parted-1.8.6-warnings1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1001parted-1.8.6-notransname1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1002parted-1.8.6-off-by-one1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1003parted-1.8.6-primary-boundary1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1004parted-1.8.6-xvd1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/1005parted-1.8.6-devmapper-header1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/7000no_effect_macro1.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted-1.8.6/ui.c-fix-build-error.patch
>  create mode 100644 meta-oe/recipes-extended/parted/parted_1.8.6.bb

I cannot take this to meta-oe, because as soon as it's added there it
will be used by all DISTROs even those who don't mind having GPLv3
version.

Everybody would need to define PREFERRED_VERSION, because
DEFAULT_PREFERENCE is useless across different layers :/
https://bugzilla.yoctoproject.org/show_bug.cgi?id=2964

So this either has to be introduced in oe-core or in completely separate
layer which would be included only by those who cannot use GPLv3.

Regards,

> 
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1000parted-1.8.6-warnings1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1000parted-1.8.6-warnings1.patch
> new file mode 100644
> index 0000000..c8b2e7d
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1000parted-1.8.6-warnings1.patch
> @@ -0,0 +1,11 @@
> +--- parted-1.8.6/libparted/fs/linux_swap/linux_swap.c.warnings	2007-03-20 13:22:36.000000000 -0400
> ++++ parted-1.8.6/libparted/fs/linux_swap/linux_swap.c	2007-03-20 13:59:11.000000000 -0400
> +@@ -123,7 +123,7 @@
> + 
> + error_close_fs:
> + 	swap_close (fs);
> +-error:
> ++
> + 	return 0;
> + }
> + #endif /* !DISCOVER_ONLY */
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1001parted-1.8.6-notransname1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1001parted-1.8.6-notransname1.patch
> new file mode 100644
> index 0000000..5fdf10b
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1001parted-1.8.6-notransname1.patch
> @@ -0,0 +1,39 @@
> +--- parted-1.8.6/parted/parted.c.notransname	2007-03-13 13:01:09.000000000 -0400
> ++++ parted-1.8.6/parted/parted.c	2007-03-21 10:50:35.000000000 -0400
> +@@ -1429,7 +1429,7 @@
> +                                              part->fs_type->name : "");
> + 
> +                             if (has_name) {
> +-                                    name = _(ped_partition_get_name (part));
> ++                                    name = ped_partition_get_name (part);
> +                                     str_list_append (row, name);
> +                             }
> + 
> +--- parted-1.8.6/parted/table.c.notransname	2007-03-13 13:01:09.000000000 -0400
> ++++ parted-1.8.6/parted/table.c	2007-03-21 10:51:31.000000000 -0400
> +@@ -191,7 +191,8 @@
> +         len += wcslen(COLSUFFIX);
> + 
> +         newsize = (wcslen(*s) + len + 1) * sizeof(wchar_t);
> +-        *s = realloc (*s, newsize);
> ++        *s = (wchar_t *) realloc (*s, newsize);
> ++        assert(*s != NULL);
> + 
> +         for (i = 0; i < ncols; ++i)
> +         {
> +@@ -199,6 +200,7 @@
> +                 int nspaces = max(t->widths[i] - wcswidth(row[i], MAX_WIDTH),
> +                                   0);
> +                 wchar_t* pad = malloc ( (nspaces + 1) * sizeof(wchar_t) );
> ++                assert(pad != NULL);
> + 
> +                 for (j = 0; j < nspaces; ++j)
> +                        pad[j] = L' '; 
> +@@ -211,6 +213,7 @@
> +                         wcscat (*s, DELIMITER);
> + 
> +                 free (pad);
> ++                pad = NULL;
> +         }
> + 
> +         wcscat (*s, COLSUFFIX);
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1002parted-1.8.6-off-by-one1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1002parted-1.8.6-off-by-one1.patch
> new file mode 100644
> index 0000000..9652a98
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1002parted-1.8.6-off-by-one1.patch
> @@ -0,0 +1,25 @@
> +--- parted-1.8.6/parted/parted.c.offbyone	2007-04-11 12:13:06.000000000 -0400
> ++++ parted-1.8.6/parted/parted.c	2007-04-11 12:13:21.000000000 -0400
> +@@ -1217,6 +1217,7 @@
> + static int
> + do_print (PedDevice** dev)
> + {
> ++        PedUnit         default_unit;
> +         PedDisk*        disk;
> +         Table*          table;
> +         StrList*        row;
> +@@ -1303,11 +1304,12 @@
> +         }
> + 
> +         start = ped_unit_format (*dev, 0);
> ++        default_unit = ped_unit_get_default ();
> +         end = ped_unit_format_byte (*dev, (*dev)->length * (*dev)->sector_size
> +-                                          - 1 );
> ++         - (default_unit == PED_UNIT_CHS || default_unit == PED_UNIT_CYLINDER));
> +         
> +         if (opt_machine_mode) {
> +-            switch (ped_unit_get_default ()) {
> ++            switch (default_unit) {
> +                 case PED_UNIT_CHS:      puts ("CHS;");
> +                                         break;
> +                 case PED_UNIT_CYLINDER: puts ("CYL;");
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1003parted-1.8.6-primary-boundary1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1003parted-1.8.6-primary-boundary1.patch
> new file mode 100644
> index 0000000..0366977
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1003parted-1.8.6-primary-boundary1.patch
> @@ -0,0 +1,12 @@
> +--- parted-1.8.6/libparted/labels/dos.c.boundary	2007-03-13 13:01:09.000000000 -0400
> ++++ parted-1.8.6/libparted/labels/dos.c	2007-04-11 14:56:54.000000000 -0400
> +@@ -1696,8 +1696,7 @@
> + 					 _primary_start_constraint (disk, part,
> + 						 bios_geom, min_geom)));
> + 
> +-	if (!solution)
> +-		solution = _best_solution (part, bios_geom, solution,
> ++	solution = _best_solution (part, bios_geom, solution,
> + 			_try_constraint (part, constraint,
> + 				_primary_constraint (disk, bios_geom,
> + 				min_geom)));
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1004parted-1.8.6-xvd1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1004parted-1.8.6-xvd1.patch
> new file mode 100644
> index 0000000..17ec29a
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1004parted-1.8.6-xvd1.patch
> @@ -0,0 +1,50 @@
> +diff -up parted-1.8.6/libparted/arch/linux.c.xvd parted-1.8.6/libparted/arch/linux.c
> +--- parted-1.8.6/libparted/arch/linux.c.xvd	2007-08-07 14:05:59.000000000 -0400
> ++++ parted-1.8.6/libparted/arch/linux.c	2007-08-07 14:07:13.000000000 -0400
> +@@ -248,6 +248,7 @@ struct blkdev_ioctl_param {
> + #define VIODASD_MAJOR           112
> + #define SX8_MAJOR1              160
> + #define SX8_MAJOR2              161
> ++#define XVD_MAJOR               202
> + 
> + #define SCSI_BLK_MAJOR(M) (                                             \
> +                 (M) == SCSI_DISK0_MAJOR                                 \
> +@@ -450,6 +451,8 @@ _device_probe_type (PedDevice* dev)
> +         } else if (_is_dm_major(dev_major)) {
> +                 dev->type = PED_DEVICE_DM;
> + #endif
> ++        } else if (dev_major == XVD_MAJOR && (dev_minor % 0x10 == 0)) {
> ++                dev->type = PED_DEVICE_XVD;
> +         } else {
> +                 dev->type = PED_DEVICE_UNKNOWN;
> +         }
> +@@ -1152,6 +1155,11 @@ linux_new (const char* path)
> +                 break;
> + #endif
> + 
> ++        case PED_DEVICE_XVD:
> ++                if (!init_generic (dev, _("Xen Virtual Block Device")))
> ++                        goto error_free_arch_specific;
> ++                break;
> ++
> +         case PED_DEVICE_UNKNOWN:
> +                 if (!init_generic (dev, _("Unknown")))
> +                         goto error_free_arch_specific;
> +diff -up parted-1.8.6/include/parted/device.h.xvd parted-1.8.6/include/parted/device.h
> +--- parted-1.8.6/include/parted/device.h.xvd	2007-01-12 10:15:10.000000000 -0500
> ++++ parted-1.8.6/include/parted/device.h	2007-08-07 14:07:13.000000000 -0400
> +@@ -45,11 +45,11 @@ typedef enum {
> +         PED_DEVICE_UBD          = 8,
> +         PED_DEVICE_DASD         = 9,
> +         PED_DEVICE_VIODASD      = 10,
> +-        PED_DEVICE_SX8          = 11
> ++        PED_DEVICE_SX8          = 11,
> + #ifdef ENABLE_DEVICE_MAPPER
> +-                                    ,
> +-        PED_DEVICE_DM           = 12
> ++        PED_DEVICE_DM           = 12,
> + #endif
> ++        PED_DEVICE_XVD          = 13
> + } PedDeviceType;
> + 
> + typedef struct _PedDevice PedDevice;
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/1005parted-1.8.6-devmapper-header1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/1005parted-1.8.6-devmapper-header1.patch
> new file mode 100644
> index 0000000..536a20d
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/1005parted-1.8.6-devmapper-header1.patch
> @@ -0,0 +1,13 @@
> +diff -up parted-1.8.6/include/parted/device.h.devmapper parted-1.8.6/include/parted/device.h
> +--- parted-1.8.6/include/parted/device.h.devmapper	2007-10-04 15:39:27.000000000 -0400
> ++++ parted-1.8.6/include/parted/device.h	2007-10-04 15:40:11.000000000 -0400
> +@@ -46,9 +46,7 @@ typedef enum {
> +         PED_DEVICE_DASD         = 9,
> +         PED_DEVICE_VIODASD      = 10,
> +         PED_DEVICE_SX8          = 11,
> +-#ifdef ENABLE_DEVICE_MAPPER
> +         PED_DEVICE_DM           = 12,
> +-#endif
> +         PED_DEVICE_XVD          = 13
> + } PedDeviceType;
> + 
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/7000no_effect_macro1.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/7000no_effect_macro1.patch
> new file mode 100644
> index 0000000..033f3f5
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/7000no_effect_macro1.patch
> @@ -0,0 +1,11 @@
> +--- parted-1.8.6/parted/table.c	2010-11-02 13:37:16.256204798 +0900
> ++++ parted-1.8.6/parted/table.c	2010-11-02 13:45:16.231266752 +0900
> +@@ -43,7 +43,7 @@
> + #       define wcslen strlen
> + #       define wcswidth strnlen
> + #       define wcscat strcat
> +-#       define wcsdup strdup
> ++/* #       define wcsdup strdup */
> +         size_t strnlen (const char *, size_t);
> + #endif
> + 
> diff --git a/meta-oe/recipes-extended/parted/parted-1.8.6/ui.c-fix-build-error.patch b/meta-oe/recipes-extended/parted/parted-1.8.6/ui.c-fix-build-error.patch
> new file mode 100644
> index 0000000..777fe6a
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted-1.8.6/ui.c-fix-build-error.patch
> @@ -0,0 +1,26 @@
> +From 4f4dfd5aabdaadd8f495e193ca8daed5a3a1782a Mon Sep 17 00:00:00 2001
> +From: Li xin <lixin.fnst at cn.fujitsu.com>
> +Date: Fri, 28 Nov 2014 02:49:19 +0900
> +Subject: [PATCH] parted/ui.c : fix build error
> +
> +Signed-off-by: Li Xin <lixin.fnst at cn.fujitsu.com>
> +---
> + parted/ui.c | 2 +-
> + 1 file changed, 1 insertion(+), 1 deletion(-)
> +
> +diff --git a/parted/ui.c b/parted/ui.c
> +index 59cb98b..b583693 100644
> +--- a/parted/ui.c
> ++++ b/parted/ui.c
> +@@ -1376,7 +1376,7 @@ init_ui ()
> + 
> + #ifdef HAVE_LIBREADLINE
> +         rl_initialize ();
> +-        rl_attempted_completion_function = (CPPFunction*) complete_function;
> ++        rl_attempted_completion_function = (rl_completion_func_t*) complete_function;
> +         readline_state.in_readline = 0;
> + #endif
> + 
> +-- 
> +1.8.4.2
> +
> diff --git a/meta-oe/recipes-extended/parted/parted_1.8.6.bb b/meta-oe/recipes-extended/parted/parted_1.8.6.bb
> new file mode 100644
> index 0000000..537978f
> --- /dev/null
> +++ b/meta-oe/recipes-extended/parted/parted_1.8.6.bb
> @@ -0,0 +1,62 @@
> +SUMMARY = "The GNU disk partition manipulation program"
> +DESCRIPTION = "The GNU Parted program allows you to create, destroy, resize, move, \
> +and copy hard disk partitions. Parted can be used for creating space \
> +for new operating systems, reorganizing disk usage, and copying data \
> +to new hard disks."
> +HOMEPAGE = "http://www.gnu.org/software/parted"
> +SECTION = "Applications/System"
> +
> +SRC_URI = "http://ftp.gnu.org/gnu/parted/parted-1.8.6.tar.bz2 \
> +	   file://1000parted-1.8.6-warnings1.patch \
> +	   file://1001parted-1.8.6-notransname1.patch \
> +	   file://1002parted-1.8.6-off-by-one1.patch \
> +	   file://1003parted-1.8.6-primary-boundary1.patch \
> +	   file://1004parted-1.8.6-xvd1.patch \
> +	   file://1005parted-1.8.6-devmapper-header1.patch \
> +	   file://7000no_effect_macro1.patch \
> +           file://ui.c-fix-build-error.patch \
> +	   "
> +
> +SRC_URI[md5sum] = "03c967ae0e915e08da90605d68ba93d7"
> +SRC_URI[sha256sum] = "82d94c9bb58cccd1eacfc5ff3a9331d179cc26d8fbe00c451e2c84feb6d23408"
> +
> +LICENSE = "GPLv2+"
> +LIC_FILES_CHKSUM = "file://COPYING;md5=eb723b61539feef013de476e68b5c50a"
> +
> +inherit autotools gettext pkgconfig
> +
> +DEPENDS = "lvm2 readline"
> +
> +EXTRA_OECONF = "--enable-device-mapper \
> +	        --disable-selinux \
> +	        --disable-static \
> +	        --sbindir=${sbindir} \
> +	        --disable-Werror \
> +	        --disable-rpath \
> +	        "
> +EXTRA_OEMAKE = "DESTDIR=${D}"
> +
> +do_configure_prepend() {
> +	# ltmain.sh will set rpath to path on host.
> +	for l in `find ${S} -name "ltmain\.sh"` ; do
> +		sed -i -e 's/\$compile_rpath//g' \
> +		       -e 's/\$finalize_rpath//g' ${l}
> +	done
> +
> +	# FIXME: Some option may be needed by EXTRA_OECONF.
> +	sed -i 's/ac_cv_func_malloc_0_nonnull=no/ac_cv_func_malloc_0_nonnull=yes/g' ${S}/configure
> +	sed -i 's/ac_cv_func_calloc_0_nonnull=no/ac_cv_func_calloc_0_nonnull=yes/g' ${S}/configure
> +	sed -i 's/ac_cv_func_memcmp_working=no/ac_cv_func_memcmp_working=yes/g' ${S}/configure
> +	sed -i 's/ac_cv_func_realloc_0_nonnull=no/ac_cv_func_realloc_0_nonnull=yes/g' ${S}/configure
> +}
> +
> +do_configure() {
> +	oe_runconf
> +}
> +
> +do_install_append() {
> +	/bin/rm -rf ${D}/${libdir}/*.la
> +	/bin/rm -rf ${D}/usr/share/info/dir
> +	/bin/rm -fr ${D}/usr/bin
> +}
> +
> -- 
> 1.8.4.2
> 
> -- 
> _______________________________________________
> Openembedded-devel mailing list
> Openembedded-devel at lists.openembedded.org
> http://lists.openembedded.org/mailman/listinfo/openembedded-devel

-- 
Martin 'JaMa' Jansa     jabber: Martin.Jansa at gmail.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 181 bytes
Desc: Digital signature
URL: <http://lists.openembedded.org/pipermail/openembedded-devel/attachments/20150831/46c730bc/attachment-0002.sig>


More information about the Openembedded-devel mailing list