[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Minios-devel] [UNIKRAFT/LIBUUID PATCH v3 2/2] Initial port of the libuuid library (version 1.0.3).
Hi Simon, Sharan, On 02.09.19, 10:51, "Sharan Santhanam" <Sharan.Santhanam@xxxxxxxxx> wrote: On 8/30/19 5:41 PM, Simon Kuenzer wrote: > On 24.07.19 15:59, Felipe Huici wrote: >> Note newlib is required. >> >> Signed-off-by: Felipe Huici <felipe.huici@xxxxxxxxx> >> --- >> Config.uk | 5 + >> Makefile.uk | 126 >> +++++++++++++++++++++++++ >> exportsyms.uk | 17 ++++ >> include/config.h | 77 +++++++++++++++ >> patches/0001-add-syscall-h-compile-guard.patch | 12 +++ >> 5 files changed, 237 insertions(+) >> create mode 100644 Config.uk >> create mode 100644 Makefile.uk >> create mode 100644 exportsyms.uk >> create mode 100644 include/config.h >> create mode 100644 patches/0001-add-syscall-h-compile-guard.patch >> >> diff --git a/Config.uk b/Config.uk >> new file mode 100644 >> index 0000000..e52870a >> --- /dev/null >> +++ b/Config.uk >> @@ -0,0 +1,5 @@ >> +menuconfig LIBUUID >> + bool "libuuid - library for unique id generation" >> + default n >> + depends on HAVE_LIBC >> + select UKUNISTD >> diff --git a/Makefile.uk b/Makefile.uk >> new file mode 100644 >> index 0000000..4f66857 >> --- /dev/null >> +++ b/Makefile.uk >> @@ -0,0 +1,126 @@ >> +# libuuid Makefile.uc >> +# >> +# Authors: Felipe Huici <felipe.huici@xxxxxxxxx> >> +# >> +# >> +# Copyright (c) 2019, NEC Europe Ltd., NEC Corporation. All rights >> reserved. >> +# >> +# Redistribution and use in source and binary forms, with or without >> +# modification, are permitted provided that the following conditions >> +# are met: >> +# >> +# 1. Redistributions of source code must retain the above copyright >> +# notice, this list of conditions and the following disclaimer. >> +# 2. Redistributions in binary form must reproduce the above copyright >> +# notice, this list of conditions and the following disclaimer >> in the >> +# documentation and/or other materials provided with the >> distribution. >> +# 3. Neither the name of the copyright holder nor the names of its >> +# contributors may be used to endorse or promote products >> derived from >> +# this software without specific prior written permission. >> +# >> +# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND >> CONTRIBUTORS "AS IS" >> +# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED >> TO, THE >> +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A >> PARTICULAR PURPOSE >> +# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR >> CONTRIBUTORS BE >> +# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR >> +# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF >> +# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR >> BUSINESS >> +# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, >> WHETHER IN >> +# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR >> OTHERWISE) >> +# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF >> ADVISED OF THE >> +# POSSIBILITY OF SUCH DAMAGE. >> +# >> +# THIS HEADER MAY NOT BE EXTRACTED OR MODIFIED IN ANY WAY. >> +# >> + >> +################################################################################ >> >> +# Library registration >> +################################################################################ >> >> +$(eval $(call addlib_s,libuuid,$(CONFIG_LIBUUID))) >> + >> +################################################################################ >> >> +# Sources >> +################################################################################ >> >> +LIBUUID_VERSION=1.0.3 >> +LIBUUID_URL=https://sourceforge.net/projects/libuuid/files/libuuid-$(LIBUUID_VERSION).tar.gz/download >> >> +LIBUUID_PATCHDIR=$(LIBUUID_BASE)/patches >> +$(eval $(call fetchas,libuuid,$(LIBUUID_URL),$(LIBUUID_VERSION).tgz)) >> +$(eval $(call >> patch,libuuid,$(LIBUUID_PATCHDIR),libuuid-$(LIBUUID_VERSION))) >> + >> +################################################################################ >> >> +# Helpers >> +################################################################################ >> >> +LIBUUID_SUBDIR=libuuid-$(LIBUUID_VERSION) >> +LIBUUID_SRC=$(LIBUUID_ORIGIN)/$(LIBUUID_SUBDIR) >> + >> +################################################################################ >> >> +# Library includes >> +################################################################################ >> >> +# Put public headers (uuid.h) in a public folder and export them >> globally. The >> +# prepare step below takes care of populating the folder. >> +$(call mk_sub_build_dir,libuuid/include/public) >> +CINCLUDES-$(CONFIG_LIBUUID) += -I$(LIBUUID_BUILD)/include/public >> + >> +# Put private headers (the glue's config.h, and uuid's non-uuid.h >> headers) >> +# in a private folder and export that only locally to libuuid. The >> prepare >> +# step below takes care of populating the folder >> +$(call mk_sub_build_dir,libuuid/include/private) >> +LIBUUID_CINCLUDES-y += -I$(LIBUUID_BUILD)/include/private >> + >> +################################################################################ >> >> +# Global flags >> +################################################################################ >> >> +LIBUUID_CFLAGS-y += -DHAVE_CONFIG_H >> + >> +# Suppress some warnings to make the build process look neater >> +LIBUUID_SUPPRESS_FLAGS += -Wno-unused-parameter >> -Wno-unused-variable \ >> +-Wno-nonnull -Wno-unused-but-set-variable -Wno-unused-label >> -Wno-char-subscripts\ >> +-Wno-unused-function -Wno-missing-field-initializers >> -Wno-uninitialized \ >> +-Wno-maybe-uninitialized -Wno-pointer-sign >> -Wno-unused-value \ >> +-Wno-unused-macros -Wno-parentheses >> -Wno-implicit-function-declaration \ >> +-Wno-missing-braces -Wno-endif-labels >> -Wno-unused-but-set-variable \ >> +-Wno-implicit-function-declaration >> + >> +LIBUUID_CFLAGS-y += $(LIBUUID_SUPPRESS_FLAGS) >> +LIBUUID_CXXFLAGS-y += $(LIBUUID_SUPPRESS_FLAGS) >> + >> +################################################################################ >> >> +# Sources >> +################################################################################ >> >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/clear.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/copy.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/isnull.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/parse.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/unparse.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/compare.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/gen_uuid.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/pack.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/randutils.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/unpack.c >> +LIBUUID_SRCS-y += $(LIBUUID_SRC)/uuid_time.c >> + >> +################################################################################ >> >> +# Lib-specific Targets >> +################################################################################ >> >> +$(LIBUUID_BUILD)/include/public/%.h: $(LIBUUID_SRC)/%.h >> + $(call build_cmd,LN,libuuid,$@,\ >> + ln -sf $< $@) >> + >> +$(LIBUUID_BUILD)/include/private/%.h: $(LIBUUID_SRC)/%.h >> + $(call build_cmd,LN,libuuid,$@,\ >> + ln -sf $< $@) > > If you just type "make", I noticed that this wildcard rules get > executed before the archive is extracted. I got it solved by adding > the following rule to state the dependency: > > $(LIBUUID_SRC)/%.h: $(LIBUUID_BUILD)/.origin > @# empty recipe to enforce dependency to archive extraction Would recommend using @: instead of @#. This represent a noop > > At this point I have no clue why this only works with a filled-out > recipe, even if it is non-sense. It looks like that Make is doing some > magic internal simplification if you state the dependency without recipe. Ok, thanks, will add the rule with just @ . > >> + >> +$(LIBUUID_BUILD)/include/private/config.h: >> $(LIBUUID_BASE)/include/config.h >> + $(call build_cmd,LN,libuuid,$@,\ >> + ln -sf $< $(LIBUUID_BUILD)/include/private/config.h) >> + >> +# public headers >> +UK_PREPARE += $(LIBUUID_BUILD)/include/public/uuid.h >> + >> +# private headers >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/all-io.h >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/c.h >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/randutils.h >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/uuidd.h >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/uuidP.h >> +UK_PREPARE += $(LIBUUID_BUILD)/include/private/config.h >> \ No newline at end of file >> diff --git a/exportsyms.uk b/exportsyms.uk >> new file mode 100644 >> index 0000000..0c62271 >> --- /dev/null >> +++ b/exportsyms.uk >> @@ -0,0 +1,17 @@ >> +uuid_clear >> +uuid_compare >> +uuid_copy >> +uuid_generate >> +uuid_generate_random >> +uuid_generate_time >> +uuid_generate_time_safe >> +uuid_is_null >> +uuid_pack >> +uuid_parse >> +uuid_time >> +uuid_type >> +uuid_unpack >> +uuid_unparse >> +uuid_unparse_lower >> +uuid_unparse_upper >> +uuid_variant >> diff --git a/include/config.h b/include/config.h >> new file mode 100644 >> index 0000000..19840ad >> --- /dev/null >> +++ b/include/config.h >> @@ -0,0 +1,77 @@ >> +/* config.h. Generated from config.h.in by libuuid's configure. */ >> +/* config.h.in. Generated from configure.ac by autoheader. */ >> + >> +/* Define to 1 if you have the <fcntl.h> header file. */ >> +#define HAVE_FCNTL_H 1 >> + >> +/* Define to 1 if you have the `ftruncate' function. */ >> +#define HAVE_FTRUNCATE 1 >> + >> +/* Define to 1 if you have the `gettimeofday' function. */ >> +#define HAVE_GETTIMEOFDAY 1 >> + >> +/* Define to 1 if you have the <inttypes.h> header file. */ >> +#define HAVE_INTTYPES_H 1 >> + >> +/* Define to 1 if you have the <limits.h> header file. */ >> +#define HAVE_LIMITS_H 1 >> + >> +/* Define to 1 if you have the <memory.h> header file. */ >> +#define HAVE_MEMORY_H 1 >> + >> +/* Define to 1 if you have the `memset' function. */ >> +#define HAVE_MEMSET 1 >> + >> +/* Define to 1 if you have the <netinet/in.h> header file. */ >> +#ifdef $(HAVE_NW_STACK) >> +#define HAVE_NETINET_IN_H 1 >> +#endif >> + >> +/* Define to 1 if you have the `socket' function. */ >> +#ifdef $(HAVE_NW_STACK) >> +#define HAVE_SOCKET 1 >> +#endif >> + >> +/* Define to 1 if you have the `srandom' function. */ >> +#define HAVE_SRANDOM 1 >> + >> +/* Define to 1 if you have the <stdint.h> header file. */ >> +#define HAVE_STDINT_H 1 >> + >> +/* Define to 1 if you have the <stdlib.h> header file. */ >> +#define HAVE_STDLIB_H 1 >> + >> +/* Define to 1 if you have the <strings.h> header file. */ >> +#define HAVE_STRINGS_H 1 >> + >> +/* Define to 1 if you have the <string.h> header file. */ >> +#define HAVE_STRING_H 1 >> + >> +/* Define to 1 if you have the `strtoul' function. */ >> +#define HAVE_STRTOUL 1 >> + >> +/* Define to 1 if you have the <sys/file.h> header file. */ >> +#define HAVE_SYS_FILE_H 1 >> + >> +/* Define to 1 if you have the <sys/ioctl.h> header file. */ >> +#define HAVE_SYS_IOCTL_H 1 >> + >> +/* Define to 1 if you have the <sys/socket.h> header file. */ >> +#ifdef $(HAVE_NW_STACK) >> +#define HAVE_SYS_SOCKET_H 1 >> +#endif >> + >> +/* Define to 1 if you have the <sys/stat.h> header file. */ >> +#define HAVE_SYS_STAT_H 1 >> + >> +/* Define to 1 if you have the <sys/time.h> header file. */ >> +#define HAVE_SYS_TIME_H 1 >> + >> +/* Define to 1 if you have the <sys/types.h> header file. */ >> +#define HAVE_SYS_TYPES_H 1 >> + >> +/* Define to 1 if you have the <unistd.h> header file. */ >> +#define HAVE_UNISTD_H 1 >> + >> +/* Define to 1 if you have the `usleep' function. */ >> +#define HAVE_USLEEP 1 >> diff --git a/patches/0001-add-syscall-h-compile-guard.patch >> b/patches/0001-add-syscall-h-compile-guard.patch >> new file mode 100644 >> index 0000000..adea66a >> --- /dev/null >> +++ b/patches/0001-add-syscall-h-compile-guard.patch >> @@ -0,0 +1,12 @@ >> +--- a/randutils.c 2019-04-03 14:46:14.827682485 +0200 >> ++++ b/randutils.c 2019-04-03 14:46:48.375286950 +0200 >> +@@ -13,7 +13,9 @@ >> + #include <string.h> >> + #include <sys/time.h> >> + >> ++#ifdef DO_JRAND_MIX >> + #include <sys/syscall.h> >> ++#endif >> + >> + #include "randutils.h" >> + >> > > _______________________________________________ > Minios-devel mailing list > Minios-devel@xxxxxxxxxxxxxxxxxxxx > https://lists.xenproject.org/mailman/listinfo/minios-devel _______________________________________________ Minios-devel mailing list Minios-devel@xxxxxxxxxxxxxxxxxxxx https://lists.xenproject.org/mailman/listinfo/minios-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |