blob: b481ccd7ff3c30330046f6b24311f5fcc6e0ef0f [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>
Maxim Levitsky026ec572010-02-22 20:39:33 +020013#include <linux/sysfs.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070014
15struct hd_geometry;
16struct mtd_info;
17struct mtd_blktrans_ops;
18struct file;
19struct inode;
20
21struct mtd_blktrans_dev {
22 struct mtd_blktrans_ops *tr;
23 struct list_head list;
24 struct mtd_info *mtd;
Ingo Molnar48b19262006-03-31 02:29:41 -080025 struct mutex lock;
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 int devnum;
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 unsigned long size;
28 int readonly;
Maxim Levitsky048d8712010-02-22 20:39:30 +020029 int open;
30 struct kref ref;
Maxim Levitskya8638622010-02-22 20:39:29 +020031 struct gendisk *disk;
Maxim Levitsky026ec572010-02-22 20:39:33 +020032 struct attribute_group *disk_attributes;
Maxim Levitskya8638622010-02-22 20:39:29 +020033 struct task_struct *thread;
34 struct request_queue *rq;
35 spinlock_t queue_lock;
36 void *priv;
Linus Torvalds1da177e2005-04-16 15:20:36 -070037};
38
Linus Torvalds1da177e2005-04-16 15:20:36 -070039struct mtd_blktrans_ops {
40 char *name;
41 int major;
42 int part_bits;
Richard Purdie19187672006-10-27 09:09:33 +010043 int blksize;
44 int blkshift;
Linus Torvalds1da177e2005-04-16 15:20:36 -070045
46 /* Access functions */
47 int (*readsect)(struct mtd_blktrans_dev *dev,
48 unsigned long block, char *buffer);
49 int (*writesect)(struct mtd_blktrans_dev *dev,
50 unsigned long block, char *buffer);
David Woodhouseeae9acd2008-08-05 18:08:25 +010051 int (*discard)(struct mtd_blktrans_dev *dev,
52 unsigned long block, unsigned nr_blocks);
Linus Torvalds1da177e2005-04-16 15:20:36 -070053
54 /* Block layer ioctls */
55 int (*getgeo)(struct mtd_blktrans_dev *dev, struct hd_geometry *geo);
56 int (*flush)(struct mtd_blktrans_dev *dev);
57
58 /* Called with mtd_table_mutex held; no race with add/remove */
59 int (*open)(struct mtd_blktrans_dev *dev);
60 int (*release)(struct mtd_blktrans_dev *dev);
61
62 /* Called on {de,}registration and on subsequent addition/removal
63 of devices, with mtd_table_mutex held. */
64 void (*add_mtd)(struct mtd_blktrans_ops *tr, struct mtd_info *mtd);
65 void (*remove_dev)(struct mtd_blktrans_dev *dev);
66
67 struct list_head devs;
68 struct list_head list;
69 struct module *owner;
Linus Torvalds1da177e2005-04-16 15:20:36 -070070};
71
72extern int register_mtd_blktrans(struct mtd_blktrans_ops *tr);
73extern int deregister_mtd_blktrans(struct mtd_blktrans_ops *tr);
74extern int add_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
75extern int del_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
Thomas Gleixner61ecfa82005-11-07 11:15:31 +000076
Linus Torvalds1da177e2005-04-16 15:20:36 -070077
78#endif /* __MTD_TRANS_H__ */