omap_opp_data.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * OMAP SoC specific OPP Data helpers
  3. *
  4. * Copyright (C) 2009-2010 Texas Instruments Incorporated - http://www.ti.com/
  5. * Nishanth Menon
  6. * Kevin Hilman
  7. * Copyright (C) 2010 Nokia Corporation.
  8. * Eduardo Valentin
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License version 2 as
  12. * published by the Free Software Foundation.
  13. *
  14. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  15. * kind, whether express or implied; without even the implied warranty
  16. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. */
  19. #ifndef __ARCH_ARM_MACH_OMAP2_OMAP_OPP_DATA_H
  20. #define __ARCH_ARM_MACH_OMAP2_OMAP_OPP_DATA_H
  21. #include "omap_hwmod.h"
  22. #include "voltage.h"
  23. /*
  24. * *BIG FAT WARNING*:
  25. * USE the following ONLY in opp data initialization common to an SoC.
  26. * DO NOT USE these in board files/pm core etc.
  27. */
  28. /**
  29. * struct omap_opp_def - OMAP OPP Definition
  30. * @hwmod_name: Name of the hwmod for this domain
  31. * @freq: Frequency in hertz corresponding to this OPP
  32. * @u_volt: Nominal voltage in microvolts corresponding to this OPP
  33. * @default_available: True/false - is this OPP available by default
  34. *
  35. * OMAP SOCs have a standard set of tuples consisting of frequency and voltage
  36. * pairs that the device will support per voltage domain. This is called
  37. * Operating Points or OPP. The actual definitions of OMAP Operating Points
  38. * varies over silicon within the same family of devices. For a specific
  39. * domain, you can have a set of {frequency, voltage} pairs and this is denoted
  40. * by an array of omap_opp_def. As the kernel boots and more information is
  41. * available, a set of these are activated based on the precise nature of
  42. * device the kernel boots up on. It is interesting to remember that each IP
  43. * which belongs to a voltage domain may define their own set of OPPs on top
  44. * of this - but this is handled by the appropriate driver.
  45. */
  46. struct omap_opp_def {
  47. char *hwmod_name;
  48. unsigned long freq;
  49. unsigned long u_volt;
  50. bool default_available;
  51. };
  52. /*
  53. * Initialization wrapper used to define an OPP for OMAP variants.
  54. */
  55. #define OPP_INITIALIZER(_hwmod_name, _enabled, _freq, _uv) \
  56. { \
  57. .hwmod_name = _hwmod_name, \
  58. .default_available = _enabled, \
  59. .freq = _freq, \
  60. .u_volt = _uv, \
  61. }
  62. /*
  63. * Initialization wrapper used to define SmartReflex process data
  64. * XXX Is this needed? Just use C99 initializers in data files?
  65. */
  66. #define VOLT_DATA_DEFINE(_v_nom, _efuse_offs, _errminlimit, _errgain) \
  67. { \
  68. .volt_nominal = _v_nom, \
  69. .sr_efuse_offs = _efuse_offs, \
  70. .sr_errminlimit = _errminlimit, \
  71. .vp_errgain = _errgain \
  72. }
  73. /* Use this to initialize the default table */
  74. extern int __init omap_init_opp_table(struct omap_opp_def *opp_def,
  75. u32 opp_def_size);
  76. extern struct omap_volt_data omap34xx_vddmpu_volt_data[];
  77. extern struct omap_volt_data omap34xx_vddcore_volt_data[];
  78. extern struct omap_volt_data omap36xx_vddmpu_volt_data[];
  79. extern struct omap_volt_data omap36xx_vddcore_volt_data[];
  80. extern struct omap_volt_data omap443x_vdd_mpu_volt_data[];
  81. extern struct omap_volt_data omap443x_vdd_iva_volt_data[];
  82. extern struct omap_volt_data omap443x_vdd_core_volt_data[];
  83. extern struct omap_volt_data omap446x_vdd_mpu_volt_data[];
  84. extern struct omap_volt_data omap446x_vdd_iva_volt_data[];
  85. extern struct omap_volt_data omap446x_vdd_core_volt_data[];
  86. #endif /* __ARCH_ARM_MACH_OMAP2_OMAP_OPP_DATA_H */