blob: 4f1f3c4f3e8cd95a00425a0d6755dc19975d5b5c [file] [log] [blame]
/*
* Copyright (c) 2005 Silicon Graphics, Inc.
* All Rights Reserved.
*
* 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.
*
* This program is distributed in the hope that it would 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.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "quota.h"
#include <sys/quota.h>
#ifndef PRJQUOTA
#define PRJQUOTA 2
#endif
static int
xtype_to_qtype(
uint type)
{
switch (type) {
case XFS_USER_QUOTA:
return USRQUOTA;
case XFS_GROUP_QUOTA:
return GRPQUOTA;
case XFS_PROJ_QUOTA:
return PRJQUOTA;
}
return 0;
}
static int
xcommand_to_qcommand(
uint command)
{
switch (command) {
case XFS_QUOTAON:
return Q_XQUOTAON;
case XFS_QUOTAOFF:
return Q_XQUOTAOFF;
case XFS_GETQUOTA:
return Q_XGETQUOTA;
case XFS_GETNEXTQUOTA:
return Q_XGETNEXTQUOTA;
case XFS_SETQLIM:
return Q_XSETQLIM;
case XFS_GETQSTAT:
return Q_XGETQSTAT;
case XFS_GETQSTATV:
return Q_XGETQSTATV;
case XFS_QUOTARM:
return Q_XQUOTARM;
case XFS_QSYNC:
return Q_XQUOTASYNC;
}
return 0;
}
int
xfsquotactl(
int command,
const char *device,
uint type,
uint id,
void *addr)
{
int qcommand, qtype;
qtype = xtype_to_qtype(type);
qcommand = xcommand_to_qcommand(command);
return quotactl(QCMD(qcommand, qtype), device, id, addr);
}