Go to the documentation of this file.
16 #ifndef __ASM_PLAT_MFP_H
17 #define __ASM_PLAT_MFP_H
19 #define mfp_to_gpio(m) ((m) % 256)
358 #define MFP_PIN(x) ((x) & 0x3ff)
360 #define MFP_AF0 (0x0 << 10)
361 #define MFP_AF1 (0x1 << 10)
362 #define MFP_AF2 (0x2 << 10)
363 #define MFP_AF3 (0x3 << 10)
364 #define MFP_AF4 (0x4 << 10)
365 #define MFP_AF5 (0x5 << 10)
366 #define MFP_AF6 (0x6 << 10)
367 #define MFP_AF7 (0x7 << 10)
368 #define MFP_AF_MASK (0x7 << 10)
369 #define MFP_AF(x) (((x) >> 10) & 0x7)
371 #define MFP_DS01X (0x0 << 13)
372 #define MFP_DS02X (0x1 << 13)
373 #define MFP_DS03X (0x2 << 13)
374 #define MFP_DS04X (0x3 << 13)
375 #define MFP_DS06X (0x4 << 13)
376 #define MFP_DS08X (0x5 << 13)
377 #define MFP_DS10X (0x6 << 13)
378 #define MFP_DS13X (0x7 << 13)
379 #define MFP_DS_MASK (0x7 << 13)
380 #define MFP_DS(x) (((x) >> 13) & 0x7)
382 #define MFP_LPM_DEFAULT (0x0 << 16)
383 #define MFP_LPM_DRIVE_LOW (0x1 << 16)
384 #define MFP_LPM_DRIVE_HIGH (0x2 << 16)
385 #define MFP_LPM_PULL_LOW (0x3 << 16)
386 #define MFP_LPM_PULL_HIGH (0x4 << 16)
387 #define MFP_LPM_FLOAT (0x5 << 16)
388 #define MFP_LPM_INPUT (0x6 << 16)
389 #define MFP_LPM_STATE_MASK (0x7 << 16)
390 #define MFP_LPM_STATE(x) (((x) >> 16) & 0x7)
392 #define MFP_LPM_EDGE_NONE (0x0 << 19)
393 #define MFP_LPM_EDGE_RISE (0x1 << 19)
394 #define MFP_LPM_EDGE_FALL (0x2 << 19)
395 #define MFP_LPM_EDGE_BOTH (0x3 << 19)
396 #define MFP_LPM_EDGE_MASK (0x3 << 19)
397 #define MFP_LPM_EDGE(x) (((x) >> 19) & 0x3)
399 #define MFP_PULL_NONE (0x0 << 21)
400 #define MFP_PULL_LOW (0x1 << 21)
401 #define MFP_PULL_HIGH (0x2 << 21)
402 #define MFP_PULL_BOTH (0x3 << 21)
403 #define MFP_PULL_FLOAT (0x4 << 21)
404 #define MFP_PULL_MASK (0x7 << 21)
405 #define MFP_PULL(x) (((x) >> 21) & 0x7)
407 #define MFP_CFG_DEFAULT (MFP_AF0 | MFP_DS03X | MFP_LPM_DEFAULT |\
408 MFP_LPM_EDGE_NONE | MFP_PULL_NONE)
410 #define MFP_CFG(pin, af) \
411 ((MFP_CFG_DEFAULT & ~MFP_AF_MASK) |\
412 (MFP_PIN(MFP_PIN_##pin) | MFP_##af))
414 #define MFP_CFG_DRV(pin, af, drv) \
415 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_DS_MASK)) |\
416 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_##drv))
418 #define MFP_CFG_LPM(pin, af, lpm) \
419 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_LPM_STATE_MASK)) |\
420 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_LPM_##lpm))
422 #define MFP_CFG_X(pin, af, drv, lpm) \
423 ((MFP_CFG_DEFAULT & ~(MFP_AF_MASK | MFP_DS_MASK | MFP_LPM_STATE_MASK)) |\
424 (MFP_PIN(MFP_PIN_##pin) | MFP_##af | MFP_##drv | MFP_LPM_##lpm))
426 #if defined(CONFIG_PXA3xx) || defined(CONFIG_PXA95x) || defined(CONFIG_ARCH_MMP)
445 struct mfp_addr_map {
451 #define MFP_ADDR_X(start, end, offset) \
452 { MFP_PIN_##start, MFP_PIN_##end, offset }
454 #define MFP_ADDR(pin, offset) \
455 { MFP_PIN_##pin, -1, offset }
457 #define MFP_ADDR_END { MFP_PIN_INVALID, 0 }
469 void mfp_write(
int mfp,
unsigned long mfpr_val);
470 void mfp_config(
unsigned long *mfp_cfgs,
int num);