mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-01-06 18:28:56 +00:00
41 lines
1 KiB
C
41 lines
1 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
/*
|
||
|
* Copyright (C) 2018 Marvell International Ltd.
|
||
|
*/
|
||
|
|
||
|
#ifndef _MV_DDR_TRAINING_DB_H
|
||
|
#define _MV_DDR_TRAINING_DB_H
|
||
|
|
||
|
#include "mv_ddr_topology.h"
|
||
|
|
||
|
/* in ns */
|
||
|
#define TREFI_LOW 7800
|
||
|
#define TREFI_HIGH 3900
|
||
|
|
||
|
enum mv_ddr_page_size {
|
||
|
MV_DDR_PAGE_SIZE_1K = 1,
|
||
|
MV_DDR_PAGE_SIZE_2K
|
||
|
};
|
||
|
|
||
|
struct mv_ddr_page_element {
|
||
|
/* 8-bit bus width page size */
|
||
|
enum mv_ddr_page_size page_size_8bit;
|
||
|
/* 16-bit bus width page size */
|
||
|
enum mv_ddr_page_size page_size_16bit;
|
||
|
};
|
||
|
|
||
|
/* cas latency value per frequency */
|
||
|
struct mv_ddr_cl_val_per_freq {
|
||
|
unsigned int cl_val[MV_DDR_FREQ_LAST];
|
||
|
};
|
||
|
|
||
|
u32 mv_ddr_rfc_get(u32 mem);
|
||
|
unsigned int *mv_ddr_freq_tbl_get(void);
|
||
|
u32 mv_ddr_freq_get(enum mv_ddr_freq freq);
|
||
|
u32 mv_ddr_page_size_get(enum mv_ddr_dev_width bus_width, enum mv_ddr_die_capacity mem_size);
|
||
|
unsigned int mv_ddr_speed_bin_timing_get(enum mv_ddr_speed_bin index, enum mv_ddr_speed_bin_timing element);
|
||
|
u32 mv_ddr_cl_val_get(u32 index, u32 freq);
|
||
|
u32 mv_ddr_cwl_val_get(u32 index, u32 freq);
|
||
|
|
||
|
#endif /* _MV_DDR_TRAINING_DB_H */
|