board.h 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * board.h
  3. *
  4. * (C) Copyright 2013 Siemens Schweiz AG
  5. * (C) Heiko Schocher, DENX Software Engineering, hs@denx.de.
  6. *
  7. * Based on:
  8. * TI AM335x boards information header
  9. * u-boot:/board/ti/am335x/board.h
  10. *
  11. * Copyright (C) 2011, Texas Instruments, Incorporated - http://www.ti.com/
  12. *
  13. * SPDX-License-Identifier: GPL-2.0+
  14. */
  15. #ifndef _BOARD_H_
  16. #define _BOARD_H_
  17. #define PARGS(x) #x , /* Parameter Name */ \
  18. settings.ddr3.x, /* EEPROM Value */ \
  19. ddr3_default.x, /* Default Value */ \
  20. settings.ddr3.x-ddr3_default.x /* Difference */
  21. #define PRINTARGS(y) printf("%-20s, %8x, %8x, %4d\n", PARGS(y))
  22. #define MAGIC_CHIP 0x50494843
  23. /* Automatic generated definition */
  24. /* Wed, 16 Apr 2014 16:50:41 +0200 */
  25. /* From file: draco/ddr3-data-universal-default@303MHz-i0-ES3.txt */
  26. struct ddr3_data {
  27. unsigned int magic; /* 0x33524444 */
  28. unsigned int version; /* 0x56312e35 */
  29. unsigned short int ddr3_sratio; /* 0x0080 */
  30. unsigned short int iclkout; /* 0x0000 */
  31. unsigned short int dt0rdsratio0; /* 0x003A */
  32. unsigned short int dt0wdsratio0; /* 0x003F */
  33. unsigned short int dt0fwsratio0; /* 0x009F */
  34. unsigned short int dt0wrsratio0; /* 0x0079 */
  35. unsigned int sdram_tim1; /* 0x0888A39B */
  36. unsigned int sdram_tim2; /* 0x26247FDA */
  37. unsigned int sdram_tim3; /* 0x501F821F */
  38. unsigned int emif_ddr_phy_ctlr_1; /* 0x00100206 */
  39. unsigned int sdram_config; /* 0x61A44A32 */
  40. unsigned int ref_ctrl; /* 0x0000093B */
  41. unsigned int ioctr_val; /* 0x0000014A */
  42. char manu_name[32]; /* "default@303MHz \0" */
  43. char manu_marking[32]; /* "default \0" */
  44. };
  45. struct chip_data {
  46. unsigned int magic;
  47. char sdevname[16];
  48. char shwver[7];
  49. };
  50. struct draco_baseboard_id {
  51. struct ddr3_data ddr3;
  52. struct chip_data chip;
  53. };
  54. /*
  55. * We have three pin mux functions that must exist. We must be able to enable
  56. * uart0, for initial output and i2c0 to read the main EEPROM. We then have a
  57. * main pinmux function that can be overridden to enable all other pinmux that
  58. * is required on the board.
  59. */
  60. void enable_uart0_pin_mux(void);
  61. void enable_uart1_pin_mux(void);
  62. void enable_uart2_pin_mux(void);
  63. void enable_uart3_pin_mux(void);
  64. void enable_uart4_pin_mux(void);
  65. void enable_uart5_pin_mux(void);
  66. void enable_i2c0_pin_mux(void);
  67. void enable_board_pin_mux(void);
  68. /* Forwared declaration, defined in common board.c */
  69. void set_env_gpios(unsigned char state);
  70. #endif