Revert the following changes:
src/sys/sys/quotactl.h 1.37
src/sys/compat/netbsd32/netbsd32.h 1.101
src/sys/compat/netbsd32/netbsd32_netbsd.c 1.188, 1.189
src/sys/kern/vfs_quotactl.c 1.39
src/sys/kern/vfs_syscalls.c 1.483
src/sys/ufs/lfs/ulfs_quota.c 1.11
src/sys/ufs/ufs/ufs_quota.c 1.116
src/lib/libquota/quota_kernel.c 1.5
and do them correctly.
If you're going to change the name of something, you need to change
the name of *all* the things with the same name, not just a handful,
and you should change it to something similar so it still matches the
rest of the system rather than just picking an arbitrarily different
name.
Hi, Joerg.
To wit, rename the quotactl "delete" operation to "del", because
"delete" is a reserved word in C++ and for some reason Joerg wants to
run internal interfaces used only by C code through his C++ compiler.
Do not rename it to "remove" instead, because this doesn't match
libquota or the rest of the usage throughout the system; and rename
all the related identifiers, not just the ones that blew the mind of
Joerg's C++ compiler.
Because this is not a user-facing API (the only userland consumer
sys/quotactl.h is libquota) it is sort of ok to make arbitrary
source-incompatible changes; however, by the same token it's completely
unnecessary. If it *were* a user-facing API that someone might have a
semi-rational reason to want to run a C++ compiler on, it would be
incorrect to change it at this point.
2014-06-29 02:27:50 +04:00
|
|
|
/* $NetBSD: vfs_quotactl.c,v 1.40 2014/06/28 22:27:50 dholland Exp $ */
|
2012-02-01 09:34:38 +04:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 2012 The NetBSD Foundation, Inc.
|
|
|
|
* All rights reserved.
|
2012-01-29 10:26:54 +04:00
|
|
|
*
|
2012-02-01 09:34:38 +04:00
|
|
|
* This code is derived from software contributed to The NetBSD Foundation
|
|
|
|
* by David A. Holland.
|
2012-01-29 10:26:54 +04:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*
|
2012-02-01 09:34:38 +04:00
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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.
|
2012-01-29 10:26:54 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <sys/cdefs.h>
|
Revert the following changes:
src/sys/sys/quotactl.h 1.37
src/sys/compat/netbsd32/netbsd32.h 1.101
src/sys/compat/netbsd32/netbsd32_netbsd.c 1.188, 1.189
src/sys/kern/vfs_quotactl.c 1.39
src/sys/kern/vfs_syscalls.c 1.483
src/sys/ufs/lfs/ulfs_quota.c 1.11
src/sys/ufs/ufs/ufs_quota.c 1.116
src/lib/libquota/quota_kernel.c 1.5
and do them correctly.
If you're going to change the name of something, you need to change
the name of *all* the things with the same name, not just a handful,
and you should change it to something similar so it still matches the
rest of the system rather than just picking an arbitrarily different
name.
Hi, Joerg.
To wit, rename the quotactl "delete" operation to "del", because
"delete" is a reserved word in C++ and for some reason Joerg wants to
run internal interfaces used only by C code through his C++ compiler.
Do not rename it to "remove" instead, because this doesn't match
libquota or the rest of the usage throughout the system; and rename
all the related identifiers, not just the ones that blew the mind of
Joerg's C++ compiler.
Because this is not a user-facing API (the only userland consumer
sys/quotactl.h is libquota) it is sort of ok to make arbitrary
source-incompatible changes; however, by the same token it's completely
unnecessary. If it *were* a user-facing API that someone might have a
semi-rational reason to want to run a C++ compiler on, it would be
incorrect to change it at this point.
2014-06-29 02:27:50 +04:00
|
|
|
__KERNEL_RCSID(0, "$NetBSD: vfs_quotactl.c,v 1.40 2014/06/28 22:27:50 dholland Exp $$");
|
2012-01-29 10:26:54 +04:00
|
|
|
|
2012-01-29 10:29:04 +04:00
|
|
|
#include <sys/mount.h>
|
2012-01-29 10:34:57 +04:00
|
|
|
#include <sys/quotactl.h>
|
2012-01-29 10:29:04 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_stat(struct mount *mp, struct quotastat *info)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:36:50 +04:00
|
|
|
|
2012-01-29 11:13:42 +04:00
|
|
|
args.qc_op = QUOTACTL_STAT;
|
2012-02-01 09:43:53 +04:00
|
|
|
args.u.stat.qc_info = info;
|
2012-02-01 09:34:38 +04:00
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_idtypestat(struct mount *mp, int idtype,
|
|
|
|
struct quotaidtypestat *info)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 11:11:12 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_IDTYPESTAT;
|
|
|
|
args.u.idtypestat.qc_idtype = idtype;
|
|
|
|
args.u.idtypestat.qc_info = info;
|
2012-01-29 11:14:38 +04:00
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_objtypestat(struct mount *mp, int objtype,
|
|
|
|
struct quotaobjtypestat *info)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 11:11:55 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_OBJTYPESTAT;
|
|
|
|
args.u.objtypestat.qc_objtype = objtype;
|
|
|
|
args.u.objtypestat.qc_info = info;
|
2012-01-29 11:14:38 +04:00
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_get(struct mount *mp, const struct quotakey *key,
|
|
|
|
struct quotaval *val)
|
2012-01-29 10:39:36 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:41:41 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_GET;
|
|
|
|
args.u.get.qc_key = key;
|
2012-02-01 09:43:53 +04:00
|
|
|
args.u.get.qc_val = val;
|
2012-02-01 09:34:38 +04:00
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:39:36 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_put(struct mount *mp, const struct quotakey *key,
|
|
|
|
const struct quotaval *val)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:37:30 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_PUT;
|
|
|
|
args.u.put.qc_key = key;
|
|
|
|
args.u.put.qc_val = val;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
Revert the following changes:
src/sys/sys/quotactl.h 1.37
src/sys/compat/netbsd32/netbsd32.h 1.101
src/sys/compat/netbsd32/netbsd32_netbsd.c 1.188, 1.189
src/sys/kern/vfs_quotactl.c 1.39
src/sys/kern/vfs_syscalls.c 1.483
src/sys/ufs/lfs/ulfs_quota.c 1.11
src/sys/ufs/ufs/ufs_quota.c 1.116
src/lib/libquota/quota_kernel.c 1.5
and do them correctly.
If you're going to change the name of something, you need to change
the name of *all* the things with the same name, not just a handful,
and you should change it to something similar so it still matches the
rest of the system rather than just picking an arbitrarily different
name.
Hi, Joerg.
To wit, rename the quotactl "delete" operation to "del", because
"delete" is a reserved word in C++ and for some reason Joerg wants to
run internal interfaces used only by C code through his C++ compiler.
Do not rename it to "remove" instead, because this doesn't match
libquota or the rest of the usage throughout the system; and rename
all the related identifiers, not just the ones that blew the mind of
Joerg's C++ compiler.
Because this is not a user-facing API (the only userland consumer
sys/quotactl.h is libquota) it is sort of ok to make arbitrary
source-incompatible changes; however, by the same token it's completely
unnecessary. If it *were* a user-facing API that someone might have a
semi-rational reason to want to run a C++ compiler on, it would be
incorrect to change it at this point.
2014-06-29 02:27:50 +04:00
|
|
|
vfs_quotactl_del(struct mount *mp, const struct quotakey *key)
|
2012-01-29 10:45:25 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:45:25 +04:00
|
|
|
|
Revert the following changes:
src/sys/sys/quotactl.h 1.37
src/sys/compat/netbsd32/netbsd32.h 1.101
src/sys/compat/netbsd32/netbsd32_netbsd.c 1.188, 1.189
src/sys/kern/vfs_quotactl.c 1.39
src/sys/kern/vfs_syscalls.c 1.483
src/sys/ufs/lfs/ulfs_quota.c 1.11
src/sys/ufs/ufs/ufs_quota.c 1.116
src/lib/libquota/quota_kernel.c 1.5
and do them correctly.
If you're going to change the name of something, you need to change
the name of *all* the things with the same name, not just a handful,
and you should change it to something similar so it still matches the
rest of the system rather than just picking an arbitrarily different
name.
Hi, Joerg.
To wit, rename the quotactl "delete" operation to "del", because
"delete" is a reserved word in C++ and for some reason Joerg wants to
run internal interfaces used only by C code through his C++ compiler.
Do not rename it to "remove" instead, because this doesn't match
libquota or the rest of the usage throughout the system; and rename
all the related identifiers, not just the ones that blew the mind of
Joerg's C++ compiler.
Because this is not a user-facing API (the only userland consumer
sys/quotactl.h is libquota) it is sort of ok to make arbitrary
source-incompatible changes; however, by the same token it's completely
unnecessary. If it *were* a user-facing API that someone might have a
semi-rational reason to want to run a C++ compiler on, it would be
incorrect to change it at this point.
2014-06-29 02:27:50 +04:00
|
|
|
args.qc_op = QUOTACTL_DEL;
|
|
|
|
args.u.del.qc_key = key;
|
2012-02-01 09:34:38 +04:00
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:45:25 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursoropen(struct mount *mp, struct quotakcursor *cursor)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:47:38 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_CURSOROPEN;
|
|
|
|
args.u.cursoropen.qc_cursor = cursor;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursorclose(struct mount *mp, struct quotakcursor *cursor)
|
2012-01-29 11:06:37 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 11:06:37 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_CURSORCLOSE;
|
|
|
|
args.u.cursorclose.qc_cursor = cursor;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 11:06:37 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursorskipidtype(struct mount *mp, struct quotakcursor *cursor,
|
|
|
|
int idtype)
|
2012-01-29 11:02:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 11:02:06 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_CURSORSKIPIDTYPE;
|
|
|
|
args.u.cursorskipidtype.qc_cursor = cursor;
|
|
|
|
args.u.cursorskipidtype.qc_idtype = idtype;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 11:02:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursorget(struct mount *mp, struct quotakcursor *cursor,
|
|
|
|
struct quotakey *keys, struct quotaval *vals, unsigned maxnum,
|
|
|
|
unsigned *ret)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
|
|
|
|
|
|
|
args.qc_op = QUOTACTL_CURSORGET;
|
|
|
|
args.u.cursorget.qc_cursor = cursor;
|
|
|
|
args.u.cursorget.qc_keys = keys;
|
|
|
|
args.u.cursorget.qc_vals = vals;
|
|
|
|
args.u.cursorget.qc_maxnum = maxnum;
|
|
|
|
args.u.cursorget.qc_ret = ret;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursoratend(struct mount *mp, struct quotakcursor *cursor,
|
|
|
|
int *ret)
|
2012-01-29 10:36:06 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:55:44 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_CURSORATEND;
|
|
|
|
args.u.cursoratend.qc_cursor = cursor;
|
|
|
|
args.u.cursoratend.qc_ret = ret;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:36:06 +04:00
|
|
|
}
|
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_cursorrewind(struct mount *mp, struct quotakcursor *cursor)
|
2012-01-29 10:34:57 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:34:57 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_CURSORREWIND;
|
|
|
|
args.u.cursorrewind.qc_cursor = cursor;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:34:57 +04:00
|
|
|
}
|
|
|
|
|
2012-01-29 10:29:04 +04:00
|
|
|
int
|
2012-02-01 09:34:38 +04:00
|
|
|
vfs_quotactl_quotaon(struct mount *mp, int idtype, const char *path)
|
2012-01-29 10:29:04 +04:00
|
|
|
{
|
2012-02-01 09:34:38 +04:00
|
|
|
struct quotactl_args args;
|
2012-01-29 10:32:43 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_QUOTAON;
|
|
|
|
args.u.quotaon.qc_idtype = idtype;
|
|
|
|
args.u.quotaon.qc_quotafile = path;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
|
|
|
}
|
2012-01-29 10:32:43 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
int
|
|
|
|
vfs_quotactl_quotaoff(struct mount *mp, int idtype)
|
|
|
|
{
|
|
|
|
struct quotactl_args args;
|
2012-01-29 10:32:43 +04:00
|
|
|
|
2012-02-01 09:34:38 +04:00
|
|
|
args.qc_op = QUOTACTL_QUOTAOFF;
|
|
|
|
args.u.quotaoff.qc_idtype = idtype;
|
|
|
|
return VFS_QUOTACTL(mp, &args);
|
2012-01-29 10:29:04 +04:00
|
|
|
}
|