core.h 2.8 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13
/*
 * drivers/mfd/mfd-core.h
 *
 * core MFD support
 * Copyright (c) 2006 Ian Molton
 * Copyright (c) 2007 Dmitry Baryshkov
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 *
 */

B
Ben Dooks 已提交
14 15 16
#ifndef MFD_CORE_H
#define MFD_CORE_H

17 18 19 20 21 22 23 24 25
#include <linux/platform_device.h>

/*
 * This struct describes the MFD part ("cell").
 * After registration the copy of this structure will become the platform data
 * of the resulting platform_device
 */
struct mfd_cell {
	const char		*name;
26
	int			id;
27

28 29
	/* refcounting for multiple drivers to use a single cell */
	atomic_t		*usage_count;
30 31
	int			(*enable)(struct platform_device *dev);
	int			(*disable)(struct platform_device *dev);
32

33 34 35
	int			(*suspend)(struct platform_device *dev);
	int			(*resume)(struct platform_device *dev);

36 37
	/* mfd_data can be used to pass data to client drivers */
	void			*mfd_data;
38

39
	/*
40 41
	 * These resources can be specified relative to the parent device.
	 * For accessing hardware you should use resources from the platform dev
42 43 44
	 */
	int			num_resources;
	const struct resource	*resources;
45 46 47

	/* don't check for resource conflicts */
	bool			ignore_resource_conflicts;
48 49 50 51 52 53

	/*
	 * Disable runtime PM callbacks for this subdevice - see
	 * pm_runtime_no_callbacks().
	 */
	bool			pm_runtime_no_callbacks;
54 55
};

56 57 58 59 60 61 62 63 64
/*
 * Convenience functions for clients using shared cells.  Refcounting
 * happens automatically, with the cell's enable/disable callbacks
 * being called only when a device is first being enabled or no other
 * clients are making use of it.
 */
extern int mfd_shared_cell_enable(struct platform_device *pdev);
extern int mfd_shared_cell_disable(struct platform_device *pdev);

65 66 67 68 69 70 71 72 73 74 75
/*
 * Given a platform device that's been created by mfd_add_devices(), fetch
 * the mfd_cell that created it.
 */
static inline const struct mfd_cell *mfd_get_cell(struct platform_device *pdev)
{
	return pdev->dev.platform_data;
}

/*
 * Given a platform device that's been created by mfd_add_devices(), fetch
76
 * the .mfd_data entry from the mfd_cell that created it.
77 78 79
 */
static inline void *mfd_get_data(struct platform_device *pdev)
{
80
	return mfd_get_cell(pdev)->mfd_data;
81 82
}

83
extern int mfd_add_devices(struct device *parent, int id,
84
			   struct mfd_cell *cells, int n_devs,
B
Ben Dooks 已提交
85 86
			   struct resource *mem_base,
			   int irq_base);
87

88
extern void mfd_remove_devices(struct device *parent);
89

90 91 92 93 94 95 96 97 98
/*
 * For MFD drivers with clients sharing access to resources, these create
 * multiple platform devices per cell.  Contention handling must still be
 * handled via drivers (ie, with enable/disable hooks).
 */
extern int mfd_shared_platform_driver_register(struct platform_driver *drv,
		const char *cellname);
extern void mfd_shared_platform_driver_unregister(struct platform_driver *drv);

99
#endif