| /* SPDX-License-Identifier: GPL-2.0-or-later */ |
| |
| #ifndef DEVICE_DRAM_COMMON_H |
| #define DEVICE_DRAM_COMMON_H |
| |
| #include <console/console.h> |
| #include <stdint.h> |
| |
| /** |
| * \brief Convenience definitions for TCK values |
| * |
| * Different values for tCK, representing standard DDR3 frequencies. |
| * These values are in 1/256 ns units. |
| * @{ |
| */ |
| #define NS2MHZ_DIV256 (1000 << 8) |
| |
| #define TCK_1333MHZ 192 |
| #define TCK_1200MHZ 212 |
| #define TCK_1100MHZ 232 |
| #define TCK_1066MHZ 240 |
| #define TCK_1000MHZ 256 |
| #define TCK_933MHZ 274 |
| #define TCK_900MHZ 284 |
| #define TCK_800MHZ 320 |
| #define TCK_700MHZ 365 |
| #define TCK_666MHZ 384 |
| #define TCK_533MHZ 480 |
| #define TCK_400MHZ 640 |
| #define TCK_333MHZ 768 |
| #define TCK_266MHZ 960 |
| #define TCK_200MHZ 1280 |
| /** @} */ |
| |
| /** |
| * \brief Convenience macro for enabling printk with CONFIG(DEBUG_RAM_SETUP) |
| * |
| * Use this macro instead of printk(); for verbose RAM initialization messages. |
| * When CONFIG(DEBUG_RAM_SETUP) is not selected, these messages are automatically |
| * disabled. |
| * @{ |
| */ |
| #define printram(x, ...) \ |
| do { \ |
| if (CONFIG(DEBUG_RAM_SETUP)) \ |
| printk(BIOS_DEBUG, x, ##__VA_ARGS__); \ |
| } while (0) |
| /** @} */ |
| |
| /** Result of the SPD decoding process */ |
| enum spd_status { |
| SPD_STATUS_OK = 0, |
| SPD_STATUS_INVALID, |
| SPD_STATUS_CRC_ERROR, |
| SPD_STATUS_INVALID_FIELD, |
| }; |
| |
| u16 ddr_crc16(const u8 *ptr, int n_crc); |
| |
| #endif /* DEVICE_DRAM_COMMON_H */ |