aboutsummaryrefslogtreecommitdiffstats
path: root/fs/relayfs/inode.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/relayfs/inode.c')
-rw-r--r--fs/relayfs/inode.c89
1 files changed, 47 insertions, 42 deletions
diff --git a/fs/relayfs/inode.c b/fs/relayfs/inode.c
index b4c3e0466e98..7b7f2cb5f0e1 100644
--- a/fs/relayfs/inode.c
+++ b/fs/relayfs/inode.c
@@ -247,13 +247,13 @@ int relayfs_remove_dir(struct dentry *dentry)
247} 247}
248 248
249/** 249/**
250 * relayfs_open - open file op for relayfs files 250 * relay_file_open - open file op for relay files
251 * @inode: the inode 251 * @inode: the inode
252 * @filp: the file 252 * @filp: the file
253 * 253 *
254 * Increments the channel buffer refcount. 254 * Increments the channel buffer refcount.
255 */ 255 */
256static int relayfs_open(struct inode *inode, struct file *filp) 256static int relay_file_open(struct inode *inode, struct file *filp)
257{ 257{
258 struct rchan_buf *buf = inode->u.generic_ip; 258 struct rchan_buf *buf = inode->u.generic_ip;
259 kref_get(&buf->kref); 259 kref_get(&buf->kref);
@@ -263,26 +263,26 @@ static int relayfs_open(struct inode *inode, struct file *filp)
263} 263}
264 264
265/** 265/**
266 * relayfs_mmap - mmap file op for relayfs files 266 * relay_file_mmap - mmap file op for relay files
267 * @filp: the file 267 * @filp: the file
268 * @vma: the vma describing what to map 268 * @vma: the vma describing what to map
269 * 269 *
270 * Calls upon relay_mmap_buf to map the file into user space. 270 * Calls upon relay_mmap_buf to map the file into user space.
271 */ 271 */
272static int relayfs_mmap(struct file *filp, struct vm_area_struct *vma) 272static int relay_file_mmap(struct file *filp, struct vm_area_struct *vma)
273{ 273{
274 struct rchan_buf *buf = filp->private_data; 274 struct rchan_buf *buf = filp->private_data;
275 return relay_mmap_buf(buf, vma); 275 return relay_mmap_buf(buf, vma);
276} 276}
277 277
278/** 278/**
279 * relayfs_poll - poll file op for relayfs files 279 * relay_file_poll - poll file op for relay files
280 * @filp: the file 280 * @filp: the file
281 * @wait: poll table 281 * @wait: poll table
282 * 282 *
283 * Poll implemention. 283 * Poll implemention.
284 */ 284 */
285static unsigned int relayfs_poll(struct file *filp, poll_table *wait) 285static unsigned int relay_file_poll(struct file *filp, poll_table *wait)
286{ 286{
287 unsigned int mask = 0; 287 unsigned int mask = 0;
288 struct rchan_buf *buf = filp->private_data; 288 struct rchan_buf *buf = filp->private_data;
@@ -300,14 +300,14 @@ static unsigned int relayfs_poll(struct file *filp, poll_table *wait)
300} 300}
301 301
302/** 302/**
303 * relayfs_release - release file op for relayfs files 303 * relay_file_release - release file op for relay files
304 * @inode: the inode 304 * @inode: the inode
305 * @filp: the file 305 * @filp: the file
306 * 306 *
307 * Decrements the channel refcount, as the filesystem is 307 * Decrements the channel refcount, as the filesystem is
308 * no longer using it. 308 * no longer using it.
309 */ 309 */
310static int relayfs_release(struct inode *inode, struct file *filp) 310static int relay_file_release(struct inode *inode, struct file *filp)
311{ 311{
312 struct rchan_buf *buf = filp->private_data; 312 struct rchan_buf *buf = filp->private_data;
313 kref_put(&buf->kref, relay_remove_buf); 313 kref_put(&buf->kref, relay_remove_buf);
@@ -316,11 +316,11 @@ static int relayfs_release(struct inode *inode, struct file *filp)
316} 316}
317 317
318/** 318/**
319 * relayfs_read_consume - update the consumed count for the buffer 319 * relay_file_read_consume - update the consumed count for the buffer
320 */ 320 */
321static void relayfs_read_consume(struct rchan_buf *buf, 321static void relay_file_read_consume(struct rchan_buf *buf,
322 size_t read_pos, 322 size_t read_pos,
323 size_t bytes_consumed) 323 size_t bytes_consumed)
324{ 324{
325 size_t subbuf_size = buf->chan->subbuf_size; 325 size_t subbuf_size = buf->chan->subbuf_size;
326 size_t n_subbufs = buf->chan->n_subbufs; 326 size_t n_subbufs = buf->chan->n_subbufs;
@@ -343,9 +343,9 @@ static void relayfs_read_consume(struct rchan_buf *buf,
343} 343}
344 344
345/** 345/**
346 * relayfs_read_avail - boolean, are there unconsumed bytes available? 346 * relay_file_read_avail - boolean, are there unconsumed bytes available?
347 */ 347 */
348static int relayfs_read_avail(struct rchan_buf *buf, size_t read_pos) 348static int relay_file_read_avail(struct rchan_buf *buf, size_t read_pos)
349{ 349{
350 size_t bytes_produced, bytes_consumed, write_offset; 350 size_t bytes_produced, bytes_consumed, write_offset;
351 size_t subbuf_size = buf->chan->subbuf_size; 351 size_t subbuf_size = buf->chan->subbuf_size;
@@ -376,16 +376,16 @@ static int relayfs_read_avail(struct rchan_buf *buf, size_t read_pos)
376 if (bytes_produced == bytes_consumed) 376 if (bytes_produced == bytes_consumed)
377 return 0; 377 return 0;
378 378
379 relayfs_read_consume(buf, read_pos, 0); 379 relay_file_read_consume(buf, read_pos, 0);
380 380
381 return 1; 381 return 1;
382} 382}
383 383
384/** 384/**
385 * relayfs_read_subbuf_avail - return bytes available in sub-buffer 385 * relay_file_read_subbuf_avail - return bytes available in sub-buffer
386 */ 386 */
387static size_t relayfs_read_subbuf_avail(size_t read_pos, 387static size_t relay_file_read_subbuf_avail(size_t read_pos,
388 struct rchan_buf *buf) 388 struct rchan_buf *buf)
389{ 389{
390 size_t padding, avail = 0; 390 size_t padding, avail = 0;
391 size_t read_subbuf, read_offset, write_subbuf, write_offset; 391 size_t read_subbuf, read_offset, write_subbuf, write_offset;
@@ -407,14 +407,14 @@ static size_t relayfs_read_subbuf_avail(size_t read_pos,
407} 407}
408 408
409/** 409/**
410 * relayfs_read_start_pos - find the first available byte to read 410 * relay_file_read_start_pos - find the first available byte to read
411 * 411 *
412 * If the read_pos is in the middle of padding, return the 412 * If the read_pos is in the middle of padding, return the
413 * position of the first actually available byte, otherwise 413 * position of the first actually available byte, otherwise
414 * return the original value. 414 * return the original value.
415 */ 415 */
416static size_t relayfs_read_start_pos(size_t read_pos, 416static size_t relay_file_read_start_pos(size_t read_pos,
417 struct rchan_buf *buf) 417 struct rchan_buf *buf)
418{ 418{
419 size_t read_subbuf, padding, padding_start, padding_end; 419 size_t read_subbuf, padding, padding_start, padding_end;
420 size_t subbuf_size = buf->chan->subbuf_size; 420 size_t subbuf_size = buf->chan->subbuf_size;
@@ -433,11 +433,11 @@ static size_t relayfs_read_start_pos(size_t read_pos,
433} 433}
434 434
435/** 435/**
436 * relayfs_read_end_pos - return the new read position 436 * relay_file_read_end_pos - return the new read position
437 */ 437 */
438static size_t relayfs_read_end_pos(struct rchan_buf *buf, 438static size_t relay_file_read_end_pos(struct rchan_buf *buf,
439 size_t read_pos, 439 size_t read_pos,
440 size_t count) 440 size_t count)
441{ 441{
442 size_t read_subbuf, padding, end_pos; 442 size_t read_subbuf, padding, end_pos;
443 size_t subbuf_size = buf->chan->subbuf_size; 443 size_t subbuf_size = buf->chan->subbuf_size;
@@ -456,7 +456,7 @@ static size_t relayfs_read_end_pos(struct rchan_buf *buf,
456} 456}
457 457
458/** 458/**
459 * relayfs_read - read file op for relayfs files 459 * relay_file_read - read file op for relay files
460 * @filp: the file 460 * @filp: the file
461 * @buffer: the userspace buffer 461 * @buffer: the userspace buffer
462 * @count: number of bytes to read 462 * @count: number of bytes to read
@@ -465,10 +465,10 @@ static size_t relayfs_read_end_pos(struct rchan_buf *buf,
465 * Reads count bytes or the number of bytes available in the 465 * Reads count bytes or the number of bytes available in the
466 * current sub-buffer being read, whichever is smaller. 466 * current sub-buffer being read, whichever is smaller.
467 */ 467 */
468static ssize_t relayfs_read(struct file *filp, 468static ssize_t relay_file_read(struct file *filp,
469 char __user *buffer, 469 char __user *buffer,
470 size_t count, 470 size_t count,
471 loff_t *ppos) 471 loff_t *ppos)
472{ 472{
473 struct rchan_buf *buf = filp->private_data; 473 struct rchan_buf *buf = filp->private_data;
474 struct inode *inode = filp->f_dentry->d_inode; 474 struct inode *inode = filp->f_dentry->d_inode;
@@ -477,11 +477,11 @@ static ssize_t relayfs_read(struct file *filp,
477 void *from; 477 void *from;
478 478
479 down(&inode->i_sem); 479 down(&inode->i_sem);
480 if(!relayfs_read_avail(buf, *ppos)) 480 if(!relay_file_read_avail(buf, *ppos))
481 goto out; 481 goto out;
482 482
483 read_start = relayfs_read_start_pos(*ppos, buf); 483 read_start = relay_file_read_start_pos(*ppos, buf);
484 avail = relayfs_read_subbuf_avail(read_start, buf); 484 avail = relay_file_read_subbuf_avail(read_start, buf);
485 if (!avail) 485 if (!avail)
486 goto out; 486 goto out;
487 487
@@ -491,20 +491,20 @@ static ssize_t relayfs_read(struct file *filp,
491 ret = -EFAULT; 491 ret = -EFAULT;
492 goto out; 492 goto out;
493 } 493 }
494 relayfs_read_consume(buf, read_start, count); 494 relay_file_read_consume(buf, read_start, count);
495 *ppos = relayfs_read_end_pos(buf, read_start, count); 495 *ppos = relay_file_read_end_pos(buf, read_start, count);
496out: 496out:
497 up(&inode->i_sem); 497 up(&inode->i_sem);
498 return ret; 498 return ret;
499} 499}
500 500
501struct file_operations relayfs_file_operations = { 501struct file_operations relay_file_operations = {
502 .open = relayfs_open, 502 .open = relay_file_open,
503 .poll = relayfs_poll, 503 .poll = relay_file_poll,
504 .mmap = relayfs_mmap, 504 .mmap = relay_file_mmap,
505 .read = relayfs_read, 505 .read = relay_file_read,
506 .llseek = no_llseek, 506 .llseek = no_llseek,
507 .release = relayfs_release, 507 .release = relay_file_release,
508}; 508};
509 509
510static struct super_operations relayfs_ops = { 510static struct super_operations relayfs_ops = {
@@ -558,13 +558,18 @@ static int __init init_relayfs_fs(void)
558 558
559static void __exit exit_relayfs_fs(void) 559static void __exit exit_relayfs_fs(void)
560{ 560{
561
562
563
564
565
561 unregister_filesystem(&relayfs_fs_type); 566 unregister_filesystem(&relayfs_fs_type);
562} 567}
563 568
564module_init(init_relayfs_fs) 569module_init(init_relayfs_fs)
565module_exit(exit_relayfs_fs) 570module_exit(exit_relayfs_fs)
566 571
567EXPORT_SYMBOL_GPL(relayfs_file_operations); 572EXPORT_SYMBOL_GPL(relay_file_operations);
568EXPORT_SYMBOL_GPL(relayfs_create_dir); 573EXPORT_SYMBOL_GPL(relayfs_create_dir);
569EXPORT_SYMBOL_GPL(relayfs_remove_dir); 574EXPORT_SYMBOL_GPL(relayfs_remove_dir);
570EXPORT_SYMBOL_GPL(relayfs_create_file); 575EXPORT_SYMBOL_GPL(relayfs_create_file);