This source file includes following definitions.
- cp_old_stat
- cp_new_stat
- sys_stat
- sys_newstat
- sys_lstat
- sys_newlstat
- sys_fstat
- sys_newfstat
- sys_readlink
1
2
3
4
5
6
7 #include <linux/errno.h>
8 #include <linux/stat.h>
9 #include <linux/fs.h>
10 #include <linux/sched.h>
11 #include <linux/kernel.h>
12 #include <asm/segment.h>
13
14 static void cp_old_stat(struct inode * inode, struct old_stat * statbuf)
15 {
16 struct old_stat tmp;
17
18 if (inode->i_ino & 0xffff0000)
19 printk("Warning: using old stat() call on bigfs\n");
20 verify_area(statbuf,sizeof (*statbuf));
21 tmp.st_dev = inode->i_dev;
22 tmp.st_ino = inode->i_ino;
23 tmp.st_mode = inode->i_mode;
24 tmp.st_nlink = inode->i_nlink;
25 tmp.st_uid = inode->i_uid;
26 tmp.st_gid = inode->i_gid;
27 tmp.st_rdev = inode->i_rdev;
28 tmp.st_size = inode->i_size;
29 tmp.st_atime = inode->i_atime;
30 tmp.st_mtime = inode->i_mtime;
31 tmp.st_ctime = inode->i_ctime;
32 memcpy_tofs(statbuf,&tmp,sizeof(tmp));
33 }
34
35 static void cp_new_stat(struct inode * inode, struct new_stat * statbuf)
36 {
37 struct new_stat tmp = {0, };
38 unsigned int blocks, indirect;
39
40 verify_area(statbuf,sizeof (*statbuf));
41 tmp.st_dev = inode->i_dev;
42 tmp.st_ino = inode->i_ino;
43 tmp.st_mode = inode->i_mode;
44 tmp.st_nlink = inode->i_nlink;
45 tmp.st_uid = inode->i_uid;
46 tmp.st_gid = inode->i_gid;
47 tmp.st_rdev = inode->i_rdev;
48 tmp.st_size = inode->i_size;
49 tmp.st_atime = inode->i_atime;
50 tmp.st_mtime = inode->i_mtime;
51 tmp.st_ctime = inode->i_ctime;
52
53
54
55
56
57
58
59
60 if (!inode->i_blksize) {
61 blocks = (tmp.st_size + 511) / 512;
62 if (blocks > 10) {
63 indirect = (blocks - 11)/256+1;
64 if (blocks > 10+256) {
65 indirect += (blocks - 267)/(256*256)+1;
66 if (blocks > 10+256+256*256)
67 indirect++;
68 }
69 blocks += indirect;
70 }
71 tmp.st_blocks = blocks;
72 } else
73 tmp.st_blocks = (inode->i_blocks * inode->i_blksize) / 512;
74 tmp.st_blksize = 512;
75 memcpy_tofs(statbuf,&tmp,sizeof(tmp));
76 }
77
78 int sys_stat(char * filename, struct old_stat * statbuf)
79 {
80 struct inode * inode;
81 int error;
82
83 error = namei(filename,&inode);
84 if (error)
85 return error;
86 cp_old_stat(inode,statbuf);
87 iput(inode);
88 return 0;
89 }
90
91 int sys_newstat(char * filename, struct new_stat * statbuf)
92 {
93 struct inode * inode;
94 int error;
95
96 error = namei(filename,&inode);
97 if (error)
98 return error;
99 cp_new_stat(inode,statbuf);
100 iput(inode);
101 return 0;
102 }
103
104 int sys_lstat(char * filename, struct old_stat * statbuf)
105 {
106 struct inode * inode;
107 int error;
108
109 error = lnamei(filename,&inode);
110 if (error)
111 return error;
112 cp_old_stat(inode,statbuf);
113 iput(inode);
114 return 0;
115 }
116
117 int sys_newlstat(char * filename, struct new_stat * statbuf)
118 {
119 struct inode * inode;
120 int error;
121
122 error = lnamei(filename,&inode);
123 if (error)
124 return error;
125 cp_new_stat(inode,statbuf);
126 iput(inode);
127 return 0;
128 }
129
130 int sys_fstat(unsigned int fd, struct old_stat * statbuf)
131 {
132 struct file * f;
133 struct inode * inode;
134
135 if (fd >= NR_OPEN || !(f=current->filp[fd]) || !(inode=f->f_inode))
136 return -EBADF;
137 cp_old_stat(inode,statbuf);
138 return 0;
139 }
140
141 int sys_newfstat(unsigned int fd, struct new_stat * statbuf)
142 {
143 struct file * f;
144 struct inode * inode;
145
146 if (fd >= NR_OPEN || !(f=current->filp[fd]) || !(inode=f->f_inode))
147 return -EBADF;
148 cp_new_stat(inode,statbuf);
149 return 0;
150 }
151
152 int sys_readlink(const char * path, char * buf, int bufsiz)
153 {
154 struct inode * inode;
155 int error;
156
157 if (bufsiz <= 0)
158 return -EINVAL;
159 verify_area(buf,bufsiz);
160 error = lnamei(path,&inode);
161 if (error)
162 return error;
163 if (!inode->i_op || !inode->i_op->readlink) {
164 iput(inode);
165 return -EINVAL;
166 }
167 return inode->i_op->readlink(inode,buf,bufsiz);
168 }