2 * arch/arm/plat-pxa/include/plat/mfp.h
4 * Common Multi-Function Pin Definitions
6 * Copyright (C) 2007 Marvell International Ltd.
8 * 2007-8-21: eric miao <eric.miao@marvell.com>
11 * This program is free software; you can redistribute it and/or modify
12 * it under the terms of the GNU General Public License version 2 as
13 * published by the Free Software Foundation.
16 #ifndef __ASM_PLAT_MFP_H
17 #define __ASM_PLAT_MFP_H
19 #define mfp_to_gpio(m) ((m) % 128)
21 /* list of all the configurable MFP pins */
178 MFP_PIN_DF_nADV1_ALE
,
183 MFP_PIN_DF_nADV2_ALE
,
212 MFP_PIN_DF_nCS0_SM_nCS2
,
213 MFP_PIN_DF_nCS1_SM_nCS3
,
218 MFP_PIN_DF_CLE_SM_OEn
,
219 MFP_PIN_DF_ALE_SM_WEn
,
243 /* additional pins on PXA930 */
255 * a possible MFP configuration is represented by a 32-bit integer
257 * bit 0.. 9 - MFP Pin Number (1024 Pins Maximum)
258 * bit 10..12 - Alternate Function Selection
259 * bit 13..15 - Drive Strength
260 * bit 16..18 - Low Power Mode State
261 * bit 19..20 - Low Power Mode Edge Detection
262 * bit 21..22 - Run Mode Pull State
264 * to facilitate the definition, the following macros are provided
266 * MFP_CFG_DEFAULT - default MFP configuration value, with
267 * alternate function = 0,
268 * drive strength = fast 3mA (MFP_DS03X)
269 * low power mode = default
270 * edge detection = none
272 * MFP_CFG - default MFPR value with alternate function
273 * MFP_CFG_DRV - default MFPR value with alternate function and
275 * MFP_CFG_LPM - default MFPR value with alternate function and
277 * MFP_CFG_X - default MFPR value with alternate function,
278 * pin drive strength and low power mode
281 typedef unsigned long mfp_cfg_t
;
283 #define MFP_PIN(x) ((x) & 0x3ff)
285 #define MFP_AF0 (0x0 << 10)
286 #define MFP_AF1 (0x1 << 10)
287 #define MFP_AF2 (0x2 << 10)
288 #define MFP_AF3 (0x3 << 10)
289 #define MFP_AF4 (0x4 << 10)
290 #define MFP_AF5 (0x5 << 10)
291 #define MFP_AF6 (0x6 << 10)
292 #define MFP_AF7 (0x7 << 10)
293 #define MFP_AF_MASK (0x7 << 10)
294 #define MFP_AF(x) (((x) >> 10) & 0x7)
296 #define MFP_DS01X (0x0 << 13)
297 #define MFP_DS02X (0x1 << 13)
298 #define MFP_DS03X (0x2 << 13)
299 #define MFP_DS04X (0x3 << 13)
300 #define MFP_DS06X (0x4 << 13)
301 #define MFP_DS08X (0x5 << 13)
302 #define MFP_DS10X (0x6 << 13)
303 #define MFP_DS13X (0x7 << 13)
304 #define MFP_DS_MASK (0x7 << 13)
305 #define MFP_DS(x) (((x) >> 13) & 0x7)
307 #define MFP_LPM_DEFAULT (0x0 << 16)
308 #define MFP_LPM_DRIVE_LOW (0x1 << 16)
309 #define MFP_LPM_DRIVE_HIGH (0x2 << 16)
310 #define MFP_LPM_PULL_LOW (0x3 << 16)
311 #define MFP_LPM_PULL_HIGH (0x4 << 16)
312 #define MFP_LPM_FLOAT (0x5 << 16)
313 #define MFP_LPM_INPUT (0x6 << 16)
314 #define MFP_LPM_STATE_MASK (0x7 << 16)
315 #define MFP_LPM_STATE(x) (((x) >> 16) & 0x7)
317 #define MFP_LPM_EDGE_NONE (0x0 << 19)
318 #define MFP_LPM_EDGE_RISE (0x1 << 19)
319 #define MFP_LPM_EDGE_FALL (0x2 << 19)
320 #define MFP_LPM_EDGE_BOTH (0x3 << 19)
321 #define MFP_LPM_EDGE_MASK (0x3 << 19)
322 #define MFP_LPM_EDGE(x) (((x) >> 19) & 0x3)
324 #define MFP_PULL_NONE (0x0 << 21)
325 #define MFP_PULL_LOW (0x1 << 21)
326 #define MFP_PULL_HIGH (0x2 << 21)
327 #define MFP_PULL_BOTH (0x3 << 21)
328 #define MFP_PULL_MASK (0x3 << 21)
329 #define MFP_PULL(x) (((x) >> 21) & 0x3)
331 #define MFP_CFG_DEFAULT (MFP_AF0 | MFP_DS03X | MFP_LPM_DEFAULT |\
332 MFP_LPM_EDGE_NONE | MFP_PULL_NONE)
334 #define MFP_CFG(pin, af) \
335 ((MFP_CFG_DEFAULT & ~MFP_AF_MASK) |\
336 (MFP_PIN(MFP_PIN_##pin) | MFP_##af))
338 #define MFP_CFG_DRV(pin, af, drv) \
339 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_DS_MASK)) |\
340 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_##drv))
342 #define MFP_CFG_LPM(pin, af, lpm) \
343 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_LPM_STATE_MASK)) |\
344 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_LPM_##lpm))
346 #define MFP_CFG_X(pin, af, drv, lpm) \
347 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_DS_MASK | MFP_LPM_STATE_MASK)) |\
348 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_##drv | MFP_LPM_##lpm))
350 #if defined(CONFIG_PXA3xx) || defined(CONFIG_ARCH_MMP)
352 * each MFP pin will have a MFPR register, since the offset of the
353 * register varies between processors, the processor specific code
354 * should initialize the pin offsets by mfp_init()
356 * mfp_init_base() - accepts a virtual base for all MFPR registers and
357 * initialize the MFP table to a default state
359 * mfp_init_addr() - accepts a table of "mfp_addr_map" structure, which
360 * represents a range of MFP pins from "start" to "end", with the offset
361 * begining at "offset", to define a single pin, let "end" = -1.
365 * MFP_ADDR_X() to define a range of pins
366 * MFP_ADDR() to define a single pin
367 * MFP_ADDR_END to signal the end of pin offset definitions
369 struct mfp_addr_map
{
372 unsigned long offset
;
375 #define MFP_ADDR_X(start, end, offset) \
376 { MFP_PIN_##start, MFP_PIN_##end, offset }
378 #define MFP_ADDR(pin, offset) \
379 { MFP_PIN_##pin, -1, offset }
381 #define MFP_ADDR_END { MFP_PIN_INVALID, 0 }
383 void __init
mfp_init_base(unsigned long mfpr_base
);
384 void __init
mfp_init_addr(struct mfp_addr_map
*map
);
387 * mfp_{read, write}() - for direct read/write access to the MFPR register
388 * mfp_config() - for configuring a group of MFPR registers
389 * mfp_config_lpm() - configuring all low power MFPR registers for suspend
390 * mfp_config_run() - configuring all run time MFPR registers after resume
392 unsigned long mfp_read(int mfp
);
393 void mfp_write(int mfp
, unsigned long mfpr_val
);
394 void mfp_config(unsigned long *mfp_cfgs
, int num
);
395 void mfp_config_run(void);
396 void mfp_config_lpm(void);
397 #endif /* CONFIG_PXA3xx || CONFIG_ARCH_MMP */
399 #endif /* __ASM_PLAT_MFP_H */