From patchwork Wed May 30 14:58:58 2012 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "jeff.liu" X-Patchwork-Id: 161994 Return-Path: X-Original-To: patchwork-incoming@ozlabs.org Delivered-To: patchwork-incoming@ozlabs.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 98564B6FC5 for ; Thu, 31 May 2012 01:06:05 +1000 (EST) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751533Ab2E3PF4 (ORCPT ); Wed, 30 May 2012 11:05:56 -0400 Received: from rcsinet15.oracle.com ([148.87.113.117]:39839 "EHLO rcsinet15.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754177Ab2E3PFj (ORCPT ); Wed, 30 May 2012 11:05:39 -0400 Received: from acsinet22.oracle.com (acsinet22.oracle.com [141.146.126.238]) by rcsinet15.oracle.com (Sentrion-MTA-4.2.2/Sentrion-MTA-4.2.2) with ESMTP id q4UF4kMD030038 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK); Wed, 30 May 2012 15:04:47 GMT Received: from acsmt357.oracle.com (acsmt357.oracle.com [141.146.40.157]) by acsinet22.oracle.com (8.14.4+Sun/8.14.4) with ESMTP id q4UF4ktZ013771 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=NO); Wed, 30 May 2012 15:04:46 GMT Received: from abhmt105.oracle.com (abhmt105.oracle.com [141.146.116.57]) by acsmt357.oracle.com (8.12.11.20060308/8.12.11) with ESMTP id q4UF4jRc013459; Wed, 30 May 2012 10:04:45 -0500 Received: from localhost.localdomain (/123.119.107.100) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Wed, 30 May 2012 08:04:45 -0700 From: jeff.liu@oracle.com To: containers@lists.linux-foundation.org Cc: cgroups@vger.kernel.org, jack@suse.cz, glommer@parallels.com, daniel.lezcano@free.fr, tytso@mit.edu, bpm@sgi.com, chris.mason@oracle.com, hch@infradead.org, christopher.jones@oracle.com, david@fromorbit.com, tinguely@sgi.com, tm@tao.ma, linux-ext4@vger.kernel.org, linux-fsdevel@vger.kernel.org, Jie Liu Subject: [PATCH 04/12] container quota: introduce container disk quota data header file. Date: Wed, 30 May 2012 22:58:58 +0800 Message-Id: <1338389946-13711-5-git-send-email-jeff.liu@oracle.com> X-Mailer: git-send-email 1.7.9 In-Reply-To: <1338389946-13711-1-git-send-email-jeff.liu@oracle.com> References: <1338389946-13711-1-git-send-email-jeff.liu@oracle.com> X-Source-IP: acsinet22.oracle.com [141.146.126.238] Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org Header file for container disk quota. Signed-off-by: Jie Liu --- fs/ns_quota.h | 84 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 84 insertions(+), 0 deletions(-) create mode 100644 fs/ns_quota.h diff --git a/fs/ns_quota.h b/fs/ns_quota.h new file mode 100644 index 0000000..cf90fff --- /dev/null +++ b/fs/ns_quota.h @@ -0,0 +1,84 @@ +#ifndef _LINUX_NS_QUOTA_ +#define _LINUX_NS_QUOTA_ + +#include +#include +#include +#include +#include +#include +#include +#include + +#define NS_MAX_IQ_TIME 604800 /* (7*24*60*60) 1 week */ +#define NS_MAX_DQ_TIME 604800 /* (7*24*60*60) 1 week */ + +/* + * Below most stuff were copied from kernel/user.c, using them + * to calculate and define quota hash table and hash routine. + */ +#define NS_DQHASH_BITS (CONFIG_BASE_SMALL ? 3 : 7) +#define NS_DQHASH_SZ (1 << NS_DQHASH_BITS) + +struct ns_mem_dqinfo { + unsigned long dqi_flags; + unsigned int dqi_bgrace; + unsigned int dqi_igrace; + qsize_t dqi_maxblimit; + qsize_t dqi_maxilimit; +}; + +/* Mount namespace disk quota definitation */ +struct ns_quota_info { + /* Flags for disk quotas on this mount namespace */ + unsigned int dq_flags; + /* Serialize mount namespace quotaon & quotaoff */ + struct mutex dqonoff_mutex; + /* Serialize user/group quota list operations */ + spinlock_t dq_list_lock; + /* Serialize quota value incr/decr operations */ + spinlock_t dq_data_lock; + struct kmem_cache *dquot_cachep; + /* Hash list of all user disk quotas */ + struct hlist_head u_dquots[NS_DQHASH_SZ]; + /* Hash list of all group disk quotas */ + struct hlist_head g_dquots[NS_DQHASH_SZ]; + /* Information for each quota type */ + struct ns_mem_dqinfo dqinfo[MAXQUOTAS]; +}; + +/* Mount namespace disk quota object */ +struct ns_dquot { + struct hlist_node dq_hash_node; /* Hash list in memory */ + struct mnt_namespace *dq_ns; /* Mount namespace this applies to */ + unsigned int dq_id; /* ID this applies to (uid, gid) */ + unsigned long dq_flags; /* See DQ_* */ + short dq_type; /* Type of quota */ + struct mem_dqblk dq_dqb; /* Diskquota usage */ +}; + +/* Operations for quota object allocation/destroy */ +struct ns_dquot_ops { + /* Allocate memory for new dqout object */ + struct ns_dquot *(*alloc_dquot)(struct mnt_namespace *); + /* Free memory for dquot */ + void (*destroy_dquot)(struct ns_dquot *); +}; + +/* Operations for quota control */ +struct ns_quotactl_ops { + int (*quota_on)(struct mnt_namespace *, int); + int (*quota_off)(struct mnt_namespace *, int); + int (*get_info)(struct mnt_namespace *, int, struct if_dqinfo *); + int (*set_info)(struct mnt_namespace *, int, struct if_dqinfo *); + int (*get_dqblk)(struct mnt_namespace *, int, qid_t, + struct fs_disk_quota *); + int (*set_dqblk)(struct mnt_namespace *, int, qid_t, + struct fs_disk_quota *); +}; + +int ns_dqinfo_init(struct mnt_namespace *ns); +void ns_dqinfo_destroy(struct mnt_namespace *ns); +extern unsigned int ns_dquot_getfmt(struct mnt_namespace *ns, int type); + +#endif /* _LINUX_NS_QUOTA_ */