mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-11 13:56:30 +00:00
46 lines
1,013 B
C
46 lines
1,013 B
C
|
/* SPDX-License-Identifier: GPL-2.0+ */
|
||
|
/*
|
||
|
* ddrmc DDR3 calibration code for NXP's VF610
|
||
|
*
|
||
|
* Copyright (C) 2018 DENX Software Engineering
|
||
|
* Lukasz Majewski, DENX Software Engineering, lukma@denx.de
|
||
|
*
|
||
|
*/
|
||
|
|
||
|
#ifndef __DDRMC_VF610_CALIBRATOIN_H_
|
||
|
#define __DDRMC_VF610_CALIBRATOIN_H_
|
||
|
|
||
|
/*
|
||
|
* Number of "samples" in the calibration bitmap
|
||
|
* to be considered during calibration.
|
||
|
*/
|
||
|
#define N_SAMPLES 3
|
||
|
|
||
|
/*
|
||
|
* Constants to indicate if we are looking for a rising or
|
||
|
* falling edge in the calibration bitmap
|
||
|
*/
|
||
|
enum edge {
|
||
|
FALLING_EDGE = 1,
|
||
|
RISING_EDGE
|
||
|
};
|
||
|
|
||
|
/*
|
||
|
* The max number of delay elements when DQS to DQ setting
|
||
|
*/
|
||
|
#define DDRMC_DQS_DQ_MAX_DELAY 0xFF
|
||
|
|
||
|
/**
|
||
|
* ddrmc_calibration - Vybrid's (VF610) DDR3 calibration code
|
||
|
*
|
||
|
* This function is calculating proper memory controller values
|
||
|
* during run time.
|
||
|
*
|
||
|
* @param ddrmr_regs - memory controller registers
|
||
|
*
|
||
|
* @return 0 on success, otherwise error code
|
||
|
*/
|
||
|
int ddrmc_calibration(struct ddrmr_regs *ddrmr);
|
||
|
|
||
|
#endif /* __DDRMC_VF610_CALIBRATOIN_H_ */
|