]> git.proxmox.com Git - mirror_edk2.git/blame - QuarkSocPkg/QuarkNorthCluster/MemoryInit/Pei/meminit_utils.h
QuarkSocPkg: Replace BSD License with BSD+Patent License
[mirror_edk2.git] / QuarkSocPkg / QuarkNorthCluster / MemoryInit / Pei / meminit_utils.h
CommitLineData
9b6bbcdb
MK
1/************************************************************************\r
2 *\r
8e8cc688 3 * Copyright (c) 2013-2017 Intel Corporation.\r
9b6bbcdb 4 *\r
c9f231d0 5* SPDX-License-Identifier: BSD-2-Clause-Patent\r
9b6bbcdb
MK
6 *\r
7 ***************************************************************************/\r
8#ifndef _MEMINIT_UTILS_H_\r
9#define _MEMINIT_UTILS_H_\r
10\r
11// General Definitions:\r
12#ifdef QUICKSIM\r
13#define SAMPLE_SIZE 4 // reduce number of training samples in simulation env\r
14#else\r
15#define SAMPLE_SIZE 6 // must be odd number\r
16#endif\r
17\r
18#define EARLY_DB (0x12) // must be less than this number to enable early deadband\r
19#define LATE_DB (0x34) // must be greater than this number to enable late deadband\r
20#define CHX_REGS (11*4)\r
21#define FULL_CLK 128\r
22#define HALF_CLK 64\r
23#define QRTR_CLK 32\r
24\r
25\r
26\r
27#define MCEIL(num,den) ((uint8_t)((num+den-1)/den))\r
28#define MMAX(a,b) ((((int32_t)(a))>((int32_t)(b)))?(a):(b))\r
29#define MCOUNT(a) (sizeof(a)/sizeof(*a))\r
30\r
31typedef enum ALGOS_enum {\r
32 eRCVN = 0,\r
33 eWDQS,\r
34 eWDQx,\r
35 eRDQS,\r
36 eVREF,\r
37 eWCMD,\r
38 eWCTL,\r
39 eWCLK,\r
40 eMAX_ALGOS,\r
41} ALGOs_t;\r
42\r
43\r
44// Prototypes:\r
45void set_rcvn(uint8_t channel, uint8_t rank, uint8_t byte_lane, uint32_t pi_count);\r
46void set_rdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane, uint32_t pi_count);\r
47void set_wdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane, uint32_t pi_count);\r
48void set_wdq(uint8_t channel, uint8_t rank, uint8_t byte_lane, uint32_t pi_count);\r
49void set_wcmd(uint8_t channel, uint32_t pi_count);\r
50void set_wclk(uint8_t channel, uint8_t grp, uint32_t pi_count);\r
51void set_wctl(uint8_t channel, uint8_t rank, uint32_t pi_count);\r
52void set_vref(uint8_t channel, uint8_t byte_lane, uint32_t setting);\r
53uint32_t get_rcvn(uint8_t channel, uint8_t rank, uint8_t byte_lane);\r
54uint32_t get_rdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane);\r
55uint32_t get_wdqs(uint8_t channel, uint8_t rank, uint8_t byte_lane);\r
56uint32_t get_wdq(uint8_t channel, uint8_t rank, uint8_t byte_lane);\r
57uint32_t get_wcmd(uint8_t channel);\r
58uint32_t get_wclk(uint8_t channel, uint8_t group);\r
59uint32_t get_wctl(uint8_t channel, uint8_t rank);\r
60uint32_t get_vref(uint8_t channel, uint8_t byte_lane);\r
61\r
62void clear_pointers(void);\r
63void enable_cache(void);\r
64void disable_cache(void);\r
65void find_rising_edge(MRCParams_t *mrc_params, uint32_t delay[], uint8_t channel, uint8_t rank, bool rcvn);\r
66uint32_t sample_dqs(MRCParams_t *mrc_params, uint8_t channel, uint8_t rank, bool rcvn);\r
67uint32_t get_addr(MRCParams_t *mrc_params, uint8_t channel, uint8_t rank);\r
68uint32_t byte_lane_mask(MRCParams_t *mrc_params);\r
69\r
70uint64_t read_tsc(void);\r
71uint32_t get_tsc_freq(void);\r
72void delay_n(uint32_t nanoseconds);\r
73void delay_u(uint32_t microseconds);\r
74void delay_m(uint32_t milliseconds);\r
75void delay_s(uint32_t seconds);\r
76\r
77void post_code(uint8_t major, uint8_t minor);\r
78void training_message(uint8_t channel, uint8_t rank, uint8_t byte_lane);\r
79void print_timings(MRCParams_t *mrc_params);\r
80\r
81void enable_scrambling(MRCParams_t *mrc_params);\r
82void store_timings(MRCParams_t *mrc_params);\r
83void restore_timings(MRCParams_t *mrc_params);\r
84void default_timings(MRCParams_t *mrc_params);\r
85\r
86#ifndef SIM\r
8e8cc688
MK
87//\r
88// Map memset() and memcpy() to BaseMemoryLib functions\r
89//\r
90#include <Library/BaseMemoryLib.h>\r
91#define memset(d,c,n) ((c) == 0) ? ZeroMem ((d), (n)) : SetMem ((d), (n), (c))\r
92#define memcpy(d,s,n) CopyMem ((d), (s), (n))\r
9b6bbcdb
MK
93#endif\r
94\r
95#endif // _MEMINIT_UTILS_H_\r