hte.h 919 B

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /* SPDX-License-Identifier: Intel */
  2. /*
  3. * Copyright (C) 2013, Intel Corporation
  4. * Copyright (C) 2015, Bin Meng <bmeng.cn@gmail.com>
  5. *
  6. * Ported from Intel released Quark UEFI BIOS
  7. * QuarkSocPkg/QuarkNorthCluster/MemoryInit/Pei
  8. */
  9. #ifndef _HTE_H_
  10. #define _HTE_H_
  11. enum {
  12. MRC_MEM_INIT,
  13. MRC_MEM_TEST
  14. };
  15. enum {
  16. READ_TRAIN,
  17. WRITE_TRAIN
  18. };
  19. /*
  20. * EXP_LOOP_CNT field of HTE_CMD_CTL
  21. *
  22. * This CANNOT be less than 4!
  23. */
  24. #define HTE_LOOP_CNT 5
  25. /* random seed for victim */
  26. #define HTE_LFSR_VICTIM_SEED 0xf294ba21
  27. /* random seed for aggressor */
  28. #define HTE_LFSR_AGRESSOR_SEED 0xeba7492d
  29. u32 hte_mem_init(struct mrc_params *mrc_params, u8 flag);
  30. u16 hte_basic_write_read(struct mrc_params *mrc_params, u32 addr,
  31. u8 first_run, u8 mode);
  32. u16 hte_write_stress_bit_lanes(struct mrc_params *mrc_params,
  33. u32 addr, u8 first_run);
  34. void hte_mem_op(u32 addr, u8 first_run, u8 is_write);
  35. #endif /* _HTE_H_ */