| /* SPDX-License-Identifier: Intel */ |
| /* |
| * Copyright (C) 2013, Intel Corporation |
| * Copyright (C) 2015, Bin Meng <bmeng.cn@gmail.com> |
| * |
| * Ported from Intel released Quark UEFI BIOS |
| * QuarkSocPkg/QuarkNorthCluster/MemoryInit/Pei |
| */ |
| |
| #ifndef _MRC_UTIL_H_ |
| #define _MRC_UTIL_H_ |
| |
| /* Turn on this macro to enable MRC debugging output */ |
| #undef MRC_DEBUG |
| |
| /* MRC Debug Support */ |
| #define DPF debug_cond |
| |
| /* debug print type */ |
| |
| #ifdef MRC_DEBUG |
| #define D_ERROR 0x0001 |
| #define D_INFO 0x0002 |
| #define D_REGRD 0x0004 |
| #define D_REGWR 0x0008 |
| #define D_FCALL 0x0010 |
| #define D_TRN 0x0020 |
| #define D_TIME 0x0040 |
| #else |
| #define D_ERROR 0 |
| #define D_INFO 0 |
| #define D_REGRD 0 |
| #define D_REGWR 0 |
| #define D_FCALL 0 |
| #define D_TRN 0 |
| #define D_TIME 0 |
| #endif |
| |
| #define ENTERFN(...) debug_cond(D_FCALL, "<%s>\n", __func__) |
| #define LEAVEFN(...) debug_cond(D_FCALL, "</%s>\n", __func__) |
| #define REPORTFN(...) debug_cond(D_FCALL, "<%s/>\n", __func__) |
| |
| /* Message Bus Port */ |
| #define MEM_CTLR 0x01 |
| #define HOST_BRIDGE 0x03 |
| #define MEM_MGR 0x05 |
| #define HTE 0x11 |
| #define DDRPHY 0x12 |
| |
| /* number of sample points */ |
| #define SAMPLE_CNT 3 |
| /* number of PIs to increment per sample */ |
| #define SAMPLE_DLY 26 |
| |
| enum { |
| /* indicates to decrease delays when looking for edge */ |
| BACKWARD, |
| /* indicates to increase delays when looking for edge */ |
| FORWARD |
| }; |
| |
| enum { |
| RCVN, |
| WDQS, |
| WDQX, |
| RDQS, |
| VREF, |
| WCMD, |
| WCTL, |
| WCLK, |
| MAX_ALGOS, |
| }; |
| |
| void mrc_write_mask(u32 unit, u32 addr, u32 data, u32 mask); |
| void mrc_alt_write_mask(u32 unit, u32 addr, u32 data, u32 mask); |
| void mrc_post_code(uint8_t major, uint8_t minor); |
| void delay_n(uint32_t ns); |
| void delay_u(uint32_t ms); |
| void select_mem_mgr(void); |
| void select_hte(void); |
| void dram_init_command(uint32_t data); |
| void dram_wake_command(void); |
| void training_message(uint8_t channel, uint8_t rank, uint8_t byte_lane); |
| |
| void set_rcvn(uint8_t channel, uint8_t rank, |
| uint8_t byte_lane, uint32_t pi_count); |
| uint32_t get_rcvn(uint8_t channel, uint8_t rank, uint8_t byte_lane); |
| void set_rdqs(uint8_t channel, uint8_t rank, |
| uint8_t byte_lane, uint32_t pi_count); |
| uint32_t get_rdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane); |
| void set_wdqs(uint8_t channel, uint8_t rank, |
| uint8_t byte_lane, uint32_t pi_count); |
| uint32_t get_wdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane); |
| void set_wdq(uint8_t channel, uint8_t rank, |
| uint8_t byte_lane, uint32_t pi_count); |
| uint32_t get_wdq(uint8_t channel, uint8_t rank, uint8_t byte_lane); |
| void set_wcmd(uint8_t channel, uint32_t pi_count); |
| uint32_t get_wcmd(uint8_t channel); |
| void set_wclk(uint8_t channel, uint8_t rank, uint32_t pi_count); |
| uint32_t get_wclk(uint8_t channel, uint8_t rank); |
| void set_wctl(uint8_t channel, uint8_t rank, uint32_t pi_count); |
| uint32_t get_wctl(uint8_t channel, uint8_t rank); |
| void set_vref(uint8_t channel, uint8_t byte_lane, uint32_t setting); |
| uint32_t get_vref(uint8_t channel, uint8_t byte_lane); |
| |
| uint32_t get_addr(uint8_t channel, uint8_t rank); |
| uint32_t sample_dqs(struct mrc_params *mrc_params, uint8_t channel, |
| uint8_t rank, bool rcvn); |
| void find_rising_edge(struct mrc_params *mrc_params, uint32_t delay[], |
| uint8_t channel, uint8_t rank, bool rcvn); |
| uint32_t byte_lane_mask(struct mrc_params *mrc_params); |
| uint32_t check_rw_coarse(struct mrc_params *mrc_params, uint32_t address); |
| uint32_t check_bls_ex(struct mrc_params *mrc_params, uint32_t address); |
| void lfsr32(uint32_t *lfsr_ptr); |
| void clear_pointers(void); |
| void print_timings(struct mrc_params *mrc_params); |
| |
| #endif /* _MRC_UTIL_H_ */ |