Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Make rump_smbfs(8) uses host iconv(3) to convert filenames
details: https://anonhg.NetBSD.org/src/rev/b7c30a0a3b62
branches: trunk
changeset: 333745:b7c30a0a3b62
user: nakayama <nakayama%NetBSD.org@localhost>
date: Sat Nov 15 18:49:04 2014 +0000
description:
Make rump_smbfs(8) uses host iconv(3) to convert filenames
character set.
diffstat:
sys/netsmb/iconv.c | 34 +++++++++---
sys/rump/dev/lib/libnetsmb/Makefile | 5 +-
sys/rump/dev/lib/libnetsmb/netsmb_iconv.c | 79 ++++++++++++++++++++++++++++++
sys/rump/dev/lib/libnetsmb/netsmb_user.c | 81 +++++++++++++++++++++++++++++++
sys/rump/dev/lib/libnetsmb/netsmb_user.h | 31 +++++++++++
5 files changed, 219 insertions(+), 11 deletions(-)
diffs (truncated from 305 to 300 lines):
diff -r d2af20b2779f -r b7c30a0a3b62 sys/netsmb/iconv.c
--- a/sys/netsmb/iconv.c Sat Nov 15 17:49:19 2014 +0000
+++ b/sys/netsmb/iconv.c Sat Nov 15 18:49:04 2014 +0000
@@ -1,41 +1,48 @@
-/* $NetBSD: iconv.c,v 1.13 2014/02/20 11:08:57 joerg Exp $ */
+/* $NetBSD: iconv.c,v 1.14 2014/11/15 18:49:04 nakayama Exp $ */
/* Public domain */
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: iconv.c,v 1.13 2014/02/20 11:08:57 joerg Exp $");
+__KERNEL_RCSID(0, "$NetBSD: iconv.c,v 1.14 2014/11/15 18:49:04 nakayama Exp $");
#include <sys/param.h>
#include <sys/kernel.h>
#include <sys/systm.h>
#include <sys/errno.h>
-#include <sys/malloc.h>
#include <netsmb/iconv.h>
+/* stubs for iconv functions */
+int iconv_open_stub(const char *, const char *, void **);
+int iconv_close_stub(void *);
+int iconv_conv_stub(void *, const char **, size_t *, char **, size_t *);
+__weak_alias(iconv_open, iconv_open_stub);
+__weak_alias(iconv_close, iconv_close_stub);
+__weak_alias(iconv_conv, iconv_conv_stub);
+
int
-iconv_open(const char *to, const char *from,
+iconv_open_stub(const char *to, const char *from,
void **handle)
{
return 0;
}
int
-iconv_close(void *handle)
+iconv_close_stub(void *handle)
{
return 0;
}
int
-iconv_conv(void *handle, const char **inbuf,
+iconv_conv_stub(void *handle, const char **inbuf,
size_t *inbytesleft, char **outbuf, size_t *outbytesleft)
{
+ if (inbuf == NULL)
+ return(0); /* initial shift state */
+
if (*inbytesleft > *outbytesleft)
return(E2BIG);
- if (inbuf == NULL)
- return(0); /* initial shift state */
-
(void)memcpy(*outbuf, *inbuf, *inbytesleft);
*outbytesleft -= *inbytesleft;
@@ -59,7 +66,11 @@
strlcpy(dst, src, l);
return dst;
}
- inlen = outlen = strlen(src);
+ inlen = strlen(src);
+ outlen = l - 1;
+ error = iconv_conv(handle, NULL, NULL, &p, &outlen);
+ if (error)
+ return NULL;
error = iconv_conv(handle, &src, &inlen, &p, &outlen);
if (error)
return NULL;
@@ -82,6 +93,9 @@
return dst;
}
inlen = outlen = size;
+ error = iconv_conv(handle, NULL, NULL, &d, &outlen);
+ if (error)
+ return NULL;
error = iconv_conv(handle, &s, &inlen, &d, &outlen);
if (error)
return NULL;
diff -r d2af20b2779f -r b7c30a0a3b62 sys/rump/dev/lib/libnetsmb/Makefile
--- a/sys/rump/dev/lib/libnetsmb/Makefile Sat Nov 15 17:49:19 2014 +0000
+++ b/sys/rump/dev/lib/libnetsmb/Makefile Sat Nov 15 18:49:04 2014 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.4 2014/03/13 01:57:29 pooka Exp $
+# $NetBSD: Makefile,v 1.5 2014/11/15 18:49:04 nakayama Exp $
#
.PATH: ${.CURDIR}/../../../../netsmb
@@ -13,5 +13,8 @@
CPPFLAGS+= -I${RUMPTOP}/librump/rumpvfs
#CPPFLAGS+= -DSMB_SOCKET_DEBUG -DSMB_IOD_DEBUG
+SRCS+= netsmb_iconv.c
+RUMPCOMP_USER_SRCS= netsmb_user.c
+
.include <bsd.lib.mk>
.include <bsd.klinks.mk>
diff -r d2af20b2779f -r b7c30a0a3b62 sys/rump/dev/lib/libnetsmb/netsmb_iconv.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/rump/dev/lib/libnetsmb/netsmb_iconv.c Sat Nov 15 18:49:04 2014 +0000
@@ -0,0 +1,79 @@
+/* $NetBSD: netsmb_iconv.c,v 1.1 2014/11/15 18:49:04 nakayama Exp $ */
+
+/*
+ * Copyright (c) 2014 Takeshi Nakayama.
+ * 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.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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 <sys/cdefs.h>
+__KERNEL_RCSID(0, "$NetBSD: netsmb_iconv.c,v 1.1 2014/11/15 18:49:04 nakayama Exp $");
+
+#include <sys/param.h>
+#include <sys/kernel.h>
+#include <sys/systm.h>
+#include <sys/errno.h>
+
+#include <netsmb/iconv.h>
+
+#include "netsmb_user.h"
+
+int
+iconv_open(const char *to, const char *from, void **handle)
+{
+ if (strcmp(to, "tolower") && strcmp(to, "toupper"))
+ return rumpcomp_netsmb_iconv_open(to, from, handle);
+ return 0;
+}
+
+int
+iconv_close(void *handle)
+{
+ if (handle != NULL)
+ return rumpcomp_netsmb_iconv_close(handle);
+ return 0;
+}
+
+int
+iconv_conv(void *handle, const char **inbuf, size_t *inbytesleft,
+ char **outbuf, size_t *outbytesleft)
+{
+ size_t len;
+
+ if (handle != NULL)
+ return rumpcomp_netsmb_iconv_conv(handle, inbuf, inbytesleft,
+ outbuf, outbytesleft);
+
+ if (inbuf == NULL)
+ return 0;
+
+ if (*inbytesleft > *outbytesleft)
+ return E2BIG;
+
+ len = *inbytesleft;
+ memcpy(*outbuf, *inbuf, len);
+ *inbuf += len;
+ *inbytesleft = 0;
+ *outbuf += len;
+ *outbytesleft -= len;
+ return 0;
+}
diff -r d2af20b2779f -r b7c30a0a3b62 sys/rump/dev/lib/libnetsmb/netsmb_user.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/rump/dev/lib/libnetsmb/netsmb_user.c Sat Nov 15 18:49:04 2014 +0000
@@ -0,0 +1,81 @@
+/* $NetBSD: netsmb_user.c,v 1.1 2014/11/15 18:49:04 nakayama Exp $ */
+
+/*
+ * Copyright (c) 2014 Takeshi Nakayama.
+ * 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.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
+ */
+#ifndef _KERNEL
+#include <stddef.h>
+#include <iconv.h>
+#include <errno.h>
+
+#include <rump/rumpuser_component.h>
+
+#include "netsmb_user.h"
+
+int
+rumpcomp_netsmb_iconv_open(const char *to, const char *from, void **handle)
+{
+ iconv_t cd;
+ int rv;
+
+ cd = iconv_open(to, from);
+ if (cd == (iconv_t)-1)
+ rv = errno;
+ else {
+ if (handle != NULL)
+ *handle = (void *)cd;
+ rv = 0;
+ }
+
+ return rumpuser_component_errtrans(rv);
+}
+
+int
+rumpcomp_netsmb_iconv_close(void *handle)
+{
+ int rv;
+
+ if (iconv_close((iconv_t)handle) == -1)
+ rv = errno;
+ else
+ rv = 0;
+
+ return rumpuser_component_errtrans(rv);
+}
+
+int
+rumpcomp_netsmb_iconv_conv(void *handle, const char **inbuf,
+ size_t *inbytesleft, char **outbuf, size_t *outbytesleft)
+{
+ int rv;
+
+ if (iconv((iconv_t)handle, inbuf, inbytesleft, outbuf, outbytesleft)
+ == (size_t)-1)
+ rv = errno;
+ else
+ rv = 0;
+
+ return rumpuser_component_errtrans(rv);
+}
+#endif
diff -r d2af20b2779f -r b7c30a0a3b62 sys/rump/dev/lib/libnetsmb/netsmb_user.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/rump/dev/lib/libnetsmb/netsmb_user.h Sat Nov 15 18:49:04 2014 +0000
@@ -0,0 +1,31 @@
+/* $NetBSD: netsmb_user.h,v 1.1 2014/11/15 18:49:04 nakayama Exp $ */
+
+/*
+ * Copyright (c) 2014 Takeshi Nakayama.
+ * 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.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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 AUTHOR 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.
+ */
Home |
Main Index |
Thread Index |
Old Index