hc
2023-02-13 e440ec23c5a540cdd3f7464e8779219be6fd3d95
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
/*
 * Copyright 2010 Wolfram Sang <w.sang@pengutronix.de>
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; version 2
 * of the License.
 */
 
#ifndef __ASM_ARCH_IMX_ESDHC_H
#define __ASM_ARCH_IMX_ESDHC_H
 
#include <linux/types.h>
 
enum wp_types {
   ESDHC_WP_NONE,        /* no WP, neither controller nor gpio */
   ESDHC_WP_CONTROLLER,    /* mmc controller internal WP */
   ESDHC_WP_GPIO,        /* external gpio pin for WP */
};
 
enum cd_types {
   ESDHC_CD_NONE,        /* no CD, neither controller nor gpio */
   ESDHC_CD_CONTROLLER,    /* mmc controller internal CD */
   ESDHC_CD_GPIO,        /* external gpio pin for CD */
   ESDHC_CD_PERMANENT,    /* no CD, card permanently wired to host */
};
 
/**
 * struct esdhc_platform_data - platform data for esdhc on i.MX
 *
 * ESDHC_WP(CD)_CONTROLLER type is not available on i.MX25/35.
 *
 * @wp_gpio:    gpio for write_protect
 * @cd_gpio:    gpio for card_detect interrupt
 * @wp_type:    type of write_protect method (see wp_types enum above)
 * @cd_type:    type of card_detect method (see cd_types enum above)
 */
 
struct esdhc_platform_data {
   unsigned int wp_gpio;
   unsigned int cd_gpio;
   enum wp_types wp_type;
   enum cd_types cd_type;
   int max_bus_width;
   unsigned int delay_line;
   unsigned int tuning_step;       /* The delay cell steps in tuning procedure */
   unsigned int tuning_start_tap;    /* The start delay cell point in tuning procedure */
};
#endif /* __ASM_ARCH_IMX_ESDHC_H */