Linux kernel & device driver programming

Cross-Referenced Linux and Device Driver Code

[ source navigation ] [ diff markup ] [ identifier search ] [ freetext search ] [ file search ]
Version: [ 2.6.11.8 ] [ 2.6.25 ] [ 2.6.25.8 ] [ 2.6.31.13 ] Architecture: [ i386 ]

Diff markup

Differences between /linux/fs/ocfs2/sysfile.c (Version 2.6.25) and /linux/fs/ocfs2/sysfile.c (Version 2.6.31.13)


  1 /* -*- mode: c; c-basic-offset: 8; -*-              1 /* -*- mode: c; c-basic-offset: 8; -*-
  2  * vim: noexpandtab sw=8 ts=8 sts=0:                2  * vim: noexpandtab sw=8 ts=8 sts=0:
  3  *                                                  3  *
  4  * sysfile.c                                        4  * sysfile.c
  5  *                                                  5  *
  6  * Initialize, read, write, etc. system files.      6  * Initialize, read, write, etc. system files.
  7  *                                                  7  *
  8  * Copyright (C) 2002, 2004 Oracle.  All right      8  * Copyright (C) 2002, 2004 Oracle.  All rights reserved.
  9  *                                                  9  *
 10  * This program is free software; you can redi     10  * This program is free software; you can redistribute it and/or
 11  * modify it under the terms of the GNU Genera     11  * modify it under the terms of the GNU General Public
 12  * License as published by the Free Software F     12  * License as published by the Free Software Foundation; either
 13  * version 2 of the License, or (at your optio     13  * version 2 of the License, or (at your option) any later version.
 14  *                                                 14  *
 15  * This program is distributed in the hope tha     15  * This program is distributed in the hope that it will be useful,
 16  * but WITHOUT ANY WARRANTY; without even the      16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR     17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 18  * General Public License for more details.        18  * General Public License for more details.
 19  *                                                 19  *
 20  * You should have received a copy of the GNU      20  * You should have received a copy of the GNU General Public
 21  * License along with this program; if not, wr     21  * License along with this program; if not, write to the
 22  * Free Software Foundation, Inc., 59 Temple P     22  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
 23  * Boston, MA 021110-1307, USA.                    23  * Boston, MA 021110-1307, USA.
 24  */                                                24  */
 25                                                    25 
 26 #include <linux/fs.h>                              26 #include <linux/fs.h>
 27 #include <linux/types.h>                           27 #include <linux/types.h>
 28 #include <linux/slab.h>                            28 #include <linux/slab.h>
 29 #include <linux/highmem.h>                         29 #include <linux/highmem.h>
 30                                                    30 
 31 #define MLOG_MASK_PREFIX ML_INODE                  31 #define MLOG_MASK_PREFIX ML_INODE
 32 #include <cluster/masklog.h>                       32 #include <cluster/masklog.h>
 33                                                    33 
 34 #include "ocfs2.h"                                 34 #include "ocfs2.h"
 35                                                    35 
 36 #include "alloc.h"                                 36 #include "alloc.h"
 37 #include "dir.h"                                   37 #include "dir.h"
 38 #include "inode.h"                                 38 #include "inode.h"
 39 #include "journal.h"                               39 #include "journal.h"
 40 #include "sysfile.h"                               40 #include "sysfile.h"
 41                                                    41 
 42 #include "buffer_head_io.h"                        42 #include "buffer_head_io.h"
 43                                                    43 
 44 static struct inode * _ocfs2_get_system_file_i     44 static struct inode * _ocfs2_get_system_file_inode(struct ocfs2_super *osb,
 45                                                    45                                                    int type,
 46                                                    46                                                    u32 slot);
 47                                                    47 
 48 static inline int is_global_system_inode(int t     48 static inline int is_global_system_inode(int type);
 49 static inline int is_in_system_inode_array(str     49 static inline int is_in_system_inode_array(struct ocfs2_super *osb,
 50                                            int     50                                            int type,
 51                                            u32     51                                            u32 slot);
 52                                                    52 
                                                   >>  53 #ifdef CONFIG_DEBUG_LOCK_ALLOC
                                                   >>  54 static struct lock_class_key ocfs2_sysfile_cluster_lock_key[NUM_SYSTEM_INODES];
                                                   >>  55 #endif
                                                   >>  56 
 53 static inline int is_global_system_inode(int t     57 static inline int is_global_system_inode(int type)
 54 {                                                  58 {
 55         return type >= OCFS2_FIRST_ONLINE_SYST     59         return type >= OCFS2_FIRST_ONLINE_SYSTEM_INODE &&
 56                 type <= OCFS2_LAST_GLOBAL_SYST     60                 type <= OCFS2_LAST_GLOBAL_SYSTEM_INODE;
 57 }                                                  61 }
 58                                                    62 
 59 static inline int is_in_system_inode_array(str     63 static inline int is_in_system_inode_array(struct ocfs2_super *osb,
 60                                            int     64                                            int type,
 61                                            u32     65                                            u32 slot)
 62 {                                                  66 {
 63         return slot == osb->slot_num || is_glo     67         return slot == osb->slot_num || is_global_system_inode(type);
 64 }                                                  68 }
 65                                                    69 
 66 struct inode *ocfs2_get_system_file_inode(stru     70 struct inode *ocfs2_get_system_file_inode(struct ocfs2_super *osb,
 67                                           int      71                                           int type,
 68                                           u32      72                                           u32 slot)
 69 {                                                  73 {
 70         struct inode *inode = NULL;                74         struct inode *inode = NULL;
 71         struct inode **arr = NULL;                 75         struct inode **arr = NULL;
 72                                                    76 
 73         /* avoid the lookup if cached in local     77         /* avoid the lookup if cached in local system file array */
 74         if (is_in_system_inode_array(osb, type     78         if (is_in_system_inode_array(osb, type, slot))
 75                 arr = &(osb->system_inodes[typ     79                 arr = &(osb->system_inodes[type]);
 76                                                    80 
 77         if (arr && ((inode = *arr) != NULL)) {     81         if (arr && ((inode = *arr) != NULL)) {
 78                 /* get a ref in addition to th     82                 /* get a ref in addition to the array ref */
 79                 inode = igrab(inode);              83                 inode = igrab(inode);
 80                 BUG_ON(!inode);                    84                 BUG_ON(!inode);
 81                                                    85 
 82                 return inode;                      86                 return inode;
 83         }                                          87         }
 84                                                    88 
 85         /* this gets one ref thru iget */          89         /* this gets one ref thru iget */
 86         inode = _ocfs2_get_system_file_inode(o     90         inode = _ocfs2_get_system_file_inode(osb, type, slot);
 87                                                    91 
 88         /* add one more if putting into array      92         /* add one more if putting into array for first time */
 89         if (arr && inode) {                        93         if (arr && inode) {
 90                 *arr = igrab(inode);               94                 *arr = igrab(inode);
 91                 BUG_ON(!*arr);                     95                 BUG_ON(!*arr);
 92         }                                          96         }
 93         return inode;                              97         return inode;
 94 }                                                  98 }
 95                                                    99 
 96 static struct inode * _ocfs2_get_system_file_i    100 static struct inode * _ocfs2_get_system_file_inode(struct ocfs2_super *osb,
 97                                                   101                                                    int type,
 98                                                   102                                                    u32 slot)
 99 {                                                 103 {
100         char namebuf[40];                         104         char namebuf[40];
101         struct inode *inode = NULL;               105         struct inode *inode = NULL;
102         u64 blkno;                                106         u64 blkno;
103         int status = 0;                           107         int status = 0;
104                                                   108 
105         ocfs2_sprintf_system_inode_name(namebu    109         ocfs2_sprintf_system_inode_name(namebuf,
106                                         sizeof    110                                         sizeof(namebuf),
107                                         type,     111                                         type, slot);
108                                                   112 
109         status = ocfs2_lookup_ino_from_name(os    113         status = ocfs2_lookup_ino_from_name(osb->sys_root_inode, namebuf,
110                                             st    114                                             strlen(namebuf), &blkno);
111         if (status < 0) {                         115         if (status < 0) {
112                 goto bail;                        116                 goto bail;
113         }                                         117         }
114                                                   118 
115         inode = ocfs2_iget(osb, blkno, OCFS2_F    119         inode = ocfs2_iget(osb, blkno, OCFS2_FI_FLAG_SYSFILE, type);
116         if (IS_ERR(inode)) {                      120         if (IS_ERR(inode)) {
117                 mlog_errno(PTR_ERR(inode));       121                 mlog_errno(PTR_ERR(inode));
118                 inode = NULL;                     122                 inode = NULL;
119                 goto bail;                        123                 goto bail;
120         }                                         124         }
                                                   >> 125 #ifdef CONFIG_DEBUG_LOCK_ALLOC
                                                   >> 126         if (type == LOCAL_USER_QUOTA_SYSTEM_INODE ||
                                                   >> 127             type == LOCAL_GROUP_QUOTA_SYSTEM_INODE ||
                                                   >> 128             type == JOURNAL_SYSTEM_INODE) {
                                                   >> 129                 /* Ignore inode lock on these inodes as the lock does not
                                                   >> 130                  * really belong to any process and lockdep cannot handle
                                                   >> 131                  * that */
                                                   >> 132                 OCFS2_I(inode)->ip_inode_lockres.l_lockdep_map.key = NULL;
                                                   >> 133         } else {
                                                   >> 134                 lockdep_init_map(&OCFS2_I(inode)->ip_inode_lockres.
                                                   >> 135                                                                 l_lockdep_map,
                                                   >> 136                                  ocfs2_system_inodes[type].si_name,
                                                   >> 137                                  &ocfs2_sysfile_cluster_lock_key[type], 0);
                                                   >> 138         }
                                                   >> 139 #endif
121 bail:                                             140 bail:
122                                                   141 
123         return inode;                             142         return inode;
124 }                                                 143 }
125                                                   144 
126                                                   145 
  This page was automatically generated by the LXR engine.