ddr3_training_ip_engine.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /*
  2. * Copyright (C) Marvell International Ltd. and its affiliates
  3. *
  4. * SPDX-License-Identifier: GPL-2.0
  5. */
  6. #ifndef _DDR3_TRAINING_IP_ENGINE_H_
  7. #define _DDR3_TRAINING_IP_ENGINE_H_
  8. #include "ddr3_training_ip_def.h"
  9. #include "ddr3_training_ip_flow.h"
  10. #define EDGE_1 0
  11. #define EDGE_2 1
  12. #define ALL_PUP_TRAINING 0xe
  13. #define PUP_RESULT_EDGE_1_MASK 0xff
  14. #define PUP_RESULT_EDGE_2_MASK (0xff << 8)
  15. #define PUP_LOCK_RESULT_BIT 25
  16. #define GET_TAP_RESULT(reg, edge) \
  17. (((edge) == EDGE_1) ? ((reg) & PUP_RESULT_EDGE_1_MASK) : \
  18. (((reg) & PUP_RESULT_EDGE_2_MASK) >> 8));
  19. #define GET_LOCK_RESULT(reg) \
  20. (((reg) & (1<<PUP_LOCK_RESULT_BIT)) >> PUP_LOCK_RESULT_BIT)
  21. #define EDGE_FAILURE 128
  22. #define ALL_BITS_PER_PUP 128
  23. #define MIN_WINDOW_SIZE 6
  24. #define MAX_WINDOW_SIZE_RX 32
  25. #define MAX_WINDOW_SIZE_TX 64
  26. int ddr3_tip_training_ip_test(u32 dev_num, enum hws_training_result result_type,
  27. enum hws_search_dir search_dir,
  28. enum hws_dir direction,
  29. enum hws_edge_compare edge,
  30. u32 init_val1, u32 init_val2,
  31. u32 num_of_iterations, u32 start_pattern,
  32. u32 end_pattern);
  33. int ddr3_tip_load_pattern_to_mem(u32 dev_num, enum hws_pattern pattern);
  34. int ddr3_tip_load_pattern_to_mem_by_cpu(u32 dev_num, enum hws_pattern pattern,
  35. u32 offset);
  36. int ddr3_tip_load_all_pattern_to_mem(u32 dev_num);
  37. int ddr3_tip_read_training_result(u32 dev_num, u32 if_id,
  38. enum hws_access_type pup_access_type,
  39. u32 pup_num, u32 bit_num,
  40. enum hws_search_dir search,
  41. enum hws_dir direction,
  42. enum hws_training_result result_type,
  43. enum hws_training_load_op operation,
  44. u32 cs_num_type, u32 **load_res,
  45. int is_read_from_db, u8 cons_tap,
  46. int is_check_result_validity);
  47. int ddr3_tip_ip_training(u32 dev_num, enum hws_access_type access_type,
  48. u32 interface_num,
  49. enum hws_access_type pup_access_type,
  50. u32 pup_num, enum hws_training_result result_type,
  51. enum hws_control_element control_element,
  52. enum hws_search_dir search_dir, enum hws_dir direction,
  53. u32 interface_mask, u32 init_value, u32 num_iter,
  54. enum hws_pattern pattern,
  55. enum hws_edge_compare edge_comp,
  56. enum hws_ddr_cs cs_type, u32 cs_num,
  57. enum hws_training_ip_stat *train_status);
  58. int ddr3_tip_ip_training_wrapper(u32 dev_num, enum hws_access_type access_type,
  59. u32 if_id,
  60. enum hws_access_type pup_access_type,
  61. u32 pup_num,
  62. enum hws_training_result result_type,
  63. enum hws_control_element control_element,
  64. enum hws_search_dir search_dir,
  65. enum hws_dir direction,
  66. u32 interface_mask, u32 init_value1,
  67. u32 init_value2, u32 num_iter,
  68. enum hws_pattern pattern,
  69. enum hws_edge_compare edge_comp,
  70. enum hws_ddr_cs train_cs_type, u32 cs_num,
  71. enum hws_training_ip_stat *train_status);
  72. int is_odpg_access_done(u32 dev_num, u32 if_id);
  73. void ddr3_tip_print_bist_res(void);
  74. struct pattern_info *ddr3_tip_get_pattern_table(void);
  75. u16 *ddr3_tip_get_mask_results_dq_reg(void);
  76. u16 *ddr3_tip_get_mask_results_pup_reg_map(void);
  77. #endif /* _DDR3_TRAINING_IP_ENGINE_H_ */