From owner-svn-src-user@FreeBSD.ORG Thu Apr 16 03:39:52 2015 Return-Path: Delivered-To: svn-src-user@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:1900:2254:206a::19:1]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by hub.freebsd.org (Postfix) with ESMTPS id AC000B7; Thu, 16 Apr 2015 03:39:52 +0000 (UTC) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id 93782195; Thu, 16 Apr 2015 03:39:52 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.9/8.14.9) with ESMTP id t3G3dq1T082909; Thu, 16 Apr 2015 03:39:52 GMT (envelope-from ngie@FreeBSD.org) Received: (from ngie@localhost) by svn.freebsd.org (8.14.9/8.14.9/Submit) id t3G3dYY8082748; Thu, 16 Apr 2015 03:39:34 GMT (envelope-from ngie@FreeBSD.org) Message-Id: <201504160339.t3G3dYY8082748@svn.freebsd.org> X-Authentication-Warning: svn.freebsd.org: ngie set sender to ngie@FreeBSD.org using -f From: Garrett Cooper Date: Thu, 16 Apr 2015 03:39:34 +0000 (UTC) To: src-committers@freebsd.org, svn-src-user@freebsd.org Subject: svn commit: r281585 - in user/ngie/more-tests: . bin/csh contrib/pjdfstest/tests/open contrib/pjdfstest/tests/truncate contrib/smbfs/include/netsmb contrib/smbfs/lib/smb etc etc/rc.d include lib/li... X-SVN-Group: user MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-user@freebsd.org X-Mailman-Version: 2.1.20 Precedence: list List-Id: "SVN commit messages for the experimental " user" src tree" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 16 Apr 2015 03:39:52 -0000 Author: ngie Date: Thu Apr 16 03:39:33 2015 New Revision: 281585 URL: https://svnweb.freebsd.org/changeset/base/281585 Log: MFhead @ r281584 Added: user/ngie/more-tests/sys/arm64/include/psl.h - copied unchanged from r281584, head/sys/arm64/include/psl.h user/ngie/more-tests/sys/boot/Makefile.arm64 - copied unchanged from r281584, head/sys/boot/Makefile.arm64 user/ngie/more-tests/sys/boot/arm64/ - copied from r281584, head/sys/boot/arm64/ user/ngie/more-tests/sys/boot/efi/boot1/fat-arm64.tmpl.bz2.uu - copied unchanged from r281584, head/sys/boot/efi/boot1/fat-arm64.tmpl.bz2.uu user/ngie/more-tests/sys/boot/efi/include/arm64/ - copied from r281584, head/sys/boot/efi/include/arm64/ user/ngie/more-tests/sys/boot/efi/loader/arch/arm64/ - copied from r281584, head/sys/boot/efi/loader/arch/arm64/ Modified: user/ngie/more-tests/UPDATING user/ngie/more-tests/bin/csh/config.h user/ngie/more-tests/contrib/pjdfstest/tests/open/20.t user/ngie/more-tests/contrib/pjdfstest/tests/truncate/11.t user/ngie/more-tests/contrib/smbfs/include/netsmb/smb_lib.h user/ngie/more-tests/contrib/smbfs/lib/smb/nls.c user/ngie/more-tests/contrib/smbfs/lib/smb/print.c user/ngie/more-tests/contrib/smbfs/lib/smb/rq.c user/ngie/more-tests/etc/login.conf user/ngie/more-tests/etc/rc.d/hostid_save user/ngie/more-tests/include/iconv.h user/ngie/more-tests/lib/libarchive/Makefile user/ngie/more-tests/lib/libc/iconv/__iconv.c user/ngie/more-tests/lib/libc/iconv/bsd_iconv.c user/ngie/more-tests/lib/libc/iconv/citrus_iconv.h user/ngie/more-tests/lib/libc/iconv/citrus_iconv_local.h user/ngie/more-tests/lib/libc/iconv/citrus_none.c user/ngie/more-tests/lib/libc/iconv/citrus_stdenc.h user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_local.h user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_template.h user/ngie/more-tests/lib/libc/iconv/iconv-internal.h user/ngie/more-tests/lib/libc/iconv/iconv.3 user/ngie/more-tests/lib/libc/iconv/iconv.c user/ngie/more-tests/lib/libc/iconv/iconv_compat.c user/ngie/more-tests/lib/libc/locale/cXXrtomb_iconv.h user/ngie/more-tests/lib/libc/locale/mbrtocXX_iconv.h user/ngie/more-tests/lib/libiconv_modules/BIG5/citrus_big5.c user/ngie/more-tests/lib/libiconv_modules/DECHanyu/citrus_dechanyu.c user/ngie/more-tests/lib/libiconv_modules/EUC/citrus_euc.c user/ngie/more-tests/lib/libiconv_modules/EUCTW/citrus_euctw.c user/ngie/more-tests/lib/libiconv_modules/GBK2K/citrus_gbk2k.c user/ngie/more-tests/lib/libiconv_modules/HZ/citrus_hz.c user/ngie/more-tests/lib/libiconv_modules/ISO2022/citrus_iso2022.c user/ngie/more-tests/lib/libiconv_modules/JOHAB/citrus_johab.c user/ngie/more-tests/lib/libiconv_modules/MSKanji/citrus_mskanji.c user/ngie/more-tests/lib/libiconv_modules/UES/citrus_ues.c user/ngie/more-tests/lib/libiconv_modules/UTF1632/citrus_utf1632.c user/ngie/more-tests/lib/libiconv_modules/UTF7/citrus_utf7.c user/ngie/more-tests/lib/libiconv_modules/UTF8/citrus_utf8.c user/ngie/more-tests/lib/libiconv_modules/VIQR/citrus_viqr.c user/ngie/more-tests/lib/libiconv_modules/ZW/citrus_zw.c user/ngie/more-tests/lib/libiconv_modules/iconv_none/citrus_iconv_none.c user/ngie/more-tests/lib/libiconv_modules/iconv_std/citrus_iconv_std.c user/ngie/more-tests/lib/libkiconv/xlat16_iconv.c user/ngie/more-tests/libexec/rtld-elf/aarch64/reloc.c user/ngie/more-tests/libexec/rtld-elf/rtld.c user/ngie/more-tests/libexec/rtld-elf/rtld.h user/ngie/more-tests/sys/arm64/arm64/vfp.c user/ngie/more-tests/sys/arm64/arm64/vm_machdep.c user/ngie/more-tests/sys/boot/Makefile.arm user/ngie/more-tests/sys/boot/common/Makefile.inc user/ngie/more-tests/sys/boot/efi/Makefile user/ngie/more-tests/sys/boot/efi/boot1/Makefile user/ngie/more-tests/sys/boot/efi/boot1/generate-fat.sh user/ngie/more-tests/sys/boot/efi/fdt/Makefile user/ngie/more-tests/sys/boot/efi/libefi/Makefile user/ngie/more-tests/sys/boot/efi/loader/Makefile user/ngie/more-tests/sys/boot/efi/loader/arch/arm/start.S user/ngie/more-tests/sys/boot/efi/loader/copy.c user/ngie/more-tests/sys/cam/cam_xpt.c user/ngie/more-tests/sys/compat/freebsd32/freebsd32_misc.c user/ngie/more-tests/sys/compat/linprocfs/linprocfs.c user/ngie/more-tests/sys/dev/sound/pci/hda/hdaa_patches.c user/ngie/more-tests/sys/dev/sound/pci/hda/hdac.c user/ngie/more-tests/sys/dev/sound/pci/hda/hdac.h user/ngie/more-tests/sys/dev/sound/pci/hda/hdacc.c user/ngie/more-tests/sys/dev/vt/vt_font.c user/ngie/more-tests/sys/fs/ext2fs/ext2_vfsops.c user/ngie/more-tests/sys/fs/fuse/fuse_vfsops.c user/ngie/more-tests/sys/fs/msdosfs/msdosfs_vfsops.c user/ngie/more-tests/sys/fs/nandfs/nandfs_vfsops.c user/ngie/more-tests/sys/fs/nfsclient/nfs_clvfsops.c user/ngie/more-tests/sys/fs/nfsserver/nfs_nfsdport.c user/ngie/more-tests/sys/fs/nullfs/null_vfsops.c user/ngie/more-tests/sys/kern/imgact_elf.c user/ngie/more-tests/sys/kern/kern_exec.c user/ngie/more-tests/sys/kern/kern_poll.c user/ngie/more-tests/sys/kern/kern_resource.c user/ngie/more-tests/sys/kern/kern_timeout.c user/ngie/more-tests/sys/kern/subr_bus.c user/ngie/more-tests/sys/kern/vfs_subr.c user/ngie/more-tests/sys/kern/vfs_syscalls.c user/ngie/more-tests/sys/net/if_types.h user/ngie/more-tests/sys/net/pfvar.h user/ngie/more-tests/sys/net/route.c user/ngie/more-tests/sys/netinet/ip_reass.c user/ngie/more-tests/sys/netpfil/pf/pf.c user/ngie/more-tests/sys/netpfil/pf/pf_norm.c user/ngie/more-tests/sys/sys/imgact.h user/ngie/more-tests/sys/sys/mount.h user/ngie/more-tests/sys/sys/param.h user/ngie/more-tests/sys/sys/syscallsubr.h user/ngie/more-tests/sys/ufs/ffs/ffs_vfsops.c user/ngie/more-tests/usr.bin/Makefile user/ngie/more-tests/usr.bin/gzip/gzip.c user/ngie/more-tests/usr.bin/iconv/iconv.c user/ngie/more-tests/usr.bin/ipcs/ipc.c user/ngie/more-tests/usr.bin/ipcs/ipc.h user/ngie/more-tests/usr.bin/lockf/lockf.c user/ngie/more-tests/usr.sbin/bhyve/bhyverun.c user/ngie/more-tests/usr.sbin/bhyvectl/bhyvectl.c user/ngie/more-tests/usr.sbin/ctld/discovery.c user/ngie/more-tests/usr.sbin/ctld/isns.c user/ngie/more-tests/usr.sbin/ctld/keys.c user/ngie/more-tests/usr.sbin/ctld/login.c user/ngie/more-tests/usr.sbin/ctld/parse.y user/ngie/more-tests/usr.sbin/ctld/pdu.c user/ngie/more-tests/usr.sbin/ctld/token.l user/ngie/more-tests/usr.sbin/freebsd-update/freebsd-update.sh user/ngie/more-tests/usr.sbin/vidcontrol/vidcontrol.c Directory Properties: user/ngie/more-tests/ (props changed) user/ngie/more-tests/etc/ (props changed) user/ngie/more-tests/include/ (props changed) user/ngie/more-tests/lib/libc/ (props changed) user/ngie/more-tests/sys/ (props changed) user/ngie/more-tests/sys/boot/ (props changed) user/ngie/more-tests/usr.sbin/bhyve/ (props changed) user/ngie/more-tests/usr.sbin/bhyvectl/ (props changed) Modified: user/ngie/more-tests/UPDATING ============================================================================== --- user/ngie/more-tests/UPDATING Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/UPDATING Thu Apr 16 03:39:33 2015 (r281585) @@ -31,6 +31,10 @@ NOTE TO PEOPLE WHO THINK THAT FreeBSD 11 disable the most expensive debugging functionality run "ln -s 'abort:false,junk:false' /etc/malloc.conf".) +20150415: + The const qualifier has been removed from iconv(3) to comply with + POSIX. The ports tree is aware of this from r384038 onwards. + 20150324: From legacy ata(4) driver was removed support for SATA controllers supported by more functional drivers ahci(4), siis(4) and mvs(4). Modified: user/ngie/more-tests/bin/csh/config.h ============================================================================== --- user/ngie/more-tests/bin/csh/config.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/bin/csh/config.h Thu Apr 16 03:39:33 2015 (r281585) @@ -198,7 +198,7 @@ #define HAVE_WCWIDTH 1 /* Define as const if the declaration of iconv() needs const. */ -#define ICONV_CONST const +#define ICONV_CONST /* Support NLS. */ #define NLS 1 Modified: user/ngie/more-tests/contrib/pjdfstest/tests/open/20.t ============================================================================== --- user/ngie/more-tests/contrib/pjdfstest/tests/open/20.t Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/pjdfstest/tests/open/20.t Thu Apr 16 03:39:33 2015 (r281585) @@ -14,7 +14,11 @@ n0=`namegen` cp -pf `which sleep` ${n0} ./${n0} 3 & +while ! pkill -0 -f ./${n0}; do + sleep 0.1 +done expect ETXTBSY open ${n0} O_WRONLY expect ETXTBSY open ${n0} O_RDWR expect ETXTBSY open ${n0} O_RDONLY,O_TRUNC +pkill -9 -f ./${n0} expect 0 unlink ${n0} Modified: user/ngie/more-tests/contrib/pjdfstest/tests/truncate/11.t ============================================================================== --- user/ngie/more-tests/contrib/pjdfstest/tests/truncate/11.t Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/pjdfstest/tests/truncate/11.t Thu Apr 16 03:39:33 2015 (r281585) @@ -14,5 +14,9 @@ n0=`namegen` cp -pf `which sleep` ${n0} ./${n0} 3 & +while ! pkill -0 -f ./${n0}; do + sleep 0.1 +done expect ETXTBSY truncate ${n0} 123 +pkill -9 -f ./${n0} expect 0 unlink ${n0} Modified: user/ngie/more-tests/contrib/smbfs/include/netsmb/smb_lib.h ============================================================================== --- user/ngie/more-tests/contrib/smbfs/include/netsmb/smb_lib.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/smbfs/include/netsmb/smb_lib.h Thu Apr 16 03:39:33 2015 (r281585) @@ -191,7 +191,7 @@ int smb_ctx_readrc(struct smb_ctx *); int smb_ctx_resolve(struct smb_ctx *); int smb_ctx_setflags(struct smb_ctx *, int, int, int); -int smb_smb_open_print_file(struct smb_ctx *, int, int, const char *, smbfh*); +int smb_smb_open_print_file(struct smb_ctx *, int, int, char *, smbfh*); int smb_smb_close_print_file(struct smb_ctx *, smbfh); int smb_read(struct smb_ctx *, smbfh, off_t, size_t, char *); @@ -204,8 +204,8 @@ int smb_rq_init(struct smb_ctx *, u_cha void smb_rq_done(struct smb_rq *); void smb_rq_wend(struct smb_rq *); int smb_rq_simple(struct smb_rq *); -int smb_rq_dmem(struct mbdata *, const char *, size_t); -int smb_rq_dstring(struct mbdata *, const char *); +int smb_rq_dmem(struct mbdata *, char *, size_t); +int smb_rq_dstring(struct mbdata *, char *); int smb_t2_request(struct smb_ctx *, int, int, const char *, int, void *, int, void *, int *, void *, int *, void *); @@ -246,10 +246,10 @@ extern u_char nls_lower[256], nls_upper[ int nls_setrecode(const char *, const char *); int nls_setlocale(const char *); -char* nls_str_toext(char *, const char *); -char* nls_str_toloc(char *, const char *); -void* nls_mem_toext(void *, const void *, int); -void* nls_mem_toloc(void *, const void *, int); +char* nls_str_toext(char *, char *); +char* nls_str_toloc(char *, char *); +void* nls_mem_toext(void *, void *, int); +void* nls_mem_toloc(void *, void *, int); char* nls_str_upper(char *, const char *); char* nls_str_lower(char *, const char *); Modified: user/ngie/more-tests/contrib/smbfs/lib/smb/nls.c ============================================================================== --- user/ngie/more-tests/contrib/smbfs/lib/smb/nls.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/smbfs/lib/smb/nls.c Thu Apr 16 03:39:33 2015 (r281585) @@ -102,7 +102,7 @@ nls_setrecode(const char *local, const c } char * -nls_str_toloc(char *dst, const char *src) +nls_str_toloc(char *dst, char *src) { #ifdef HAVE_ICONV char *p = dst; @@ -125,7 +125,7 @@ nls_str_toloc(char *dst, const char *src } char * -nls_str_toext(char *dst, const char *src) +nls_str_toext(char *dst, char *src) { #ifdef HAVE_ICONV char *p = dst; @@ -148,11 +148,11 @@ nls_str_toext(char *dst, const char *src } void * -nls_mem_toloc(void *dst, const void *src, int size) +nls_mem_toloc(void *dst, void *src, int size) { #ifdef HAVE_ICONV char *p = dst; - const char *s = src; + char *s = src; size_t inlen, outlen; if (size == 0) @@ -174,11 +174,11 @@ nls_mem_toloc(void *dst, const void *src } void * -nls_mem_toext(void *dst, const void *src, int size) +nls_mem_toext(void *dst, void *src, int size) { #ifdef HAVE_ICONV char *p = dst; - const char *s = src; + char *s = src; size_t inlen, outlen; if (size == 0) Modified: user/ngie/more-tests/contrib/smbfs/lib/smb/print.c ============================================================================== --- user/ngie/more-tests/contrib/smbfs/lib/smb/print.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/smbfs/lib/smb/print.c Thu Apr 16 03:39:33 2015 (r281585) @@ -54,7 +54,7 @@ int smb_smb_open_print_file(struct smb_ctx *ctx, int setuplen, int mode, - const char *ident, smbfh *fhp) + char *ident, smbfh *fhp) { struct smb_rq *rqp; struct mbdata *mbp; Modified: user/ngie/more-tests/contrib/smbfs/lib/smb/rq.c ============================================================================== --- user/ngie/more-tests/contrib/smbfs/lib/smb/rq.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/contrib/smbfs/lib/smb/rq.c Thu Apr 16 03:39:33 2015 (r281585) @@ -86,7 +86,7 @@ smb_rq_wend(struct smb_rq *rqp) } int -smb_rq_dmem(struct mbdata *mbp, const char *src, size_t size) +smb_rq_dmem(struct mbdata *mbp, char *src, size_t size) { struct mbuf *m; char * dst; @@ -118,7 +118,7 @@ smb_rq_dmem(struct mbdata *mbp, const ch } int -smb_rq_dstring(struct mbdata *mbp, const char *s) +smb_rq_dstring(struct mbdata *mbp, char *s) { return smb_rq_dmem(mbp, s, strlen(s) + 1); } Modified: user/ngie/more-tests/etc/login.conf ============================================================================== --- user/ngie/more-tests/etc/login.conf Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/etc/login.conf Thu Apr 16 03:39:33 2015 (r281585) @@ -26,7 +26,7 @@ default:\ :passwd_format=sha512:\ :copyright=/etc/COPYRIGHT:\ :welcome=/etc/motd:\ - :setenv=MAIL=/var/mail/$,BLOCKSIZE=K:LC_COLLATE=C:\ + :setenv=MAIL=/var/mail/$,BLOCKSIZE=K,LC_COLLATE=C:\ :path=/sbin /bin /usr/sbin /usr/bin /usr/local/sbin /usr/local/bin ~/bin:\ :nologin=/var/run/nologin:\ :cputime=unlimited:\ Modified: user/ngie/more-tests/etc/rc.d/hostid_save ============================================================================== --- user/ngie/more-tests/etc/rc.d/hostid_save Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/etc/rc.d/hostid_save Thu Apr 16 03:39:33 2015 (r281585) @@ -16,12 +16,19 @@ rcvar="hostid_enable" hostid_save() { - if [ ! -r ${hostid_file} ]; then - $SYSCTL_N kern.hostuuid > ${hostid_file} - if [ $? -ne 0 ]; then - warn "could not store hostuuid in ${hostid_file}." + current_hostid=`$SYSCTL_N kern.hostuuid` + + if [ -r ${hostid_file} ]; then + read saved_hostid < ${hostid_file} + if [ ${saved_hostid} = ${current_hostid} ]; then + exit 0 fi fi + + echo ${current_hostid} > ${hostid_file} + if [ $? -ne 0 ]; then + warn "could not store hostuuid in ${hostid_file}." + fi } load_rc_config $name Modified: user/ngie/more-tests/include/iconv.h ============================================================================== --- user/ngie/more-tests/include/iconv.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/include/iconv.h Thu Apr 16 03:39:33 2015 (r281585) @@ -53,7 +53,7 @@ typedef struct __tag_iconv_t *iconv_t; __BEGIN_DECLS iconv_t iconv_open(const char *, const char *); -size_t iconv(iconv_t, const char ** __restrict, +size_t iconv(iconv_t, char ** __restrict, size_t * __restrict, char ** __restrict, size_t * __restrict); int iconv_close(iconv_t); @@ -62,7 +62,7 @@ int iconv_close(iconv_t); */ int __iconv_get_list(char ***, size_t *, __iconv_bool); void __iconv_free_list(char **, size_t); -size_t __iconv(iconv_t, const char **, size_t *, char **, +size_t __iconv(iconv_t, char **, size_t *, char **, size_t *, __uint32_t, size_t *); #define __ICONV_F_HIDE_INVALID 0x0001 Modified: user/ngie/more-tests/lib/libarchive/Makefile ============================================================================== --- user/ngie/more-tests/lib/libarchive/Makefile Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libarchive/Makefile Thu Apr 16 03:39:33 2015 (r281585) @@ -25,7 +25,7 @@ LIBADD+= md .if ${MK_ICONV} != "no" # TODO: This can be changed back to CFLAGS once iconv works correctly # with statically linked binaries. -SHARED_CFLAGS+= -DHAVE_ICONV=1 -DHAVE_ICONV_H=1 -DICONV_CONST=const +SHARED_CFLAGS+= -DHAVE_ICONV=1 -DHAVE_ICONV_H=1 -DICONV_CONST= .endif .if ${MACHINE_ARCH:Marm*} != "" || ${MACHINE_ARCH:Mmips*} != "" || \ Modified: user/ngie/more-tests/lib/libc/iconv/__iconv.c ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/__iconv.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/__iconv.c Thu Apr 16 03:39:33 2015 (r281585) @@ -31,7 +31,7 @@ #include "iconv-internal.h" size_t -__iconv(iconv_t a, const char **b, size_t *c, char **d, +__iconv(iconv_t a, char **b, size_t *c, char **d, size_t *e, __uint32_t f, size_t *g) { return __bsd___iconv(a, b, c, d, e, f, g); Modified: user/ngie/more-tests/lib/libc/iconv/bsd_iconv.c ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/bsd_iconv.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/bsd_iconv.c Thu Apr 16 03:39:33 2015 (r281585) @@ -120,7 +120,7 @@ __bsd_iconv_close(iconv_t handle) } size_t -__bsd_iconv(iconv_t handle, const char **in, size_t *szin, char **out, size_t *szout) +__bsd_iconv(iconv_t handle, char **in, size_t *szin, char **out, size_t *szout) { size_t ret; int err; @@ -141,7 +141,7 @@ __bsd_iconv(iconv_t handle, const char * } size_t -__bsd___iconv(iconv_t handle, const char **in, size_t *szin, char **out, +__bsd___iconv(iconv_t handle, char **in, size_t *szin, char **out, size_t *szout, uint32_t flags, size_t *invalids) { size_t ret; Modified: user/ngie/more-tests/lib/libc/iconv/citrus_iconv.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_iconv.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_iconv.h Thu Apr 16 03:39:33 2015 (r281585) @@ -52,7 +52,7 @@ __END_DECLS */ static __inline int _citrus_iconv_convert(struct _citrus_iconv * __restrict cv, - const char * __restrict * __restrict in, size_t * __restrict inbytes, + char * __restrict * __restrict in, size_t * __restrict inbytes, char * __restrict * __restrict out, size_t * __restrict outbytes, uint32_t flags, size_t * __restrict nresults) { Modified: user/ngie/more-tests/lib/libc/iconv/citrus_iconv_local.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_iconv_local.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_iconv_local.h Thu Apr 16 03:39:33 2015 (r281585) @@ -46,7 +46,7 @@ static void _citrus_##_m_##_iconv_unini (struct _citrus_iconv_shared *); \ static int _citrus_##_m_##_iconv_convert \ (struct _citrus_iconv * __restrict, \ - const char * __restrict * __restrict, \ + char * __restrict * __restrict, \ size_t * __restrict, \ char * __restrict * __restrict, \ size_t * __restrict outbytes, \ @@ -75,7 +75,7 @@ typedef void (*_citrus_iconv_uninit_shar (struct _citrus_iconv_shared *); typedef int (*_citrus_iconv_convert_t) (struct _citrus_iconv * __restrict, - const char *__restrict* __restrict, size_t * __restrict, + char *__restrict* __restrict, size_t * __restrict, char * __restrict * __restrict, size_t * __restrict, uint32_t, size_t * __restrict); typedef int (*_citrus_iconv_init_context_t)(struct _citrus_iconv *); Modified: user/ngie/more-tests/lib/libc/iconv/citrus_none.c ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_none.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_none.c Thu Apr 16 03:39:33 2015 (r281585) @@ -83,7 +83,7 @@ _citrus_NONE_stdenc_init_state(struct _c static int _citrus_NONE_stdenc_mbtocs(struct _citrus_stdenc * __restrict ce __unused, - _csid_t *csid, _index_t *idx, const char **s, size_t n, + _csid_t *csid, _index_t *idx, char **s, size_t n, void *ps __unused, size_t *nresult, struct iconv_hooks *hooks) { @@ -159,7 +159,7 @@ _citrus_NONE_stdenc_cstomb(struct _citru static int _citrus_NONE_stdenc_mbtowc(struct _citrus_stdenc * __restrict ce __unused, - _wc_t * __restrict pwc, const char ** __restrict s, size_t n, + _wc_t * __restrict pwc, char ** __restrict s, size_t n, void * __restrict pspriv __unused, size_t * __restrict nresult, struct iconv_hooks *hooks) { Modified: user/ngie/more-tests/lib/libc/iconv/citrus_stdenc.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_stdenc.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_stdenc.h Thu Apr 16 03:39:33 2015 (r281585) @@ -69,7 +69,7 @@ _citrus_stdenc_init_state(struct _citrus static __inline int _citrus_stdenc_mbtocs(struct _citrus_stdenc * __restrict ce, _citrus_csid_t * __restrict csid, _citrus_index_t * __restrict idx, - const char ** __restrict s, size_t n, void * __restrict ps, + char ** __restrict s, size_t n, void * __restrict ps, size_t * __restrict nresult, struct iconv_hooks *hooks) { Modified: user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_local.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_local.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_local.h Thu Apr 16 03:39:33 2015 (r281585) @@ -55,7 +55,7 @@ static int _citrus_##_e_##_stdenc_mbtoc (struct _citrus_stdenc * __restrict, \ _citrus_csid_t * __restrict, \ _citrus_index_t * __restrict, \ - const char ** __restrict, size_t, \ + char ** __restrict, size_t, \ void * __restrict, size_t * __restrict, \ struct iconv_hooks *); \ static int _citrus_##_e_##_stdenc_cstomb \ @@ -66,7 +66,7 @@ static int _citrus_##_e_##_stdenc_cstom static int _citrus_##_e_##_stdenc_mbtowc \ (struct _citrus_stdenc * __restrict, \ _citrus_wc_t * __restrict, \ - const char ** __restrict, size_t, \ + char ** __restrict, size_t, \ void * __restrict, size_t * __restrict, \ struct iconv_hooks *); \ static int _citrus_##_e_##_stdenc_wctomb \ @@ -106,7 +106,7 @@ typedef int (*_citrus_stdenc_init_state_ typedef int (*_citrus_stdenc_mbtocs_t) (struct _citrus_stdenc * __restrict, _citrus_csid_t * __restrict, _citrus_index_t * __restrict, - const char ** __restrict, size_t, + char ** __restrict, size_t, void * __restrict, size_t * __restrict, struct iconv_hooks *); typedef int (*_citrus_stdenc_cstomb_t) @@ -116,7 +116,7 @@ typedef int (*_citrus_stdenc_cstomb_t) typedef int (*_citrus_stdenc_mbtowc_t) (struct _citrus_stdenc * __restrict, _citrus_wc_t * __restrict, - const char ** __restrict, size_t, + char ** __restrict, size_t, void * __restrict, size_t * __restrict, struct iconv_hooks *); typedef int (*_citrus_stdenc_wctomb_t) Modified: user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_template.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_template.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/citrus_stdenc_template.h Thu Apr 16 03:39:33 2015 (r281585) @@ -112,7 +112,7 @@ _FUNCNAME(stdenc_init_state)(struct _cit static int _FUNCNAME(stdenc_mbtocs)(struct _citrus_stdenc * __restrict ce, _citrus_csid_t * __restrict csid, _citrus_index_t * __restrict idx, - const char ** __restrict s, size_t n, void * __restrict ps, + char ** __restrict s, size_t n, void * __restrict ps, size_t * __restrict nresult, struct iconv_hooks *hooks) { wchar_t wc; @@ -151,7 +151,7 @@ _FUNCNAME(stdenc_cstomb)(struct _citrus_ static int _FUNCNAME(stdenc_mbtowc)(struct _citrus_stdenc * __restrict ce, - _citrus_wc_t * __restrict wc, const char ** __restrict s, size_t n, + _citrus_wc_t * __restrict wc, char ** __restrict s, size_t n, void * __restrict ps, size_t * __restrict nresult, struct iconv_hooks *hooks) { Modified: user/ngie/more-tests/lib/libc/iconv/iconv-internal.h ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/iconv-internal.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/iconv-internal.h Thu Apr 16 03:39:33 2015 (r281585) @@ -29,11 +29,11 @@ /* * Interal prototypes for our back-end functions. */ -size_t __bsd___iconv(iconv_t, const char **, size_t *, char **, +size_t __bsd___iconv(iconv_t, char **, size_t *, char **, size_t *, __uint32_t, size_t *); void __bsd___iconv_free_list(char **, size_t); int __bsd___iconv_get_list(char ***, size_t *, __iconv_bool); -size_t __bsd_iconv(iconv_t, const char ** __restrict, +size_t __bsd_iconv(iconv_t, char ** __restrict, size_t * __restrict, char ** __restrict, size_t * __restrict); const char *__bsd_iconv_canonicalize(const char *); Modified: user/ngie/more-tests/lib/libc/iconv/iconv.3 ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/iconv.3 Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/iconv.3 Thu Apr 16 03:39:33 2015 (r281585) @@ -48,7 +48,7 @@ .Ft size_t .Fn iconv "iconv_t cd" "char ** restrict src" "size_t * restrict srcleft" "char ** restrict dst" "size_t * restrict dstleft" .Ft size_t -.Fn __iconv "iconv_t cd" "const char ** restrict src" "size_t * restrict srcleft" "char ** restrict dst" "size_t * restrict dstleft" "uint32_t flags" "size_t * invalids" +.Fn __iconv "iconv_t cd" "char ** restrict src" "size_t * restrict srcleft" "char ** restrict dst" "size_t * restrict dstleft" "uint32_t flags" "size_t * invalids" .Sh DESCRIPTION The .Fn iconv_open Modified: user/ngie/more-tests/lib/libc/iconv/iconv.c ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/iconv.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/iconv.c Thu Apr 16 03:39:33 2015 (r281585) @@ -31,7 +31,7 @@ #include "iconv-internal.h" size_t -iconv(iconv_t a, const char ** __restrict b, +iconv(iconv_t a, char ** __restrict b, size_t * __restrict c, char ** __restrict d, size_t * __restrict e) { Modified: user/ngie/more-tests/lib/libc/iconv/iconv_compat.c ============================================================================== --- user/ngie/more-tests/lib/libc/iconv/iconv_compat.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/iconv/iconv_compat.c Thu Apr 16 03:39:33 2015 (r281585) @@ -37,7 +37,7 @@ #include "iconv-internal.h" size_t -__iconv_compat(iconv_t a, const char ** b, size_t * c, char ** d, +__iconv_compat(iconv_t a, char ** b, size_t * c, char ** d, size_t * e, __uint32_t f, size_t *g) { return __bsd___iconv(a, b, c, d, e, f, g); @@ -56,7 +56,7 @@ __iconv_get_list_compat(char ***a, size_ } size_t -iconv_compat(iconv_t a, const char ** __restrict b, +iconv_compat(iconv_t a, char ** __restrict b, size_t * __restrict c, char ** __restrict d, size_t * __restrict e) { Modified: user/ngie/more-tests/lib/libc/locale/cXXrtomb_iconv.h ============================================================================== --- user/ngie/more-tests/lib/libc/locale/cXXrtomb_iconv.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/locale/cXXrtomb_iconv.h Thu Apr 16 03:39:33 2015 (r281585) @@ -57,8 +57,7 @@ cXXrtomb_l(char * __restrict s, charXX_t { _ConversionState *cs; struct _citrus_iconv *handle; - const char *src; - char *dst; + char *src, *dst; size_t srcleft, dstleft, invlen; int err; Modified: user/ngie/more-tests/lib/libc/locale/mbrtocXX_iconv.h ============================================================================== --- user/ngie/more-tests/lib/libc/locale/mbrtocXX_iconv.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libc/locale/mbrtocXX_iconv.h Thu Apr 16 03:39:33 2015 (r281585) @@ -99,8 +99,7 @@ mbrtocXX_l(charXX_t * __restrict pc, con /* Convert as few characters to the dst buffer as possible. */ for (i = 0; ; i++) { - const char *src; - char *dst; + char *src, *dst; size_t srcleft, dstleft, invlen; int err; Modified: user/ngie/more-tests/lib/libiconv_modules/BIG5/citrus_big5.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/BIG5/citrus_big5.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/BIG5/citrus_big5.c Thu Apr 16 03:39:33 2015 (r281585) @@ -269,12 +269,12 @@ static int /*ARGSUSED*/ _citrus_BIG5_mbrtowc_priv(_BIG5EncodingInfo * __restrict ei, wchar_t * __restrict pwc, - const char ** __restrict s, size_t n, + char ** __restrict s, size_t n, _BIG5State * __restrict psenc, size_t * __restrict nresult) { wchar_t wchar; - const char *s0; + char *s0; int c, chlenbak; s0 = *s; Modified: user/ngie/more-tests/lib/libiconv_modules/DECHanyu/citrus_dechanyu.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/DECHanyu/citrus_dechanyu.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/DECHanyu/citrus_dechanyu.c Thu Apr 16 03:39:33 2015 (r281585) @@ -165,10 +165,10 @@ is_94charset(int c) static int /*ARGSUSED*/ _citrus_DECHanyu_mbrtowc_priv(_DECHanyuEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _DECHanyuState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; wchar_t wc; int ch; Modified: user/ngie/more-tests/lib/libiconv_modules/EUC/citrus_euc.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/EUC/citrus_euc.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/EUC/citrus_euc.c Thu Apr 16 03:39:33 2015 (r281585) @@ -190,12 +190,12 @@ _citrus_EUC_unpack_state(_EUCEncodingInf #endif static int -_citrus_EUC_mbrtowc_priv(_EUCEncodingInfo *ei, wchar_t *pwc, const char **s, +_citrus_EUC_mbrtowc_priv(_EUCEncodingInfo *ei, wchar_t *pwc, char **s, size_t n, _EUCState *psenc, size_t *nresult) { wchar_t wchar; int c, chlenbak, cs, len; - const char *s0, *s1 = NULL; + char *s0, *s1 = NULL; s0 = *s; Modified: user/ngie/more-tests/lib/libiconv_modules/EUCTW/citrus_euctw.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/EUCTW/citrus_euctw.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/EUCTW/citrus_euctw.c Thu Apr 16 03:39:33 2015 (r281585) @@ -176,10 +176,10 @@ _citrus_EUCTW_encoding_module_uninit(_EU static int _citrus_EUCTW_mbrtowc_priv(_EUCTWEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _EUCTWState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; wchar_t wchar; int c, chlenbak, cs; Modified: user/ngie/more-tests/lib/libiconv_modules/GBK2K/citrus_gbk2k.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/GBK2K/citrus_gbk2k.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/GBK2K/citrus_gbk2k.c Thu Apr 16 03:39:33 2015 (r281585) @@ -149,10 +149,10 @@ _mb_count(wchar_t v) static int _citrus_GBK2K_mbrtowc_priv(_GBK2KEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _GBK2KState * __restrict psenc, size_t * __restrict nresult) { - const char *s0, *s1; + char *s0, *s1; wchar_t wc; int chlenbak, len; Modified: user/ngie/more-tests/lib/libiconv_modules/HZ/citrus_hz.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/HZ/citrus_hz.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/HZ/citrus_hz.c Thu Apr 16 03:39:33 2015 (r281585) @@ -175,13 +175,13 @@ _citrus_HZ_unpack_state(_HZEncodingInfo static int _citrus_HZ_mbrtowc_priv(_HZEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _HZState * __restrict psenc, size_t * __restrict nresult) { escape_t *candidate, *init; graphic_t *graphic; const range_t *range; - const char *s0; + char *s0; wchar_t wc; int bit, ch, head, len, tail; Modified: user/ngie/more-tests/lib/libiconv_modules/ISO2022/citrus_iso2022.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/ISO2022/citrus_iso2022.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/ISO2022/citrus_iso2022.c Thu Apr 16 03:39:33 2015 (r281585) @@ -574,7 +574,7 @@ terminate: static wchar_t _ISO2022_sgetwchar(_ISO2022EncodingInfo * __restrict ei __unused, - const char * __restrict string, size_t n, const char ** __restrict result, + char * __restrict string, size_t n, char ** __restrict result, _ISO2022State * __restrict psenc) { const struct seqtable *sp; @@ -842,10 +842,10 @@ asis: static int _citrus_ISO2022_mbrtowc_priv(_ISO2022EncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _ISO2022State * __restrict psenc, size_t * __restrict nresult) { - const char *p, *result, *s0; + char *p, *result, *s0; wchar_t wchar; int c, chlenbak; Modified: user/ngie/more-tests/lib/libiconv_modules/JOHAB/citrus_johab.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/JOHAB/citrus_johab.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/JOHAB/citrus_johab.c Thu Apr 16 03:39:33 2015 (r281585) @@ -145,10 +145,10 @@ ishanja(int l, int t) static int /*ARGSUSED*/ _citrus_JOHAB_mbrtowc_priv(_JOHABEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _JOHABState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; int l, t; if (*s == NULL) { Modified: user/ngie/more-tests/lib/libiconv_modules/MSKanji/citrus_mskanji.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/MSKanji/citrus_mskanji.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/MSKanji/citrus_mskanji.c Thu Apr 16 03:39:33 2015 (r281585) @@ -153,10 +153,10 @@ _citrus_MSKanji_unpack_state(_MSKanjiEnc static int /*ARGSUSED*/ _citrus_MSKanji_mbrtowc_priv(_MSKanjiEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _MSKanjiState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; wchar_t wchar; int chlenbak, len; Modified: user/ngie/more-tests/lib/libiconv_modules/UES/citrus_ues.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/UES/citrus_ues.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/UES/citrus_ues.c Thu Apr 16 03:39:33 2015 (r281585) @@ -185,10 +185,10 @@ is_basic(wchar_t wc) static int _citrus_UES_mbrtowc_priv(_UESEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _UESState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; int ch, head, num, tail; wchar_t hi, wc; Modified: user/ngie/more-tests/lib/libiconv_modules/UTF1632/citrus_utf1632.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/UTF1632/citrus_utf1632.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/UTF1632/citrus_utf1632.c Thu Apr 16 03:39:33 2015 (r281585) @@ -97,9 +97,9 @@ _citrus_UTF1632_init_state(_UTF1632Encod static int _citrus_UTF1632_mbrtowc_priv(_UTF1632EncodingInfo *ei, wchar_t *pwc, - const char **s, size_t n, _UTF1632State *psenc, size_t *nresult) + char **s, size_t n, _UTF1632State *psenc, size_t *nresult) { - const char *s0; + char *s0; size_t result; wchar_t wc = L'\0'; int chlenbak, endian, needlen; Modified: user/ngie/more-tests/lib/libiconv_modules/UTF7/citrus_utf7.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/UTF7/citrus_utf7.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/UTF7/citrus_utf7.c Thu Apr 16 03:39:33 2015 (r281585) @@ -151,11 +151,11 @@ static const char spaces[] = " \t\r\n"; static int _citrus_UTF7_mbtoutf16(_UTF7EncodingInfo * __restrict ei, - uint16_t * __restrict u16, const char ** __restrict s, size_t n, + uint16_t * __restrict u16, char ** __restrict s, size_t n, _UTF7State * __restrict psenc, size_t * __restrict nresult) { _UTF7State sv; - const char *s0; + char *s0; int done, i, len; s0 = *s; @@ -244,7 +244,7 @@ ilseq: static int _citrus_UTF7_mbrtowc_priv(_UTF7EncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _UTF7State * __restrict psenc, size_t * __restrict nresult) { uint32_t u32; Modified: user/ngie/more-tests/lib/libiconv_modules/UTF8/citrus_utf8.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/UTF8/citrus_utf8.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/UTF8/citrus_utf8.c Thu Apr 16 03:39:33 2015 (r281585) @@ -177,10 +177,10 @@ _citrus_UTF8_unpack_state(_UTF8EncodingI #endif static int -_citrus_UTF8_mbrtowc_priv(_UTF8EncodingInfo *ei, wchar_t *pwc, const char **s, +_citrus_UTF8_mbrtowc_priv(_UTF8EncodingInfo *ei, wchar_t *pwc, char **s, size_t n, _UTF8State *psenc, size_t *nresult) { - const char *s0; + char *s0; wchar_t wchar; int i; uint8_t c; Modified: user/ngie/more-tests/lib/libiconv_modules/VIQR/citrus_viqr.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/VIQR/citrus_viqr.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/VIQR/citrus_viqr.c Thu Apr 16 03:39:33 2015 (r281585) @@ -252,11 +252,11 @@ _citrus_VIQR_unpack_state(_VIQREncodingI static int _citrus_VIQR_mbrtowc_priv(_VIQREncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char ** __restrict s, size_t n, + wchar_t * __restrict pwc, char ** __restrict s, size_t n, _VIQRState * __restrict psenc, size_t * __restrict nresult) { mnemonic_t *m, *m0; - const char *s0; + char *s0; wchar_t wc; ssize_t i; int ch, escape; Modified: user/ngie/more-tests/lib/libiconv_modules/ZW/citrus_zw.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/ZW/citrus_zw.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/ZW/citrus_zw.c Thu Apr 16 03:39:33 2015 (r281585) @@ -107,10 +107,10 @@ _citrus_ZW_unpack_state(_ZWEncodingInfo static int _citrus_ZW_mbrtowc_priv(_ZWEncodingInfo * __restrict ei, - wchar_t * __restrict pwc, const char **__restrict s, size_t n, + wchar_t * __restrict pwc, char **__restrict s, size_t n, _ZWState * __restrict psenc, size_t * __restrict nresult) { - const char *s0; + char *s0; wchar_t wc; int ch, len; Modified: user/ngie/more-tests/lib/libiconv_modules/iconv_none/citrus_iconv_none.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/iconv_none/citrus_iconv_none.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/iconv_none/citrus_iconv_none.c Thu Apr 16 03:39:33 2015 (r281585) @@ -97,7 +97,7 @@ _citrus_iconv_none_iconv_uninit_context( static int /*ARGSUSED*/ _citrus_iconv_none_iconv_convert(struct _citrus_iconv * __restrict ci __unused, - const char * __restrict * __restrict in, size_t * __restrict inbytes, + char * __restrict * __restrict in, size_t * __restrict inbytes, char * __restrict * __restrict out, size_t * __restrict outbytes, uint32_t flags __unused, size_t * __restrict invalids) { Modified: user/ngie/more-tests/lib/libiconv_modules/iconv_std/citrus_iconv_std.c ============================================================================== --- user/ngie/more-tests/lib/libiconv_modules/iconv_std/citrus_iconv_std.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libiconv_modules/iconv_std/citrus_iconv_std.c Thu Apr 16 03:39:33 2015 (r281585) @@ -104,7 +104,7 @@ init_encoding_state(struct _citrus_iconv static __inline int mbtocsx(struct _citrus_iconv_std_encoding *se, - _csid_t *csid, _index_t *idx, const char **s, size_t n, size_t *nresult, + _csid_t *csid, _index_t *idx, char **s, size_t n, size_t *nresult, struct iconv_hooks *hooks) { @@ -461,7 +461,7 @@ _citrus_iconv_std_iconv_uninit_context(s static int _citrus_iconv_std_iconv_convert(struct _citrus_iconv * __restrict cv, - const char * __restrict * __restrict in, size_t * __restrict inbytes, + char * __restrict * __restrict in, size_t * __restrict inbytes, char * __restrict * __restrict out, size_t * __restrict outbytes, uint32_t flags, size_t * __restrict invalids) { @@ -469,7 +469,7 @@ _citrus_iconv_std_iconv_convert(struct _ struct _citrus_iconv_std_context *sc = cv->cv_closure; _csid_t csid; _index_t idx; - const char *tmpin; + char *tmpin; size_t inval, szrin, szrout; int ret, state = 0; Modified: user/ngie/more-tests/lib/libkiconv/xlat16_iconv.c ============================================================================== --- user/ngie/more-tests/lib/libkiconv/xlat16_iconv.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/lib/libkiconv/xlat16_iconv.c Thu Apr 16 03:39:33 2015 (r281585) @@ -62,7 +62,7 @@ static int chklocale(int, const char *); typedef void *iconv_t; static int my_iconv_init(void); static iconv_t (*my_iconv_open)(const char *, const char *); -static size_t (*my_iconv)(iconv_t, const char **, size_t *, char **, size_t *); +static size_t (*my_iconv)(iconv_t, char **, size_t *, char **, size_t *); static int (*my_iconv_close)(iconv_t); #else #include @@ -71,7 +71,7 @@ static int (*my_iconv_close)(iconv_t); #define my_iconv iconv #define my_iconv_close iconv_close #endif -static size_t my_iconv_char(iconv_t, const u_char **, size_t *, u_char **, size_t *); +static size_t my_iconv_char(iconv_t, u_char **, size_t *, u_char **, size_t *); int kiconv_add_xlat16_cspair(const char *tocode, const char *fromcode, int flag) @@ -221,8 +221,8 @@ kiconv_xlat16_open(const char *tocode, c src[0] = (u_char)(c >> 8); src[1] = (u_char)c; - ret = my_iconv_char(cd, (const u_char **)&srcp, - &inbytesleft, &dstp, &outbytesleft); + ret = my_iconv_char(cd, &srcp, &inbytesleft, + &dstp, &outbytesleft); if (ret == -1) { table[us] = 0; continue; @@ -338,11 +338,10 @@ my_iconv_init(void) #endif static size_t -my_iconv_char(iconv_t cd, const u_char **ibuf, size_t * ilen, u_char **obuf, +my_iconv_char(iconv_t cd, u_char **ibuf, size_t * ilen, u_char **obuf, size_t * olen) { - const u_char *sp; - u_char *dp, ilocal[3], olocal[3]; + u_char *sp, *dp, ilocal[3], olocal[3]; u_char c1, c2; int ret; size_t ir, or; @@ -352,7 +351,7 @@ my_iconv_char(iconv_t cd, const u_char * ir = *ilen; bzero(*obuf, *olen); - ret = my_iconv(cd, (const char **)&sp, ilen, (char **)&dp, olen); + ret = my_iconv(cd, (char **)&sp, ilen, (char **)&dp, olen); c1 = (*obuf)[0]; c2 = (*obuf)[1]; @@ -375,7 +374,7 @@ my_iconv_char(iconv_t cd, const u_char * sp = ilocal; dp = olocal; - if ((my_iconv(cd,(const char **)&sp, &ir, (char **)&dp, &or)) != -1) { + if ((my_iconv(cd,(char **)&sp, &ir, (char **)&dp, &or)) != -1) { if (olocal[0] != c1) return (ret); @@ -429,7 +428,7 @@ my_iconv_char(iconv_t cd, const u_char * sp = ilocal + 1; dp = olocal; - if ((my_iconv(cd,(const char **)&sp, &ir, (char **)&dp, &or)) != -1) { + if ((my_iconv(cd,(char **)&sp, &ir, (char **)&dp, &or)) != -1) { if (olocal[0] == c2) /* * inbuf is a single byte char Modified: user/ngie/more-tests/libexec/rtld-elf/aarch64/reloc.c ============================================================================== --- user/ngie/more-tests/libexec/rtld-elf/aarch64/reloc.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/libexec/rtld-elf/aarch64/reloc.c Thu Apr 16 03:39:33 2015 (r281585) @@ -161,7 +161,7 @@ rtld_tlsdesc_handle_locked(struct tls_da if (def == NULL) rtld_die(); - tlsdesc->index = defobj->tlsindex + def->st_value + rela->r_addend; + tlsdesc->index = defobj->tlsoffset + def->st_value + rela->r_addend; return (tlsdesc->index); } @@ -206,7 +206,7 @@ reloc_plt(Obj_Entry *obj) case R_AARCH64_TLSDESC: if (ELF_R_SYM(rela->r_info) == 0) { where[0] = (Elf_Addr)_rtld_tlsdesc; - where[1] = obj->tlsindex + rela->r_addend; + where[1] = obj->tlsoffset + rela->r_addend; } else { where[0] = (Elf_Addr)_rtld_tlsdesc_dynamic; where[1] = (Elf_Addr)reloc_tlsdesc_alloc(obj, Modified: user/ngie/more-tests/libexec/rtld-elf/rtld.c ============================================================================== --- user/ngie/more-tests/libexec/rtld-elf/rtld.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/libexec/rtld-elf/rtld.c Thu Apr 16 03:39:33 2015 (r281585) @@ -1158,8 +1158,8 @@ digest_dynamic1(Obj_Entry *obj, int earl obj->z_noopen = true; if ((dynp->d_un.d_val & DF_1_ORIGIN) && trust) obj->z_origin = true; - /*if (dynp->d_un.d_val & DF_1_GLOBAL) - XXX ;*/ + if (dynp->d_un.d_val & DF_1_GLOBAL) + obj->z_global = true; if (dynp->d_un.d_val & DF_1_BIND_NOW) obj->bind_now = true; if (dynp->d_un.d_val & DF_1_NODELETE) @@ -1790,22 +1790,35 @@ init_dag(Obj_Entry *root) } static void -process_nodelete(Obj_Entry *root) +process_z(Obj_Entry *root) { const Objlist_Entry *elm; + Obj_Entry *obj; /* - * Walk over object DAG and process every dependent object that - * is marked as DF_1_NODELETE. They need to grow their own DAG, - * which then should have its reference upped separately. + * Walk over object DAG and process every dependent object + * that is marked as DF_1_NODELETE or DF_1_GLOBAL. They need + * to grow their own DAG. + * + * For DF_1_GLOBAL, DAG is required for symbol lookups in + * symlook_global() to work. + * + * For DF_1_NODELETE, the DAG should have its reference upped. */ STAILQ_FOREACH(elm, &root->dagmembers, link) { - if (elm->obj != NULL && elm->obj->z_nodelete && - !elm->obj->ref_nodel) { - dbg("obj %s nodelete", elm->obj->path); - init_dag(elm->obj); - ref_dag(elm->obj); - elm->obj->ref_nodel = true; + obj = elm->obj; + if (obj == NULL) + continue; + if (obj->z_nodelete && !obj->ref_nodel) { + dbg("obj %s -z nodelete", obj->path); + init_dag(obj); + ref_dag(obj); + obj->ref_nodel = true; + } + if (obj->z_global && objlist_find(&list_global, obj) == NULL) { + dbg("obj %s -z global", obj->path); + objlist_push_tail(&list_global, obj); + init_dag(obj); } } } @@ -3044,13 +3057,13 @@ dlopen_object(const char *name, int fd, initlist_add_objects(obj, &obj->next, &initlist); } /* - * Process all no_delete objects here, given them own - * DAGs to prevent their dependencies from being unloaded. - * This has to be done after we have loaded all of the - * dependencies, so that we do not miss any. + * Process all no_delete or global objects here, given + * them own DAGs to prevent their dependencies from being + * unloaded. This has to be done after we have loaded all + * of the dependencies, so that we do not miss any. */ if (obj != NULL) - process_nodelete(obj); + process_z(obj); } else { /* * Bump the reference counts for objects on this DAG. If Modified: user/ngie/more-tests/libexec/rtld-elf/rtld.h ============================================================================== --- user/ngie/more-tests/libexec/rtld-elf/rtld.h Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/libexec/rtld-elf/rtld.h Thu Apr 16 03:39:33 2015 (r281585) @@ -264,6 +264,7 @@ typedef struct Struct_Obj_Entry { bool z_loadfltr : 1; /* Immediately load filtees */ bool z_interpose : 1; /* Interpose all objects but main */ bool z_nodeflib : 1; /* Don't search default library path */ + bool z_global : 1; /* Make the object global */ bool ref_nodel : 1; /* Refcount increased to prevent dlclose */ bool init_scanned: 1; /* Object is already on init list. */ bool on_fini_list: 1; /* Object is already on fini list. */ Modified: user/ngie/more-tests/sys/arm64/arm64/vfp.c ============================================================================== --- user/ngie/more-tests/sys/arm64/arm64/vfp.c Thu Apr 16 03:35:47 2015 (r281584) +++ user/ngie/more-tests/sys/arm64/arm64/vfp.c Thu Apr 16 03:39:33 2015 (r281585) @@ -88,41 +88,42 @@ vfp_save_state(struct thread *td) uint64_t fpcr, fpsr; uint32_t cpacr; + critical_enter(); /* * Only store the registers if the VFP is enabled, * i.e. return if we are trapping on FP access. */ cpacr = READ_SPECIALREG(cpacr_el1); - if ((cpacr & CPACR_FPEN_MASK) != CPACR_FPEN_TRAP_NONE) - return; - - vfp_state = td->td_pcb->pcb_vfp; - __asm __volatile( - "mrs %0, fpcr \n" - "mrs %1, fpsr \n" - "stp q0, q1, [%2, #16 * 0]\n" - "stp q2, q3, [%2, #16 * 2]\n" - "stp q4, q5, [%2, #16 * 4]\n" - "stp q6, q7, [%2, #16 * 6]\n" - "stp q8, q9, [%2, #16 * 8]\n" - "stp q10, q11, [%2, #16 * 10]\n" - "stp q12, q13, [%2, #16 * 12]\n" - "stp q14, q15, [%2, #16 * 14]\n" - "stp q16, q17, [%2, #16 * 16]\n" - "stp q18, q19, [%2, #16 * 18]\n" - "stp q20, q21, [%2, #16 * 20]\n" - "stp q22, q23, [%2, #16 * 22]\n" - "stp q24, q25, [%2, #16 * 24]\n" - "stp q26, q27, [%2, #16 * 26]\n" - "stp q28, q29, [%2, #16 * 28]\n" - "stp q30, q31, [%2, #16 * 30]\n" - : "=&r"(fpcr), "=&r"(fpsr) : "r"(vfp_state)); + if ((cpacr & CPACR_FPEN_MASK) == CPACR_FPEN_TRAP_NONE) { + vfp_state = td->td_pcb->pcb_vfp; + __asm __volatile( + "mrs %0, fpcr \n" + "mrs %1, fpsr \n" + "stp q0, q1, [%2, #16 * 0]\n" + "stp q2, q3, [%2, #16 * 2]\n" + "stp q4, q5, [%2, #16 * 4]\n" + "stp q6, q7, [%2, #16 * 6]\n" + "stp q8, q9, [%2, #16 * 8]\n" + "stp q10, q11, [%2, #16 * 10]\n" + "stp q12, q13, [%2, #16 * 12]\n" + "stp q14, q15, [%2, #16 * 14]\n" + "stp q16, q17, [%2, #16 * 16]\n" + "stp q18, q19, [%2, #16 * 18]\n" + "stp q20, q21, [%2, #16 * 20]\n" + "stp q22, q23, [%2, #16 * 22]\n" + "stp q24, q25, [%2, #16 * 24]\n" + "stp q26, q27, [%2, #16 * 26]\n" + "stp q28, q29, [%2, #16 * 28]\n" + "stp q30, q31, [%2, #16 * 30]\n" + : "=&r"(fpcr), "=&r"(fpsr) : "r"(vfp_state)); - td->td_pcb->pcb_fpcr = fpcr; - td->td_pcb->pcb_fpsr = fpsr; + td->td_pcb->pcb_fpcr = fpcr; *** DIFF OUTPUT TRUNCATED AT 1000 LINES ***