blob: d89b8fbba4c9988d9c082766c7ea41bf095b5aaf [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
Linus Torvalds1da177e2005-04-16 15:20:36 -07002 * (C) 2003 David Woodhouse <dwmw2@infradead.org>
3 *
4 * Interface to Linux block layer for MTD 'translation layers'.
5 *
6 */
7
8#ifndef __MTD_TRANS_H__
9#define __MTD_TRANS_H__
10
Ingo Molnar48b19262006-03-31 02:29:41 -080011#include <linux/mutex.h>
Maxim Levitsky048d8712010-02-22 20:39:30 +020012#include <linux/kref.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
14struct hd_geometry;
15struct mtd_info;
16struct mtd_blktrans_ops;
17struct file;
18struct inode;
19
20struct mtd_blktrans_dev {
21 struct mtd_blktrans_ops *tr;
22 struct list_head list;
23 struct mtd_info *mtd;
Ingo Molnar48b19262006-03-31 02:29:41 -080024 struct mutex lock;
Linus Torvalds1da177e2005-04-16 15:20:36 -070025 int devnum;
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 unsigned long size;
27 int readonly;
Maxim Levitsky048d8712010-02-22 20:39:30 +020028 int open;
29 struct kref ref;
Maxim Levitskya8638622010-02-22 20:39:29 +020030 struct gendisk *disk;
31 struct task_struct *thread;
32 struct request_queue *rq;
33 spinlock_t queue_lock;
34 void *priv;
Linus Torvalds1da177e2005-04-16 15:20:36 -070035};
36
Linus Torvalds1da177e2005-04-16 15:20:36 -070037struct mtd_blktrans_ops {
38 char *name;
39 int major;
40 int part_bits;
Richard Purdie19187672006-10-27 09:09:33 +010041 int blksize;
42 int blkshift;
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
44 /* Access functions */
45 int (*readsect)(struct mtd_blktrans_dev *dev,
46 unsigned long block, char *buffer);
47 int (*writesect)(struct mtd_blktrans_dev *dev,
48 unsigned long block, char *buffer);
David Woodhouseeae9acd2008-08-05 18:08:25 +010049 int (*discard)(struct mtd_blktrans_dev *dev,
50 unsigned long block, unsigned nr_blocks);
Linus Torvalds1da177e2005-04-16 15:20:36 -070051
52 /* Block layer ioctls */
53 int (*getgeo)(struct mtd_blktrans_dev *dev, struct hd_geometry *geo);
54 int (*flush)(struct mtd_blktrans_dev *dev);
55
56 /* Called with mtd_table_mutex held; no race with add/remove */
57 int (*open)(struct mtd_blktrans_dev *dev);
58 int (*release)(struct mtd_blktrans_dev *dev);
59
60 /* Called on {de,}registration and on subsequent addition/removal
61 of devices, with mtd_table_mutex held. */
62 void (*add_mtd)(struct mtd_blktrans_ops *tr, struct mtd_info *mtd);
63 void (*remove_dev)(struct mtd_blktrans_dev *dev);
64
65 struct list_head devs;
66 struct list_head list;
67 struct module *owner;
Linus Torvalds1da177e2005-04-16 15:20:36 -070068};
69
70extern int register_mtd_blktrans(struct mtd_blktrans_ops *tr);
71extern int deregister_mtd_blktrans(struct mtd_blktrans_ops *tr);
72extern int add_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
73extern int del_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
Thomas Gleixner61ecfa82005-11-07 11:15:31 +000074
Linus Torvalds1da177e2005-04-16 15:20:36 -070075
76#endif /* __MTD_TRANS_H__ */