blob: c92ebc39fc1fdbc5aeba2dbcb099ed6da4714081 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
Linus Walleij6ef297f2009-09-22 14:29:36 +01003 * include/linux/amba/mmci.h
Linus Torvalds1da177e2005-04-16 15:20:36 -07004 */
Linus Walleij6ef297f2009-09-22 14:29:36 +01005#ifndef AMBA_MMCI_H
6#define AMBA_MMCI_H
Linus Torvalds1da177e2005-04-16 15:20:36 -07007
Pierre Ossmanf74d1322007-02-09 22:49:31 +01008#include <linux/mmc/host.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -07009
Linus Walleij808d97c2010-04-08 07:39:38 +010010/**
11 * struct mmci_platform_data - platform configuration for the MMCI
12 * (also known as PL180) block.
Linus Walleij808d97c2010-04-08 07:39:38 +010013 * @ocr_mask: available voltages on the 4 pins from the block, this
14 * is ignored if a regulator is used, see the MMC_VDD_* masks in
15 * mmc/host.h
Ulf Hanssonbc521812011-12-13 16:57:55 +010016 * @ios_handler: a callback function to act on specfic ios changes,
17 * used for example to control a levelshifter
Rabin Vincentbb8f5632010-07-21 12:53:57 +010018 * mask into a value to be binary (or set some other custom bits
19 * in MMCIPWR) or:ed and written into the MMCIPWR register of the
20 * block. May also control external power based on the power_mode.
Linus Walleij9ef986a2018-09-20 16:01:10 -070021 * @status: if no GPIO line was given to the block in this function will
22 * be called to determine whether a card is present in the MMC slot or not
Linus Walleij808d97c2010-04-08 07:39:38 +010023 */
Linus Walleij6ef297f2009-09-22 14:29:36 +010024struct mmci_platform_data {
Linus Walleij808d97c2010-04-08 07:39:38 +010025 unsigned int ocr_mask;
Ulf Hanssonbc521812011-12-13 16:57:55 +010026 int (*ios_handler)(struct device *, struct mmc_ios *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070027 unsigned int (*status)(struct device *);
Linus Torvalds1da177e2005-04-16 15:20:36 -070028};
29
30#endif