fsl_devices.h 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. /*
  2. * include/linux/fsl_devices.h
  3. *
  4. * Definitions for any platform device related flags or structures for
  5. * Freescale processor devices
  6. *
  7. * Maintainer: Kumar Gala <galak@kernel.crashing.org>
  8. *
  9. * Copyright 2004 Freescale Semiconductor, Inc
  10. *
  11. * This program is free software; you can redistribute it and/or modify it
  12. * under the terms of the GNU General Public License as published by the
  13. * Free Software Foundation; either version 2 of the License, or (at your
  14. * option) any later version.
  15. */
  16. #ifdef __KERNEL__
  17. #ifndef _FSL_DEVICE_H_
  18. #define _FSL_DEVICE_H_
  19. #include <linux/types.h>
  20. /*
  21. * Some conventions on how we handle peripherals on Freescale chips
  22. *
  23. * unique device: a platform_device entry in fsl_plat_devs[] plus
  24. * associated device information in its platform_data structure.
  25. *
  26. * A chip is described by a set of unique devices.
  27. *
  28. * Each sub-arch has its own master list of unique devices and
  29. * enumerates them by enum fsl_devices in a sub-arch specific header
  30. *
  31. * The platform data structure is broken into two parts. The
  32. * first is device specific information that help identify any
  33. * unique features of a peripheral. The second is any
  34. * information that may be defined by the board or how the device
  35. * is connected externally of the chip.
  36. *
  37. * naming conventions:
  38. * - platform data structures: <driver>_platform_data
  39. * - platform data device flags: FSL_<driver>_DEV_<FLAG>
  40. * - platform data board flags: FSL_<driver>_BRD_<FLAG>
  41. *
  42. */
  43. struct gianfar_platform_data {
  44. /* device specific information */
  45. u32 device_flags;
  46. /* board specific information */
  47. u32 board_flags;
  48. const char *bus_id;
  49. u8 mac_addr[6];
  50. };
  51. struct gianfar_mdio_data {
  52. /* device specific information */
  53. u32 paddr;
  54. /* board specific information */
  55. int irq[32];
  56. };
  57. /* Flags related to gianfar device features */
  58. #define FSL_GIANFAR_DEV_HAS_GIGABIT 0x00000001
  59. #define FSL_GIANFAR_DEV_HAS_COALESCE 0x00000002
  60. #define FSL_GIANFAR_DEV_HAS_RMON 0x00000004
  61. #define FSL_GIANFAR_DEV_HAS_MULTI_INTR 0x00000008
  62. #define FSL_GIANFAR_DEV_HAS_CSUM 0x00000010
  63. #define FSL_GIANFAR_DEV_HAS_VLAN 0x00000020
  64. #define FSL_GIANFAR_DEV_HAS_EXTENDED_HASH 0x00000040
  65. #define FSL_GIANFAR_DEV_HAS_PADDING 0x00000080
  66. /* Flags in gianfar_platform_data */
  67. #define FSL_GIANFAR_BRD_HAS_PHY_INTR 0x00000001 /* set or use a timer */
  68. #define FSL_GIANFAR_BRD_IS_REDUCED 0x00000002 /* Set if RGMII, RMII */
  69. struct fsl_i2c_platform_data {
  70. /* device specific information */
  71. u32 device_flags;
  72. };
  73. /* Flags related to I2C device features */
  74. #define FSL_I2C_DEV_SEPARATE_DFSRR 0x00000001
  75. #define FSL_I2C_DEV_CLOCK_5200 0x00000002
  76. #endif /* _FSL_DEVICE_H_ */
  77. #endif /* __KERNEL__ */