Initial commit
This commit is contained in:
		
							
								
								
									
										62
									
								
								package/libs/libjson-c/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								package/libs/libjson-c/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| # | ||||
| # Copyright (C) 2006-2014 OpenWrt.org | ||||
| # | ||||
| # This is free software, licensed under the GNU General Public License v2. | ||||
| # See /LICENSE for more information. | ||||
| # | ||||
|  | ||||
| include $(TOPDIR)/rules.mk | ||||
|  | ||||
| PKG_NAME:=json-c | ||||
| PKG_VERSION:=0.12.1 | ||||
| PKG_RELEASE:=2.1 | ||||
|  | ||||
| PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION)-nodoc.tar.gz | ||||
| PKG_SOURCE_URL:=https://s3.amazonaws.com/json-c_releases/releases/ | ||||
| PKG_HASH:=5a617da9aade997938197ef0f8aabd7f97b670c216dc173977e1d56eef9e1291 | ||||
| PKG_SOURCE_SUBDIR:=$(PKG_NAME)-$(PKG_VERSION) | ||||
| PKG_BUILD_DIR:=$(BUILD_DIR)/$(PKG_SOURCE_SUBDIR) | ||||
|  | ||||
| PKG_LICENSE:=MIT | ||||
| PKG_LICENSE_FILES:=COPYING | ||||
| PKG_CPE_ID:=cpe:/a:json-c_project:json-c | ||||
|  | ||||
| PKG_FIXUP:=autoreconf | ||||
| PKG_INSTALL:=1 | ||||
|  | ||||
| PKG_MAINTAINER:=Felix Fietkau <nbd@nbd.name> | ||||
|  | ||||
| include $(INCLUDE_DIR)/package.mk | ||||
| include $(INCLUDE_DIR)/host-build.mk | ||||
|  | ||||
| TARGET_CFLAGS += $(FPIC) -Wno-implicit-fallthrough | ||||
| HOST_CFLAGS += -Wno-implicit-fallthrough | ||||
| HOST_BUILD_PREFIX:=$(STAGING_DIR_HOST) | ||||
|  | ||||
| define Package/libjson-c | ||||
|   SECTION:=libs | ||||
|   CATEGORY:=Libraries | ||||
|   TITLE:=javascript object notation | ||||
|   URL:=https://json-c.github.io/json-c/ | ||||
| endef | ||||
|  | ||||
| define Package/libjson-c/description | ||||
|  This package contains a library for javascript object notation backends. | ||||
| endef | ||||
|  | ||||
| define Build/InstallDev | ||||
| 	$(INSTALL_DIR) $(1)/usr/include | ||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/include/json-c $(1)/usr/include/ | ||||
| 	$(INSTALL_DIR) $(1)/usr/lib | ||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/lib/libjson-c.{a,so*} $(1)/usr/lib/ | ||||
| 	$(INSTALL_DIR) $(1)/usr/lib/pkgconfig | ||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/lib/pkgconfig/json-c.pc $(1)/usr/lib/pkgconfig/ | ||||
| endef | ||||
|  | ||||
| define Package/libjson-c/install | ||||
| 	$(INSTALL_DIR) $(1)/usr/lib | ||||
| 	$(CP) $(PKG_INSTALL_DIR)/usr/lib/libjson-c.so.* $(1)/usr/lib/ | ||||
| endef | ||||
|  | ||||
| $(eval $(call BuildPackage,libjson-c)) | ||||
| $(eval $(call HostBuild)) | ||||
							
								
								
									
										50
									
								
								package/libs/libjson-c/patches/000-libm.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								package/libs/libjson-c/patches/000-libm.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,50 @@ | ||||
