|
|
1.1 root 1: /*
2: * The I node is the focus of all
3: * file activity in unix. There is a unique
4: * inode allocated for each active file,
5: * each current directory, each mounted-on
6: * file, text file, and the root. An inode is 'named'
7: * by its dev/inumber pair. (iget/iget.c)
8: * Data, from mode on, is read in
9: * from permanent inode on volume.
10: */
11:
12: #define NADDR 13
13:
14: struct inode
15: {
16: short i_flag;
17: u_char i_count; /* reference count */
18: char i_fstyp; /* type of its filesystem */
19: dev_t i_dev; /* device where inode resides */
20: long i_number; /* i number, 1-to-1 with device address */
21: unsigned short i_mode;
22: short i_nlink; /* directory entries */
23: short i_uid; /* owner */
24: short i_gid; /* group of owner */
25: off_t i_size; /* size of file */
26: struct inode *i_mroot; /* if mount point, root inode */
27: struct inode *i_mpoint; /* inode of mount point */
28: struct stdata *i_sptr; /* stream associated with this inode */
29: union {
30: struct {
31: daddr_t I_addr[NADDR]; /* if normal file/directory */
32: daddr_t I_lastr; /* last read (for read-ahead) */
33: struct buf *I_bufp; /* buffer for super-block */
34: } i_f;
35: #define i_addr i_f.I_addr
36: #define i_lastr i_f.I_lastr
37: #define i_bufp i_f.I_bufp
38: struct {
39: daddr_t I_rdev; /* i_addr[0] */
40: long I_key; /* see istread */
41: } i_d;
42: #define i_rdev i_d.I_rdev
43: #define i_key i_d.I_key
44: struct {
45: long I_tag;
46: struct inode *I_cip; /* communications */
47: } i_a; /* when i_fstyp != 0 */
48: #define i_tag i_a.I_tag
49: #define i_cip i_a.I_cip
50: struct {
51: struct proc *I_proc; /* sanity checking */
52: int I_sigmask; /* signal trace mask */
53: } i_p;
54: #define i_proc i_p.I_proc
55: #define i_sigmask i_p.I_sigmask
56: } i_un;
57: struct inode *i_hlink; /* link in hash chain (iget/iput/ifind) */
58: };
59:
60: #ifdef KERNEL
61: struct inode *inode, *inodeNINODE;
62: int ninode;
63:
64: struct inode *rootdir; /* pointer to inode of root directory */
65:
66: struct inode *ialloc();
67: struct inode *ifind();
68: struct inode *iget();
69: struct inode *owner();
70: struct inode *maknode();
71: struct inode *namei();
72: struct inode *openi();
73: #endif
74:
75: /* flags */
76: #define ILOCK 01 /* inode is locked */
77: #define IUPD 02 /* file has been modified */
78: #define IACC 04 /* inode access time to be updated */
79: #define IMOUNT 010 /* inode is mounted on */
80: #define IWANT 020 /* some process waiting on lock */
81: #define ITEXT 040 /* inode is pure text prototype */
82: #define ICHG 0100 /* inode has been changed */
83: #define IPIPE 0200 /* inode is a pipe */
84: #define IDEAD 0400 /* only iput and iget */
85:
86: /* modes */
87: #define IFMT 0170000 /* type of file */
88: #define IFDIR 0040000 /* directory */
89: #define IFCHR 0020000 /* character special */
90: #define IFBLK 0060000 /* block special */
91: #define IFREG 0100000 /* regular */
92: #define IFLNK 0120000 /* symbolic link to another file */
93: #define ISUID 04000 /* set user id on execution */
94: #define ISGID 02000 /* set group id on execution */
95: #define IREAD 0400 /* read, write, execute permissions */
96: #define IWRITE 0200
97: #define IEXEC 0100
98: #define ICONC 0001000 /* this file is protected for concurrent access */
99: #define ICCTYP 0007000 /* type of concurrent access */
100: #define ISYNC 0001000 /* 1 writer and n readers (synchronized access) */
101: #define IEXCL 0003000 /* 1 writer or n readers (exclusive access) */
102:
103: struct argnamei { /* namei's flag argument */
104: short flag; /* type of request */
105: short mode; /* mode for creating */
106: struct inode *il; /* for linking */
107: short done; /* used as a return flag in creat */
108: } nilargnamei;
109: #define NI_DEL 1 /* unlink this file */
110: #define NI_CREAT 2 /* create it if it doesn't exits */
111: #define NI_NXCREAT 3 /* create it, error if it already exists */
112: #define NI_LINK 4 /* make a link */
113: #define NI_MKDIR 5 /* make a directory */
114: #define NI_RMDIR 6 /* remove a directory */
115: struct nx { /* arg to real nami */
116: struct inode *dp;
117: char *cp;
118: struct buf *nbp;
119: int nlink;
120: };
121:
122: /*
123: * some inline subroutines to speed things up
124: */
125:
126: #ifdef KERNEL
127:
128: #define plock(ip) \
129: { \
130: while ((ip)->i_flag & ILOCK) { \
131: (ip)->i_flag |= IWANT; \
132: sleep((caddr_t)(ip), PINOD); \
133: } \
134: (ip)->i_flag |= ILOCK; \
135: }
136:
137: #define prele(ip) \
138: { \
139: (ip)->i_flag &= ~ILOCK; \
140: if ((ip)->i_flag&IWANT) { \
141: (ip)->i_flag &= ~IWANT; \
142: wakeup((caddr_t)(ip)); \
143: } \
144: }
145:
146: #endif
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.