Blame view

kernel/linux-rt-4.4.41/include/linux/platform_data/hsmmc-omap.h 3.11 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
  /*
   * MMC definitions for OMAP2
   *
   * Copyright (C) 2006 Nokia Corporation
   *
   * 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.
   */
  
  /*
   * struct omap_hsmmc_dev_attr.flags possibilities
   *
   * OMAP_HSMMC_SUPPORTS_DUAL_VOLT: Some HSMMC controller instances can
   *    operate with either 1.8Vdc or 3.0Vdc card voltages; this flag
   *    should be set if this is the case.  See for example Section 22.5.3
   *    "MMC/SD/SDIO1 Bus Voltage Selection" of the OMAP34xx Multimedia
   *    Device Silicon Revision 3.1.x Revision ZR (July 2011) (SWPU223R).
   *
   * OMAP_HSMMC_BROKEN_MULTIBLOCK_READ: Multiple-block read transfers
   *    don't work correctly on some MMC controller instances on some
   *    OMAP3 SoCs; this flag should be set if this is the case.  See
   *    for example Advisory 2.1.1.128 "MMC: Multiple Block Read
   *    Operation Issue" in _OMAP3530/3525/3515/3503 Silicon Errata_
   *    Revision F (October 2010) (SPRZ278F).
   *
   * OMAP_HSMMC_NO_1_8_V: The controller does not support 1.8V IO voltage
   *    irrespective of what the capability states.
   *
   */
  #define OMAP_HSMMC_SUPPORTS_DUAL_VOLT		BIT(0)
  #define OMAP_HSMMC_BROKEN_MULTIBLOCK_READ	BIT(1)
  #define OMAP_HSMMC_SWAKEUP_MISSING		BIT(2)
  #define OMAP_HSMMC_REQUIRE_IODELAY		BIT(3)
  #define OMAP_HSMMC_HAS_HWPARAM			BIT(4)
  #define OMAP_HSMMC_NO_1_8_V			BIT(5)
  
  struct omap_hsmmc_dev_attr {
  	u8 flags;
  };
  
  struct mmc_card;
  
  struct omap_hsmmc_platform_data {
  	/* back-link to device */
  	struct device *dev;
  
  	/* set if your board has components or wiring that limits the
  	 * maximum frequency on the MMC bus */
  	unsigned int max_freq;
  
  	/* Integrating attributes from the omap_hwmod layer */
  	u8 controller_flags;
  
  	/* Register offset deviation */
  	u16 reg_offset;
  
  	/*
  	 * 4/8 wires and any additional host capabilities
  	 * need to OR'd all capabilities (ref. linux/mmc/host.h)
  	 */
  	u32 caps;	/* Used for the MMC driver on 2430 and later */
  	u32 pm_caps;	/* PM capabilities of the mmc */
  
  	/* use the internal clock */
  	unsigned internal_clock:1;
  
  	/* nonremovable e.g. eMMC */
  	unsigned nonremovable:1;
  
  	/* eMMC does not handle power off when not in sleep state */
  	unsigned no_regulator_off_init:1;
  
  	/* we can put the features above into this variable */
  #define HSMMC_HAS_PBIAS		(1 << 0)
  #define HSMMC_HAS_UPDATED_RESET	(1 << 1)
  #define HSMMC_HAS_HSPE_SUPPORT	(1 << 2)
  	unsigned features;
  
  	/* string specifying a particular variant of hardware */
  	char *version;
  
  	int gpio_cd;			/* gpio (card detect) */
  	int gpio_cod;			/* gpio (cover detect) */
  	int gpio_wp;			/* gpio (write protect) */
  
  	int (*set_power)(struct device *dev, int power_on, int vdd);
  	void (*remux)(struct device *dev, int power_on);
  	/* Call back before enabling / disabling regulators */
  	void (*before_set_reg)(struct device *dev, int power_on, int vdd);
  	/* Call back after enabling / disabling regulators */
  	void (*after_set_reg)(struct device *dev, int power_on, int vdd);
  	/* if we have special card, init it using this callback */
  	void (*init_card)(struct mmc_card *card);
  
  	const char *name;
  	u32 ocr_mask;
  };