Fix libc/zoneinfo build
This commit is contained in:
parent
aa96a1d2ec
commit
bde90de12f
@ -114,6 +114,10 @@ else
|
|||||||
OTHERDIRS += syscall
|
OTHERDIRS += syscall
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
CONTEXTDIRS += libc
|
||||||
|
endif
|
||||||
|
|
||||||
ifeq ($(CONFIG_NX),y)
|
ifeq ($(CONFIG_NX),y)
|
||||||
NONFSDIRS += graphics libnx
|
NONFSDIRS += graphics libnx
|
||||||
CONTEXTDIRS += graphics libnx
|
CONTEXTDIRS += graphics libnx
|
||||||
|
36
libc/Kconfig
36
libc/Kconfig
@ -321,7 +321,23 @@ config LIBC_TZDIR
|
|||||||
This is the full path to the location where the TZ database is expected
|
This is the full path to the location where the TZ database is expected
|
||||||
to be found.
|
to be found.
|
||||||
|
|
||||||
endif
|
config LIB_ZONEINFO
|
||||||
|
bool "TZ database"
|
||||||
|
default n
|
||||||
|
---help---
|
||||||
|
Download and build the TZ/Olson database.
|
||||||
|
|
||||||
|
if LIB_ZONEINFO
|
||||||
|
|
||||||
|
config LIB_ZONEINFO_ROMFS
|
||||||
|
bool "Build ROMFS filesystem"
|
||||||
|
default n
|
||||||
|
depends on FS_ROMFS
|
||||||
|
---help---
|
||||||
|
Build a mountable ROMFS filesystem containing the TZ/Olson database
|
||||||
|
|
||||||
|
endif # LIB_ZONEINFO
|
||||||
|
endif # LIBC_LOCALTIME
|
||||||
|
|
||||||
config TIME_EXTENDED
|
config TIME_EXTENDED
|
||||||
bool "Add day of week, year support"
|
bool "Add day of week, year support"
|
||||||
@ -884,21 +900,3 @@ config LIB_HEX2BIN
|
|||||||
---help---
|
---help---
|
||||||
Build in support for conversions from Intel Hex format to binary.
|
Build in support for conversions from Intel Hex format to binary.
|
||||||
This selection enables the interfaces of include/hex2bin.h.
|
This selection enables the interfaces of include/hex2bin.h.
|
||||||
|
|
||||||
config LIB_ZONEINFO
|
|
||||||
bool "TZ database"
|
|
||||||
default n
|
|
||||||
depends on LIBC_LOCALTIME
|
|
||||||
---help---
|
|
||||||
Build the TZ/Olson database.
|
|
||||||
|
|
||||||
if LIB_ZONEINFO
|
|
||||||
|
|
||||||
config LIB_ZONEINFO_ROMFS
|
|
||||||
bool "Build ROMFS filesystem"
|
|
||||||
default n
|
|
||||||
depends on FS_ROMFS
|
|
||||||
---help---
|
|
||||||
Build a mountable ROMFS filesystem containing the TZ database
|
|
||||||
|
|
||||||
endif # LIB_ZONEINFO
|
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
############################################################################
|
############################################################################
|
||||||
# libc/Makefile
|
# libc/Makefile
|
||||||
#
|
#
|
||||||
# Copyright (C) 2007-2014 Gregory Nutt. All rights reserved.
|
# Copyright (C) 2007-2014, 2016 Gregory Nutt. All rights reserved.
|
||||||
# Author: Gregory Nutt <gnutt@nuttx.org>
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without
|
# Redistribution and use in source and binary forms, with or without
|
||||||
@ -117,6 +117,9 @@ $(COBJS): $(BINDIR)$(DELIM)%$(OBJEXT): %.c
|
|||||||
|
|
||||||
$(BIN): $(OBJS)
|
$(BIN): $(OBJS)
|
||||||
$(call ARCHIVE, $@, $(OBJS))
|
$(call ARCHIVE, $@, $(OBJS))
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
$(Q) $(MAKE) -C zoneinfo all TOPDIR=$(TOPDIR) BIN=$(BIN)
|
||||||
|
endif
|
||||||
|
|
||||||
# C library for the user phase of the two-pass kernel build
|
# C library for the user phase of the two-pass kernel build
|
||||||
|
|
||||||
@ -132,6 +135,13 @@ $(KBIN):
|
|||||||
$(Q) $(MAKE) $(KBIN) BIN=$(KBIN) BINDIR=kbin TOPDIR=$(TOPDIR) EXTRADEFINES=$(EXTRADEFINES)
|
$(Q) $(MAKE) $(KBIN) BIN=$(KBIN) BINDIR=kbin TOPDIR=$(TOPDIR) EXTRADEFINES=$(EXTRADEFINES)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
# Context
|
||||||
|
|
||||||
|
context:
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
$(Q) $(MAKE) -C zoneinfo context TOPDIR=$(TOPDIR) BIN=$(BIN)
|
||||||
|
endif
|
||||||
|
|
||||||
# Dependencies
|
# Dependencies
|
||||||
|
|
||||||
.depend: Makefile $(SRCS)
|
.depend: Makefile $(SRCS)
|
||||||
@ -140,6 +150,9 @@ ifeq ($(CONFIG_BUILD_PROTECTED),y)
|
|||||||
$(Q) $(MKDEP) --obj-path kbin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) $(KDEFINE) -- $(SRCS) >Make_kbin.dep
|
$(Q) $(MKDEP) --obj-path kbin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) $(KDEFINE) -- $(SRCS) >Make_kbin.dep
|
||||||
else
|
else
|
||||||
$(Q) $(MKDEP) --obj-path bin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) -- $(SRCS) >Make_bin.dep
|
$(Q) $(MKDEP) --obj-path bin --obj-suffix $(OBJEXT) $(DEPPATH) "$(CC)" -- $(CFLAGS) -- $(SRCS) >Make_bin.dep
|
||||||
|
endif
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
$(Q) $(MAKE) -C zoneinfo depend TOPDIR=$(TOPDIR) BIN=$(BIN)
|
||||||
endif
|
endif
|
||||||
$(Q) touch $@
|
$(Q) touch $@
|
||||||
|
|
||||||
@ -151,6 +164,7 @@ clean:
|
|||||||
$(Q) $(MAKE) -C bin clean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C bin clean TOPDIR=$(TOPDIR)
|
||||||
$(Q) $(MAKE) -C ubin clean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C ubin clean TOPDIR=$(TOPDIR)
|
||||||
$(Q) $(MAKE) -C kbin clean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C kbin clean TOPDIR=$(TOPDIR)
|
||||||
|
$(Q) $(MAKE) -C zoneinfo clean TOPDIR=$(TOPDIR) BIN=$(BIN)
|
||||||
$(call DELFILE, $(BIN))
|
$(call DELFILE, $(BIN))
|
||||||
$(call DELFILE, $(UBIN))
|
$(call DELFILE, $(UBIN))
|
||||||
$(call DELFILE, $(KBIN))
|
$(call DELFILE, $(KBIN))
|
||||||
@ -162,6 +176,7 @@ distclean: clean
|
|||||||
$(Q) $(MAKE) -C bin distclean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C bin distclean TOPDIR=$(TOPDIR)
|
||||||
$(Q) $(MAKE) -C ubin distclean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C ubin distclean TOPDIR=$(TOPDIR)
|
||||||
$(Q) $(MAKE) -C kbin distclean TOPDIR=$(TOPDIR)
|
$(Q) $(MAKE) -C kbin distclean TOPDIR=$(TOPDIR)
|
||||||
|
$(Q) $(MAKE) -C zoneinfo distclean TOPDIR=$(TOPDIR) BIN=$(BIN)
|
||||||
$(call DELFILE, Make_bin.dep)
|
$(call DELFILE, Make_bin.dep)
|
||||||
$(call DELFILE, Make_ubin.dep)
|
$(call DELFILE, Make_ubin.dep)
|
||||||
$(call DELFILE, Make_kbin.dep)
|
$(call DELFILE, Make_kbin.dep)
|
||||||
|
8
libc/zoneinfo/.gitignore
vendored
8
libc/zoneinfo/.gitignore
vendored
@ -1,2 +1,10 @@
|
|||||||
|
/.built
|
||||||
|
/.tzbuilt
|
||||||
|
/.tzunpack
|
||||||
|
/romfs_zoneinfo.img
|
||||||
/romfs_zoneinfo.h
|
/romfs_zoneinfo.h
|
||||||
|
/tzbin
|
||||||
|
/tzcode-latest.tar.gz
|
||||||
|
/tzcode
|
||||||
|
/tzdata-latest.tar.gz
|
||||||
|
|
||||||
|
@ -1,47 +0,0 @@
|
|||||||
############################################################################
|
|
||||||
# nuttx/zoneinfo/Make.defs
|
|
||||||
#
|
|
||||||
# Copyright (C) 2016 Gregory Nutt. All rights reserved.
|
|
||||||
# Author: Gregory Nutt <gnutt@nuttx.org>
|
|
||||||
#
|
|
||||||
# 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 NuttX 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 OWNER 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.
|
|
||||||
#
|
|
||||||
############################################################################
|
|
||||||
|
|
||||||
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
|
||||||
|
|
||||||
# Add the zoneinifo sources to the build
|
|
||||||
|
|
||||||
CSRCS += tzromfs.c
|
|
||||||
|
|
||||||
# Add the zoneinfo directory to the build
|
|
||||||
|
|
||||||
DEPPATH += --dep-path zoneinfo
|
|
||||||
VPATH += :zoneinfo
|
|
||||||
|
|
||||||
endif
|
|
157
libc/zoneinfo/Makefile
Normal file
157
libc/zoneinfo/Makefile
Normal file
@ -0,0 +1,157 @@
|
|||||||
|
############################################################################
|
||||||
|
# libc/zoneinfo/Makefile
|
||||||
|
#
|
||||||
|
# Copyright (C) 2015-2016, Gregory Nutt. All rights reserved.
|
||||||
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
#
|
||||||
|
# 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 NuttX 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 OWNER 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.
|
||||||
|
#
|
||||||
|
############################################################################
|
||||||
|
|
||||||
|
-include $(TOPDIR)/.config
|
||||||
|
-include $(TOPDIR)/Make.defs
|
||||||
|
|
||||||
|
ifeq ($(WINTOOL),y)
|
||||||
|
INCDIROPT = -w
|
||||||
|
endif
|
||||||
|
|
||||||
|
# Zoneinfo database
|
||||||
|
|
||||||
|
ASRCS =
|
||||||
|
CSRCS =
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
CSRCS += tzromfs.c
|
||||||
|
endif
|
||||||
|
|
||||||
|
AOBJS = $(ASRCS:.S=$(OBJEXT))
|
||||||
|
COBJS = $(CSRCS:.c=$(OBJEXT))
|
||||||
|
|
||||||
|
SRCS = $(ASRCS) $(CSRCS)
|
||||||
|
OBJS = $(AOBJS) $(COBJS)
|
||||||
|
|
||||||
|
ZONEINFO_PATH = $(TOPDIR)/libc/zoneinfo
|
||||||
|
TZBIN_PATH = $(ZONEINFO_PATH)/tzbin
|
||||||
|
TZCODE_PATH = $(ZONEINFO_PATH)/tzcode
|
||||||
|
|
||||||
|
ROOTDEPPATH = --dep-path .
|
||||||
|
|
||||||
|
# Common build
|
||||||
|
|
||||||
|
VPATH =
|
||||||
|
|
||||||
|
all: .built
|
||||||
|
.PHONY: romfs register context depend clean distclean
|
||||||
|
|
||||||
|
$(AOBJS): %$(OBJEXT): %.S
|
||||||
|
$(call ASSEMBLE, $<, $@)
|
||||||
|
|
||||||
|
$(COBJS): %$(OBJEXT): %.c
|
||||||
|
$(call COMPILE, $<, $@)
|
||||||
|
|
||||||
|
.built: .tzbuilt romfs $(OBJS)
|
||||||
|
$(call ARCHIVE, ..$(DELIM)$(BIN), $(OBJS))
|
||||||
|
$(Q) touch .built
|
||||||
|
|
||||||
|
# ROMFS file system containing the TZ database
|
||||||
|
|
||||||
|
ifeq ($(CONFIG_LIB_ZONEINFO_ROMFS),y)
|
||||||
|
|
||||||
|
checkgenromfs:
|
||||||
|
@genromfs -h 1>/dev/null 2>&1 || { \
|
||||||
|
echo "Host executable genromfs not available in PATH"; \
|
||||||
|
echo "You may need to download in from http://romfs.sourceforge.net/"; \
|
||||||
|
exit 1; \
|
||||||
|
}
|
||||||
|
|
||||||
|
romfs_zoneinfo.img : checkgenromfs .tzbuilt
|
||||||
|
@genromfs -f $@ -d $(TZBIN_PATH)/etc/zoneinfo -V "TZDatbase" || { echo "genromfs failed" ; exit 1 ; }
|
||||||
|
|
||||||
|
romfs_zoneinfo.h : romfs_zoneinfo.img
|
||||||
|
@xxd -i $< >$@ || { echo "xxd of $< failed" ; exit 1 ; }
|
||||||
|
|
||||||
|
romfs: romfs_zoneinfo.h
|
||||||
|
|
||||||
|
else
|
||||||
|
|
||||||
|
romfs:
|
||||||
|
|
||||||
|
endif # CONFIG_LIB_ZONEINFO_ROMFS
|
||||||
|
|
||||||
|
# Build TZ database
|
||||||
|
|
||||||
|
tzcode:
|
||||||
|
mkdir tzcode
|
||||||
|
|
||||||
|
tzbin:
|
||||||
|
mkdir tzbin
|
||||||
|
|
||||||
|
tzcode-latest.tar.gz:
|
||||||
|
$(Q) wget --retr-symlinks ftp://ftp.iana.org/tz/tzcode-latest.tar.gz
|
||||||
|
|
||||||
|
tzdata-latest.tar.gz:
|
||||||
|
$(Q) wget --retr-symlinks ftp://ftp.iana.org/tz/tzdata-latest.tar.gz
|
||||||
|
|
||||||
|
.tzunpack: tzcode tzcode-latest.tar.gz tzdata-latest.tar.gz
|
||||||
|
$(Q) tar zx -C tzcode -f tzcode-latest.tar.gz
|
||||||
|
$(Q) tar zx -C tzcode -f tzdata-latest.tar.gz
|
||||||
|
$(Q) touch .tzunpack
|
||||||
|
|
||||||
|
.tzbuilt: tzcode tzbin .tzunpack
|
||||||
|
$(Q) $(MAKE) -C tzcode TOPDIR=$(TZBIN_PATH) install
|
||||||
|
$(Q) touch .tzbuilt
|
||||||
|
|
||||||
|
# Create initial context
|
||||||
|
|
||||||
|
context: .tzbuilt romfs
|
||||||
|
|
||||||
|
# Create dependencies
|
||||||
|
|
||||||
|
.depend: Makefile $(SRCS)
|
||||||
|
$(Q) $(MKDEP) $(ROOTDEPPATH) "$(CC)" -- $(CFLAGS) -- $(SRCS) >Make.dep
|
||||||
|
$(Q) touch $@
|
||||||
|
|
||||||
|
depend: .depend
|
||||||
|
|
||||||
|
clean:
|
||||||
|
$(call DELFILE, .built)
|
||||||
|
$(call CLEAN)
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
$(call DELFILE, Make.dep)
|
||||||
|
$(call DELFILE, .depend)
|
||||||
|
$(call DELFILE, .tzunpack)
|
||||||
|
$(call DELFILE, .tzbuilt)
|
||||||
|
$(call DELFILE, romfs_zoneinfo.img)
|
||||||
|
$(call DELFILE, romfs_zoneinfo.h)
|
||||||
|
$(call DELFILE, tzdata-latest.tar.gz)
|
||||||
|
$(call DELFILE, tzcode-latest.tar.gz)
|
||||||
|
$(call DELDIR, tzbin)
|
||||||
|
$(call DELDIR, tzcode)
|
||||||
|
|
||||||
|
-include Make.dep
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* nuttx/zoneinfo/tzromfs.c
|
* libc/zoneinfo/tzromfs.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2015 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2015-2016 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
Loading…
Reference in New Issue
Block a user