Snap for 8730993 from 0afe50d908e619ee577845c6dc8afd8c220e5113 to mainline-tzdata3-release

Change-Id: I8044c0afd1da1b3cf73237307df8c13c4240976a
diff --git a/OWNERS b/OWNERS
index 2b614ec..9d88890 100644
--- a/OWNERS
+++ b/OWNERS
@@ -2,5 +2,4 @@
 # Please update this list if you find better candidates.
 enh@google.com
 deymo@google.com
-niwa@google.com
 sspatil@google.com
diff --git a/squashfs-tools/Android.bp b/squashfs-tools/Android.bp
index 6431f54..7619367 100644
--- a/squashfs-tools/Android.bp
+++ b/squashfs-tools/Android.bp
@@ -34,7 +34,6 @@
         "-DCOMP_DEFAULT=\"lz4\"",
         "-DGZIP_SUPPORT",
         "-DLZ4_SUPPORT",
-        "-DZSTD_SUPPORT",
         "-DXATTR_SUPPORT",
         "-DXATTR_DEFAULT",
         "-Wno-unused-parameter",
@@ -51,7 +50,6 @@
     ],
     static_libs: [
         "liblz4",
-        "libzstd",
         "libz",
     ],
 }
@@ -80,7 +78,6 @@
         "gzip_wrapper.c",
         "android.c",
         "lz4_wrapper.c",
-        "zstd_wrapper.c",
     ],
 }
 
@@ -103,6 +100,5 @@
         "gzip_wrapper.c",
         "android.c",
         "lz4_wrapper.c",
-        "zstd_wrapper.c",
     ],
 }
diff --git a/squashfs-tools/Makefile b/squashfs-tools/Makefile
index 7cafb7d..52d2582 100644
--- a/squashfs-tools/Makefile
+++ b/squashfs-tools/Makefile
@@ -75,17 +75,6 @@
 #LZMA_SUPPORT = 1
 #LZMA_DIR = ../../../../LZMA/lzma465
 
-########### Building ZSTD support ############
-#
-# The ZSTD library is supported
-# ZSTD homepage: http://zstd.net
-# ZSTD source repository: https://github.com/facebook/zstd
-#
-# To build using the ZSTD library - install the library and uncomment the
-# ZSTD_SUPPORT line below.
-#
-#ZSTD_SUPPORT = 1
-
 ######## Specifying default compression ########
 #
 # The next line specifies which compression algorithm is used by default
@@ -188,14 +177,6 @@
 COMPRESSORS += lz4
 endif
 
-ifeq ($(ZSTD_SUPPORT),1)
-CFLAGS += -DZSTD_SUPPORT
-MKSQUASHFS_OBJS += zstd_wrapper.o
-UNSQUASHFS_OBJS += zstd_wrapper.o
-LIBS += -lzstd
-COMPRESSORS += zstd
-endif
-
 ifeq ($(XATTR_SUPPORT),1)
 ifeq ($(XATTR_DEFAULT),1)
 CFLAGS += -DXATTR_SUPPORT -DXATTR_DEFAULT
diff --git a/squashfs-tools/compressor.c b/squashfs-tools/compressor.c
index 02b5e90..525e316 100644
--- a/squashfs-tools/compressor.c
+++ b/squashfs-tools/compressor.c
@@ -65,13 +65,6 @@
 extern struct compressor xz_comp_ops;
 #endif
 
-#ifndef ZSTD_SUPPORT
-static struct compressor zstd_comp_ops = {
-	ZSTD_COMPRESSION, "zstd"
-};
-#else
-extern struct compressor zstd_comp_ops;
-#endif
 
 static struct compressor unknown_comp_ops = {
 	0, "unknown"
@@ -84,7 +77,6 @@
 	&lzo_comp_ops,
 	&lz4_comp_ops,
 	&xz_comp_ops,
-	&zstd_comp_ops,
 	&unknown_comp_ops
 };
 
diff --git a/squashfs-tools/mksquashfs.c b/squashfs-tools/mksquashfs.c
index f122c25..dd75aaa 100644
--- a/squashfs-tools/mksquashfs.c
+++ b/squashfs-tools/mksquashfs.c
@@ -50,7 +50,6 @@
 #include <sys/wait.h>
 #include <limits.h>
 #include <ctype.h>
-#include <sys/sysmacros.h>
 
 #ifndef FNM_EXTMATCH /* glibc extension */
     #define FNM_EXTMATCH 0
diff --git a/squashfs-tools/squashfs_fs.h b/squashfs-tools/squashfs_fs.h
index afca918..791fe12 100644
--- a/squashfs-tools/squashfs_fs.h
+++ b/squashfs-tools/squashfs_fs.h
@@ -277,7 +277,6 @@
 #define LZO_COMPRESSION		3
 #define XZ_COMPRESSION		4
 #define LZ4_COMPRESSION		5