| --- a/configure.ac | ||||
| +++ b/configure.ac | ||||
| @@ -43,12 +43,6 @@ AC_FUNC_MEMCMP | ||||
|  AC_FUNC_MALLOC | ||||
|  AC_FUNC_REALLOC | ||||
|  AC_CHECK_FUNCS(strcasecmp strdup strerror snprintf vsnprintf vasprintf open vsyslog strncasecmp setlocale) | ||||
| -AC_CHECK_DECLS([INFINITY], [], [], [[#include <math.h>]]) | ||||
| -AC_CHECK_DECLS([nan], [], [], [[#include <math.h>]]) | ||||
| -AC_CHECK_DECLS([isnan], [], [], [[#include <math.h>]]) | ||||
| -AC_CHECK_DECLS([isinf], [], [], [[#include <math.h>]]) | ||||
| -AC_CHECK_DECLS([_isnan], [], [], [[#include <float.h>]]) | ||||
| -AC_CHECK_DECLS([_finite], [], [], [[#include <float.h>]]) | ||||
|   | ||||
|  #check if .section.gnu.warning accepts long strings (for __warn_references) | ||||
|  AC_LANG_PUSH([C]) | ||||
| --- a/math_compat.h | ||||
| +++ b/math_compat.h | ||||
| @@ -1,28 +1,9 @@ | ||||
|  #ifndef __math_compat_h | ||||
|  #define __math_compat_h | ||||
|   | ||||
| -/* Define isnan and isinf on Windows/MSVC */ | ||||
| - | ||||
| -#ifndef HAVE_DECL_ISNAN | ||||
| -# ifdef HAVE_DECL__ISNAN | ||||
| -#include <float.h> | ||||
| -#define isnan(x) _isnan(x) | ||||
| -# endif | ||||
| -#endif | ||||
| - | ||||
| -#ifndef HAVE_DECL_ISINF | ||||
| -# ifdef HAVE_DECL__FINITE | ||||
| -#include <float.h> | ||||
| -#define isinf(x) (!_finite(x)) | ||||
| -# endif | ||||
| -#endif | ||||
| - | ||||
| -#ifndef HAVE_DECL_NAN | ||||
| -#error This platform does not have nan() | ||||
| -#endif | ||||
| - | ||||
| -#ifndef HAVE_DECL_INFINITY | ||||
| -#error This platform does not have INFINITY | ||||
| -#endif | ||||
| +#undef isnan | ||||
| +#define isnan(x) __builtin_isnan(x) | ||||
| +#undef isinf | ||||
| +#define isinf(x) __builtin_isinf(x) | ||||
|   | ||||
|  #endif | ||||
| @@ -0,0 +1,32 @@ | ||||
| From 77d935b7ae7871a1940cd827e850e6063044ec45 Mon Sep 17 00:00:00 2001 | ||||
| From: Tobias Stoeckmann <tobias@stoeckmann.org> | ||||
| Date: Mon, 4 May 2020 19:46:45 +0200 | ||||
| Subject: [PATCH 2/2] Prevent division by zero in linkhash. | ||||
|  | ||||
| If a linkhash with a size of zero is created, then modulo operations | ||||
| are prone to division by zero operations. | ||||
|  | ||||
| Purely protective measure against bad usage. | ||||
| --- | ||||
|  linkhash.c | 3 +++ | ||||
|  1 file changed, 3 insertions(+) | ||||
|  | ||||
| --- a/linkhash.c | ||||
| +++ b/linkhash.c | ||||
| @@ -10,6 +10,7 @@ | ||||
|   * | ||||
|   */ | ||||
|   | ||||
| +#include <assert.h> | ||||
|  #include <stdio.h> | ||||
|  #include <string.h> | ||||
|  #include <stdlib.h> | ||||
| @@ -431,6 +432,8 @@ struct lh_table* lh_table_new(int size, | ||||
|  	int i; | ||||
|  	struct lh_table *t; | ||||
|   | ||||
| +  /* Allocate space for elements to avoid divisions by zero. */ | ||||
| +  assert(size > 0); | ||||
|  	t = (struct lh_table*)calloc(1, sizeof(struct lh_table)); | ||||
|  	if(!t) lh_abort("lh_table_new: calloc failed\n"); | ||||
|  	t->count = 0; | ||||
| @@ -0,0 +1,83 @@ | ||||
| From d07b91014986900a3a75f306d302e13e005e9d67 Mon Sep 17 00:00:00 2001 | ||||
| From: Tobias Stoeckmann <tobias@stoeckmann.org> | ||||
| Date: Mon, 4 May 2020 19:47:25 +0200 | ||||
| Subject: [PATCH] Fix integer overflows. | ||||
|  | ||||
| The data structures linkhash and printbuf are limited to 2 GB in size | ||||
| due to a signed integer being used to track their current size. | ||||
|  | ||||
| If too much data is added, then size variable can overflow, which is | ||||
| an undefined behaviour in C programming language. | ||||
|  | ||||
| Assuming that a signed int overflow just leads to a negative value, | ||||
| like it happens on many sytems (Linux i686/amd64 with gcc), then | ||||
| printbuf is vulnerable to an out of boundary write on 64 bit systems. | ||||
| --- | ||||
|  linkhash.c |  7 +++++-- | ||||
|  printbuf.c | 19 ++++++++++++++++--- | ||||
|  2 files changed, 21 insertions(+), 5 deletions(-) | ||||
|  | ||||
| --- a/linkhash.c | ||||
| +++ b/linkhash.c | ||||
| @@ -498,7 +498,12 @@ int lh_table_insert(struct lh_table *t, | ||||
|  	unsigned long h, n; | ||||
|   | ||||
|  	t->inserts++; | ||||
| -	if(t->count >= t->size * LH_LOAD_FACTOR) lh_table_resize(t, t->size * 2); | ||||
| +	if(t->count >= t->size * LH_LOAD_FACTOR) { | ||||
| +		/* Avoid signed integer overflow with large tables. */ | ||||
| +		int new_size = (t->size > INT_MAX / 2) ? INT_MAX : (t->size * 2); | ||||
| +		if (t->size != INT_MAX) | ||||
| +			lh_table_resize(t, new_size); | ||||
| +	} | ||||
|   | ||||
|  	h = t->hash_fn(k); | ||||
|  	n = h % t->size; | ||||
| --- a/printbuf.c | ||||
| +++ b/printbuf.c | ||||
| @@ -15,6 +15,7 @@ | ||||
|   | ||||
|  #include "config.h" | ||||
|   | ||||
| +#include <limits.h> | ||||
|  #include <stdio.h> | ||||
|  #include <stdlib.h> | ||||
|  #include <string.h> | ||||
| @@ -63,7 +64,16 @@ static int printbuf_extend(struct printb | ||||
|  	if (p->size >= min_size) | ||||
|  		return 0; | ||||
|   | ||||
| -	new_size = json_max(p->size * 2, min_size + 8); | ||||
| +	/* Prevent signed integer overflows with large buffers. */ | ||||
| +	if (min_size > INT_MAX - 8) | ||||
| +		return -1; | ||||
| +	if (p->size > INT_MAX / 2) | ||||
| +		new_size = min_size + 8; | ||||
| +	else { | ||||
| +		new_size = p->size * 2; | ||||
| +		if (new_size < min_size + 8) | ||||
| +			new_size = min_size + 8; | ||||
| +	} | ||||
|  #ifdef PRINTBUF_DEBUG | ||||
|  	MC_DEBUG("printbuf_memappend: realloc " | ||||
|  	  "bpos=%d min_size=%d old_size=%d new_size=%d\n", | ||||
| @@ -78,6 +88,9 @@ static int printbuf_extend(struct printb | ||||
|   | ||||
|  int printbuf_memappend(struct printbuf *p, const char *buf, int size) | ||||
|  { | ||||
| +  /* Prevent signed integer overflows with large buffers. */ | ||||
| +  if (size > INT_MAX - p->bpos - 1) | ||||
| +    return -1; | ||||
|    if (p->size <= p->bpos + size + 1) { | ||||
|      if (printbuf_extend(p, p->bpos + size + 1) < 0) | ||||
|        return -1; | ||||
| @@ -94,6 +107,9 @@ int printbuf_memset(struct printbuf *pb, | ||||
|   | ||||
|  	if (offset == -1) | ||||
|  		offset = pb->bpos; | ||||
| +	/* Prevent signed integer overflows with large buffers. */ | ||||
| +	if (len > INT_MAX - offset) | ||||
| +		return -1; | ||||
|  	size_needed = offset + len; | ||||
|  	if (pb->size < size_needed) | ||||
|  	{ | ||||
		Reference in New Issue
	
	Block a user
	 domenico
					domenico