vfs: remove redundant position check in do_sendfile
[deliverable/linux.git] / include / linux / seq_file.h
CommitLineData
1da177e4
LT
1#ifndef _LINUX_SEQ_FILE_H
2#define _LINUX_SEQ_FILE_H
1da177e4
LT
3
4#include <linux/types.h>
5#include <linux/string.h>
0ac1759a 6#include <linux/mutex.h>
50ac2d69
AD
7#include <linux/cpumask.h>
8#include <linux/nodemask.h>
1da177e4
LT
9
10struct seq_operations;
11struct file;
c32c2f63 12struct path;
1da177e4 13struct inode;
6092d048 14struct dentry;
1da177e4
LT
15
16struct seq_file {
17 char *buf;
18 size_t size;
19 size_t from;
20 size_t count;
21 loff_t index;
8f19d472 22 loff_t read_pos;
2b47c361 23 u64 version;
0ac1759a 24 struct mutex lock;
15ad7cdc 25 const struct seq_operations *op;
1da177e4
LT
26 void *private;
27};
28
29struct seq_operations {
30 void * (*start) (struct seq_file *m, loff_t *pos);
31 void (*stop) (struct seq_file *m, void *v);
32 void * (*next) (struct seq_file *m, void *v, loff_t *pos);
33 int (*show) (struct seq_file *m, void *v);
34};
35
521b5d0c
AV
36#define SEQ_SKIP 1
37
74e2f334 38char *mangle_path(char *s, char *p, char *esc);
15ad7cdc 39int seq_open(struct file *, const struct seq_operations *);
1da177e4
LT
40ssize_t seq_read(struct file *, char __user *, size_t, loff_t *);
41loff_t seq_lseek(struct file *, loff_t, int);
42int seq_release(struct inode *, struct file *);
43int seq_escape(struct seq_file *, const char *, const char *);
44int seq_putc(struct seq_file *m, char c);
45int seq_puts(struct seq_file *m, const char *s);
0b923606 46int seq_write(struct seq_file *seq, const void *data, size_t len);
1da177e4
LT
47
48int seq_printf(struct seq_file *, const char *, ...)
49 __attribute__ ((format (printf,2,3)));
50
c32c2f63 51int seq_path(struct seq_file *, struct path *, char *);
6092d048 52int seq_dentry(struct seq_file *, struct dentry *, char *);
9d1bc601
MS
53int seq_path_root(struct seq_file *m, struct path *path, struct path *root,
54 char *esc);
cb78a0ce
RR
55int seq_bitmap(struct seq_file *m, const unsigned long *bits,
56 unsigned int nr_bits);
57static inline int seq_cpumask(struct seq_file *m, const struct cpumask *mask)
50ac2d69 58{
af76aba0 59 return seq_bitmap(m, cpumask_bits(mask), nr_cpu_ids);
50ac2d69
AD
60}
61
62static inline int seq_nodemask(struct seq_file *m, nodemask_t *mask)
63{
64 return seq_bitmap(m, mask->bits, MAX_NUMNODES);
65}
1da177e4 66
af76aba0 67int seq_bitmap_list(struct seq_file *m, const unsigned long *bits,
3eda2011
LJ
68 unsigned int nr_bits);
69
af76aba0
RR
70static inline int seq_cpumask_list(struct seq_file *m,
71 const struct cpumask *mask)
3eda2011 72{
af76aba0 73 return seq_bitmap_list(m, cpumask_bits(mask), nr_cpu_ids);
3eda2011
LJ
74}
75
76static inline int seq_nodemask_list(struct seq_file *m, nodemask_t *mask)
77{
78 return seq_bitmap_list(m, mask->bits, MAX_NUMNODES);
79}
80
1da177e4
LT
81int single_open(struct file *, int (*)(struct seq_file *, void *), void *);
82int single_release(struct inode *, struct file *);
39699037
PE
83void *__seq_open_private(struct file *, const struct seq_operations *, int);
84int seq_open_private(struct file *, const struct seq_operations *, int);
1da177e4
LT
85int seq_release_private(struct inode *, struct file *);
86
87#define SEQ_START_TOKEN ((void *)1)
88
bcf67e16
PE
89/*
90 * Helpers for iteration over list_head-s in seq_files
91 */
92
93extern struct list_head *seq_list_start(struct list_head *head,
94 loff_t pos);
95extern struct list_head *seq_list_start_head(struct list_head *head,
96 loff_t pos);
97extern struct list_head *seq_list_next(void *v, struct list_head *head,
98 loff_t *ppos);
99
1da177e4 100#endif
This page took 0.732158 seconds and 5 git commands to generate.