-#define ZSTD_COMPRESSION	6
 
 struct squashfs_super_block {
 	unsigned int		s_magic;
diff --git a/squashfs-tools/unsquashfs.c b/squashfs-tools/unsquashfs.c
index 643883b..0dbc4c2 100644
--- a/squashfs-tools/unsquashfs.c
+++ b/squashfs-tools/unsquashfs.c
@@ -37,7 +37,6 @@
 #include <sys/sysinfo.h>
 #endif
 
-#include <sys/sysmacros.h>
 #include <sys/types.h>
 #include <sys/time.h>
 #include <sys/resource.h>
diff --git a/squashfs-tools/zstd_wrapper.c b/squashfs-tools/zstd_wrapper.c
deleted file mode 100644
index dcab75a..0000000
--- a/squashfs-tools/zstd_wrapper.c
+++ /dev/null
@@ -1,254 +0,0 @@
-/*
- * Copyright (c) 2017
- * Phillip Lougher <phillip@squashfs.org.uk>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2,
- * or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * zstd_wrapper.c
- *
- * Support for ZSTD compression http://zstd.net
- */
-
-#include <stdio.h>
-#include <string.h>
-#include <stdlib.h>
-#include <zstd.h>
-#include <zstd_errors.h>
-
-#include "squashfs_fs.h"
-#include "zstd_wrapper.h"
-#include "compressor.h"
-
-static int compression_level = ZSTD_DEFAULT_COMPRESSION_LEVEL;
-
-/*
- * This function is called by the options parsing code in mksquashfs.c
- * to parse any -X compressor option.
- *
- * This function returns:
- *	>=0 (number of additional args parsed) on success
- *	-1 if the option was unrecognised, or
- *	-2 if the option was recognised, but otherwise bad in
- *	   some way (e.g. invalid parameter)
- *
- * Note: this function sets internal compressor state, but does not
- * pass back the results of the parsing other than success/failure.
- * The zstd_dump_options() function is called later to get the options in
- * a format suitable for writing to the filesystem.
- */
-static int zstd_options(char *argv[], int argc)
-{
-	if (strcmp(argv[0], "-Xcompression-level") == 0) {
-		if (argc < 2) {
-			fprintf(stderr, "zstd: -Xcompression-level missing "
-				"compression level\n");
-			fprintf(stderr, "zstd: -Xcompression-level it should "
-				"be 1 <= n <= %d\n", ZSTD_maxCLevel());
-			goto failed;
-		}
-
-		compression_level = atoi(argv[1]);
-		if (compression_level < 1 ||
-		    compression_level > ZSTD_maxCLevel()) {
-			fprintf(stderr, "zstd: -Xcompression-level invalid, it "
-				"should be 1 <= n <= %d\n", ZSTD_maxCLevel());
-			goto failed;
-		}
-
-		return 1;
-	}
-
-	return -1;
-failed:
-	return -2;
-}
-
-/*
- * This function is called by mksquashfs to dump the parsed
- * compressor options in a format suitable for writing to the
- * compressor options field in the filesystem (stored immediately
- * after the superblock).
- *
- * This function returns a pointer to the compression options structure
- * to be stored (and the size), or NULL if there are no compression
- * options.
- */
-static void *zstd_dump_options(int block_size, int *size)
-{
-	static struct zstd_comp_opts comp_opts;
-
-	/* don't return anything if the options are all default */
-	if (compression_level == ZSTD_DEFAULT_COMPRESSION_LEVEL)
-		return NULL;
-
-	comp_opts.compression_level = compression_level;
-
-	SQUASHFS_INSWAP_COMP_OPTS(&comp_opts);
-
-	*size = sizeof(comp_opts);
-	return &comp_opts;
-}
-
-/*
- * This function is a helper specifically for the append mode of
- * mksquashfs.  Its purpose is to set the internal compressor state
- * to the stored compressor options in the passed compressor options
- * structure.
- *
- * In effect this function sets up the compressor options
- * to the same state they were when the filesystem was originally
- * generated, this is to ensure on appending, the compressor uses
- * the same compression options that were used to generate the
- * original filesystem.
- *
- * Note, even if there are no compressor options, this function is still
- * called with an empty compressor structure (size == 0), to explicitly
- * set the default options, this is to ensure any user supplied
- * -X options on the appending mksquashfs command line are over-ridden.
- *
- * This function returns 0 on sucessful extraction of options, and -1 on error.
- */
-static int zstd_extract_options(int block_size, void *buffer, int size)
-{
-	struct zstd_comp_opts *comp_opts = buffer;
-
-	if (size == 0) {
-		/* Set default values */
-		compression_level = ZSTD_DEFAULT_COMPRESSION_LEVEL;
-		return 0;
-	}
-
-	/* we expect a comp_opts structure of sufficient size to be present */
-	if (size < sizeof(*comp_opts))
-		goto failed;
-
-	SQUASHFS_INSWAP_COMP_OPTS(comp_opts);
-
-	if (comp_opts->compression_level < 1 ||
-	    comp_opts->compression_level > ZSTD_maxCLevel()) {
-		fprintf(stderr, "zstd: bad compression level in compression "
-			"options structure\n");
-		goto failed;
-	}
-
-	compression_level = comp_opts->compression_level;
-
-	return 0;
-
-failed:
-	fprintf(stderr, "zstd: error reading stored compressor options from "
-		"filesystem!\n");
-
-	return -1;
-}
-
-static void zstd_display_options(void *buffer, int size)
-{
-	struct zstd_comp_opts *comp_opts = buffer;
-
-	/* we expect a comp_opts structure of sufficient size to be present */
-	if (size < sizeof(*comp_opts))
-		goto failed;
-
-	SQUASHFS_INSWAP_COMP_OPTS(comp_opts);
-
-	if (comp_opts->compression_level < 1 ||
-	    comp_opts->compression_level > ZSTD_maxCLevel()) {
-		fprintf(stderr, "zstd: bad compression level in compression "
-			"options structure\n");
-		goto failed;
-	}
-
-	printf("\tcompression-level %d\n", comp_opts->compression_level);
-
-	return;
-
-failed:
-	fprintf(stderr, "zstd: error reading stored compressor options from "
-		"filesystem!\n");
-}
-
-/*
- * This function is called by mksquashfs to initialise the
- * compressor, before compress() is called.
- *
- * This function returns 0 on success, and -1 on error.
- */
-static int zstd_init(void **strm, int block_size, int datablock)
-{
-	ZSTD_CCtx *cctx = ZSTD_createCCtx();
-
-	if (!cctx) {
-		fprintf(stderr, "zstd: failed to allocate compression "
-			"context!\n");
-		return -1;
-	}
-
-	*strm = cctx;
-	return 0;
-}
-
-static int zstd_compress(void *strm, void *dest, void *src, int size,
-			 int block_size, int *error)
-{
-	const size_t res = ZSTD_compressCCtx((ZSTD_CCtx*)strm, dest, block_size,
-					     src, size, compression_level);
-
-	if (ZSTD_isError(res)) {
-		/* FIXME:
-		 * zstd does not expose stable error codes. The error enum may
-		 * change between versions. Until upstream zstd stablizes the
-		 * error codes, we have no way of knowing why the error occurs.
-		 * zstd shouldn't fail to compress any input unless there isn't
-		 * enough output space. We assume that is the cause and return
-		 * the special error code for not enough output space.
-		 */
-		return 0;
-	}
-
-	return (int)res;
-}
-
-static int zstd_uncompress(void *dest, void *src, int size, int outsize,
-			   int *error)
-{
-	const size_t res = ZSTD_decompress(dest, outsize, src, size);
-
-	if (ZSTD_isError(res)) {
-		fprintf(stderr, "\t%d %d\n", outsize, size);
-
-		*error = (int)ZSTD_getErrorCode(res);
-		return -1;
-	}
-
-	return (int)res;
-}
-
-static void zstd_usage(void)
-{
-	fprintf(stderr, "\t  -Xcompression-level <compression-level>\n");
-	fprintf(stderr, "\t\t<compression-level> should be 1 .. %d (default "
-		"%d)\n", ZSTD_maxCLevel(), ZSTD_DEFAULT_COMPRESSION_LEVEL);
-}
-
-struct compressor zstd_comp_ops = {
-	.init = zstd_init,
-	.compress = zstd_compress,
-	.uncompress = zstd_uncompress,
-	.options = zstd_options,
-	.dump_options = zstd_dump_options,
-	.extract_options = zstd_extract_options,
-	.display_options = zstd_display_options,
-	.usage = zstd_usage,
-	.id = ZSTD_COMPRESSION,
-	.name = "zstd",
-	.supported = 1
-};
diff --git a/squashfs-tools/zstd_wrapper.h b/squashfs-tools/zstd_wrapper.h
deleted file mode 100644
index 4fbef0a..0000000
--- a/squashfs-tools/zstd_wrapper.h
+++ /dev/null
@@ -1,48 +0,0 @@
-#ifndef ZSTD_WRAPPER_H
-#define ZSTD_WRAPPER_H
-/*
- * Squashfs
- *
- * Copyright (c) 2017
- * Phillip Lougher <phillip@squashfs.org.uk>
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU General Public License
- * as published by the Free Software Foundation; either version 2,
- * or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU General Public License for more details.
- *
- * zstd_wrapper.h
- *
- */
-
-#ifndef linux
-#define __BYTE_ORDER BYTE_ORDER
-#define __BIG_ENDIAN BIG_ENDIAN
-#define __LITTLE_ENDIAN LITTLE_ENDIAN
-#else
-#include <endian.h>
-#endif
-
-#if __BYTE_ORDER == __BIG_ENDIAN
-extern unsigned int inswap_le16(unsigned short);
-extern unsigned int inswap_le32(unsigned int);
-
-#define SQUASHFS_INSWAP_COMP_OPTS(s) { \
-	(s)->compression_level = inswap_le32((s)->compression_level); \
-}
-#else
-#define SQUASHFS_INSWAP_COMP_OPTS(s)
-#endif
-
-/* Default compression */
-#define ZSTD_DEFAULT_COMPRESSION_LEVEL 15
-
-struct zstd_comp_opts {
-	int compression_level;
-};
-#endif