[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Minios-devel] [UNIKRAFT/SQLITE PATCH V2 2/3] Add Makefile.uk



Hi Gaulthier,

Please see inline.

On 20.11.19, 15:21, "Minios-devel on behalf of Gaulthier Gain" 
<minios-devel-bounces@xxxxxxxxxxxxxxxxxxxx on behalf of 
gaulthier.gain@xxxxxxxxx> wrote:

    Signed-off-by: Gaulthier Gain <gaulthier.gain@xxxxxxxxx>
    ---
     Makefile.uk | 84 
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
     1 file changed, 84 insertions(+)
     create mode 100644 Makefile.uk
    
    diff --git a/Makefile.uk b/Makefile.uk
    new file mode 100644
    index 0000000..efa425c
    --- /dev/null
    +++ b/Makefile.uk
    @@ -0,0 +1,84 @@
    +#  SPDX-License-Identifier: BSD-3-Clause
    +#
    +#  SQLite Makefile.uk
    +#
    +#  Authors: Gain Gaulthier <gaulthier.gain@xxxxxxxxx>
    +#
    +#  Copyright (c) 2019, University of Liege. 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.
    +#
    +
    
+################################################################################
    +# App registration
    
+################################################################################
    +$(eval $(call addlib,libsqlite))
    +
    
+################################################################################
    +# Sources
    
+################################################################################
    +LIBSQLITE_VERSION = 3300100
    +LIBSQLITE_BASENAME = sqlite-amalgamation-$(LIBSQLITE_VERSION)
    +LIBSQLITE_URL = https://www.sqlite.org/2019/$(LIBSQLITE_BASENAME).zip
    +LIBSQLITE_PATCHDIR = $(LIBSQLITE_BASE)/patches
    +$(eval $(call fetch,libsqlite,$(LIBSQLITE_URL)))
    +$(eval $(call 
patch,libsqlite,$(LIBSQLITE_PATCHDIR),sqlite-$(LIBSQLITE_VERSION)))
    +
    
+################################################################################
    +# Helpers
    
+################################################################################
    +LIBSQLITE_SRC = $(LIBSQLITE_ORIGIN)/$(LIBSQLITE_BASENAME)
    +
    
+################################################################################
    +# Library includes
    
+################################################################################
    +CINCLUDES-y += -I$(LIBSQLITE_BASE)/include

> You should namespace this (s/CINCLUDES-y/ LIBSQLITE_CINCLUDES-y)

    +LIBSQLITE_CINCLUDES += -I$(LIBSQLITE_SRC)
    +
    
+################################################################################
    +# Global flags
    
+################################################################################
    +LIBSQLITE_FLAGS = -D_HAVE_SQLITE_CONFIG_H -DSQLITE_OMIT_LOAD_EXTENSION
    +
    +# Suppress some warnings to make the build process look neater
    +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-array-bounds -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 -Wno-type-limits -Wno-sign-compare

> That's a lot of suppress flags, which I suppose you probably copied and 
> pasted, and yet there are still a number of unsupressed warnings (e.g., 
> -Wimplicit-fallthrough). I was wondering whether it wouldn't be better to 
> remove this list, and then just build a list specific to this build. Also, 
> please namespace the SUPPRESS_FLAGS variable name.

    +LIBSQLITE_CFLAGS-y += $(LIBSQLITE_FLAGS)
    +LIBSQLITE_CFLAGS-y += $(SUPPRESS_FLAGS)
    +
    
+################################################################################
    +# SQLite sources
    
+################################################################################
    +LIBSQLITE_SRCS-y += $(LIBSQLITE_SRC)/shell.c
    +LIBSQLITE_SRCS-y += $(LIBSQLITE_SRC)/sqlite3.c

> It might be a good idea to add an optional main() to the build. See 
> https://github.com/unikraft/lib-lua/blob/staging/main.c, 
> https://github.com/unikraft/lib-lua/blob/staging/Config.uk , and 
> https://github.com/unikraft/lib-lua/blob/staging/Makefile.uk (lines 37 and 
> 52).

    -- 
    2.11.0
    
    
    _______________________________________________
    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

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.