2019-05-23 16:14:39 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2005-04-17 05:20:36 +07:00
|
|
|
/*
|
2010-08-09 02:58:20 +07:00
|
|
|
* Copyright © 2003-2010 David Woodhouse <dwmw2@infradead.org>
|
2005-04-17 05:20:36 +07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __MTD_TRANS_H__
|
|
|
|
#define __MTD_TRANS_H__
|
|
|
|
|
2006-03-31 17:29:41 +07:00
|
|
|
#include <linux/mutex.h>
|
2010-02-23 01:39:30 +07:00
|
|
|
#include <linux/kref.h>
|
2010-02-23 01:39:33 +07:00
|
|
|
#include <linux/sysfs.h>
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
struct hd_geometry;
|
|
|
|
struct mtd_info;
|
|
|
|
struct mtd_blktrans_ops;
|
|
|
|
struct file;
|
|
|
|
struct inode;
|
|
|
|
|
|
|
|
struct mtd_blktrans_dev {
|
|
|
|
struct mtd_blktrans_ops *tr;
|
|
|
|
struct list_head list;
|
|
|
|
struct mtd_info *mtd;
|
2006-03-31 17:29:41 +07:00
|
|
|
struct mutex lock;
|
2005-04-17 05:20:36 +07:00
|
|
|
int devnum;
|
2011-03-25 22:41:20 +07:00
|
|
|
bool bg_stop;
|
2005-04-17 05:20:36 +07:00
|
|
|
unsigned long size;
|
|
|
|
int readonly;
|
2010-02-23 01:39:30 +07:00
|
|
|
int open;
|
|
|
|
struct kref ref;
|
2010-02-23 01:39:29 +07:00
|
|
|
struct gendisk *disk;
|
2010-02-23 01:39:33 +07:00
|
|
|
struct attribute_group *disk_attributes;
|
2010-02-23 01:39:29 +07:00
|
|
|
struct request_queue *rq;
|
2018-10-16 21:09:58 +07:00
|
|
|
struct list_head rq_list;
|
|
|
|
struct blk_mq_tag_set *tag_set;
|
2010-02-23 01:39:29 +07:00
|
|
|
spinlock_t queue_lock;
|
|
|
|
void *priv;
|
2012-01-10 19:26:58 +07:00
|
|
|
fmode_t file_mode;
|
2005-04-17 05:20:36 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct mtd_blktrans_ops {
|
|
|
|
char *name;
|
|
|
|
int major;
|
|
|
|
int part_bits;
|
2006-10-27 15:09:33 +07:00
|
|
|
int blksize;
|
|
|
|
int blkshift;
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* Access functions */
|
|
|
|
int (*readsect)(struct mtd_blktrans_dev *dev,
|
|
|
|
unsigned long block, char *buffer);
|
|
|
|
int (*writesect)(struct mtd_blktrans_dev *dev,
|
|
|
|
unsigned long block, char *buffer);
|
2008-08-06 00:08:25 +07:00
|
|
|
int (*discard)(struct mtd_blktrans_dev *dev,
|
|
|
|
unsigned long block, unsigned nr_blocks);
|
2011-02-14 21:16:09 +07:00
|
|
|
void (*background)(struct mtd_blktrans_dev *dev);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* Block layer ioctls */
|
|
|
|
int (*getgeo)(struct mtd_blktrans_dev *dev, struct hd_geometry *geo);
|
|
|
|
int (*flush)(struct mtd_blktrans_dev *dev);
|
|
|
|
|
|
|
|
/* Called with mtd_table_mutex held; no race with add/remove */
|
|
|
|
int (*open)(struct mtd_blktrans_dev *dev);
|
2013-05-06 08:31:22 +07:00
|
|
|
void (*release)(struct mtd_blktrans_dev *dev);
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
/* Called on {de,}registration and on subsequent addition/removal
|
|
|
|
of devices, with mtd_table_mutex held. */
|
|
|
|
void (*add_mtd)(struct mtd_blktrans_ops *tr, struct mtd_info *mtd);
|
|
|
|
void (*remove_dev)(struct mtd_blktrans_dev *dev);
|
|
|
|
|
|
|
|
struct list_head devs;
|
|
|
|
struct list_head list;
|
|
|
|
struct module *owner;
|
|
|
|
};
|
|
|
|
|
|
|
|
extern int register_mtd_blktrans(struct mtd_blktrans_ops *tr);
|
|
|
|
extern int deregister_mtd_blktrans(struct mtd_blktrans_ops *tr);
|
|
|
|
extern int add_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
|
|
|
|
extern int del_mtd_blktrans_dev(struct mtd_blktrans_dev *dev);
|
2011-02-14 21:16:09 +07:00
|
|
|
extern int mtd_blktrans_cease_background(struct mtd_blktrans_dev *dev);
|
2005-11-07 18:15:31 +07:00
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
#endif /* __MTD_TRANS_H__ */
|