mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 18:18:19 +01:00 
			
		
		
		
	This syncs drivers/ddr/marvell/a38x/ with the mv_ddr-armada-18.09 branch of https://github.com/MarvellEmbeddedProcessors/mv-ddr-marvell.git. Specifically this syncs with commit 99d772547314 ("Bump mv_ddr to release armada-18.09.2"). The complete log of changes is best obtained from the mv-ddr-marvell.git repository but some relevant highlights are: ddr3: add missing txsdll parameter ddr3: fix tfaw timimg parameter ddr3: fix trrd timimg parameter merge ddr3 topology header file with mv_ddr_topology one mv_ddr: a38x: fix zero memory size scrubbing issue The upstream code is incorporated omitting the portions not relevant to Armada-38x and DDR3. After that a semi-automated step is used to drop unused features with unifdef find drivers/ddr/marvell/a38x/ -name '*.[ch]' | \ xargs unifdef -m -UMV_DDR -UMV_DDR_ATF -UCONFIG_DDR4 \ -UCONFIG_APN806 -UCONFIG_MC_STATIC \ -UCONFIG_MC_STATIC_PRINT -UCONFIG_PHY_STATIC \ -UCONFIG_64BIT -UCONFIG_A3700 -UA3900 -UA80X0 \ -UA70X0 Signed-off-by: Chris Packham <judge.packham@gmail.com> Reviewed-by: Stefan Roese <sr@denx.de> Tested-by: Baruch Siach <baruch@tkos.co.il> Signed-off-by: Stefan Roese <sr@denx.de>
		
			
				
	
	
		
			87 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * Copyright (C) Marvell International Ltd. and its affiliates
 | |
|  */
 | |
| 
 | |
| #ifndef _DDR3_TRAINING_IP_ENGINE_H_
 | |
| #define _DDR3_TRAINING_IP_ENGINE_H_
 | |
| 
 | |
| #include "ddr3_training_ip_def.h"
 | |
| #include "ddr3_training_ip_flow.h"
 | |
| #include "ddr3_training_ip_pbs.h"
 | |
| 
 | |
| #define EDGE_1				0
 | |
| #define EDGE_2				1
 | |
| #define ALL_PUP_TRAINING		0xe
 | |
| #define PUP_RESULT_EDGE_1_MASK		0xff
 | |
| #define PUP_RESULT_EDGE_2_MASK		(0xff << 8)
 | |
| #define PUP_LOCK_RESULT_BIT		25
 | |
| 
 | |
| #define GET_TAP_RESULT(reg, edge)				 \
 | |
| 	(((edge) == EDGE_1) ? ((reg) & PUP_RESULT_EDGE_1_MASK) : \
 | |
| 	 (((reg) & PUP_RESULT_EDGE_2_MASK) >> 8));
 | |
| #define GET_LOCK_RESULT(reg)						\
 | |
| 	(((reg) & (1<<PUP_LOCK_RESULT_BIT)) >> PUP_LOCK_RESULT_BIT)
 | |
| 
 | |
| #define EDGE_FAILURE			128
 | |
| #define ALL_BITS_PER_PUP		128
 | |
| 
 | |
| #define MIN_WINDOW_SIZE			6
 | |
| #define MAX_WINDOW_SIZE_RX		32
 | |
| #define MAX_WINDOW_SIZE_TX		64
 | |
| 
 | |
| int ddr3_tip_training_ip_test(u32 dev_num, enum hws_training_result result_type,
 | |
| 			      enum hws_search_dir search_dir,
 | |
| 			      enum hws_dir direction,
 | |
| 			      enum hws_edge_compare edge,
 | |
| 			      u32 init_val1, u32 init_val2,
 | |
| 			      u32 num_of_iterations, u32 start_pattern,
 | |
| 			      u32 end_pattern);
 | |
| int ddr3_tip_load_pattern_to_mem(u32 dev_num, enum hws_pattern pattern);
 | |
| int ddr3_tip_load_all_pattern_to_mem(u32 dev_num);
 | |
| int ddr3_tip_read_training_result(u32 dev_num, u32 if_id,
 | |
| 				  enum hws_access_type pup_access_type,
 | |
| 				  u32 pup_num, u32 bit_num,
 | |
| 				  enum hws_search_dir search,
 | |
| 				  enum hws_dir direction,
 | |
| 				  enum hws_training_result result_type,
 | |
| 				  enum hws_training_load_op operation,
 | |
| 				  u32 cs_num_type, u32 **load_res,
 | |
| 				  int is_read_from_db, u8 cons_tap,
 | |
| 				  int is_check_result_validity);
 | |
| int ddr3_tip_ip_training(u32 dev_num, enum hws_access_type access_type,
 | |
| 			 u32 interface_num,
 | |
| 			 enum hws_access_type pup_access_type,
 | |
| 			 u32 pup_num, enum hws_training_result result_type,
 | |
| 			 enum hws_control_element control_element,
 | |
| 			 enum hws_search_dir search_dir, enum hws_dir direction,
 | |
| 			 u32 interface_mask, u32 init_value, u32 num_iter,
 | |
| 			 enum hws_pattern pattern,
 | |
| 			 enum hws_edge_compare edge_comp,
 | |
| 			 enum hws_ddr_cs cs_type, u32 cs_num,
 | |
| 			 enum hws_training_ip_stat *train_status);
 | |
| int ddr3_tip_ip_training_wrapper(u32 dev_num, enum hws_access_type access_type,
 | |
| 				 u32 if_id,
 | |
| 				 enum hws_access_type pup_access_type,
 | |
| 				 u32 pup_num,
 | |
| 				 enum hws_training_result result_type,
 | |
| 				 enum hws_control_element control_element,
 | |
| 				 enum hws_search_dir search_dir,
 | |
| 				 enum hws_dir direction,
 | |
| 				 u32 interface_mask, u32 init_value1,
 | |
| 				 u32 init_value2, u32 num_iter,
 | |
| 				 enum hws_pattern pattern,
 | |
| 				 enum hws_edge_compare edge_comp,
 | |
| 				 enum hws_ddr_cs train_cs_type, u32 cs_num,
 | |
| 				 enum hws_training_ip_stat *train_status);
 | |
| u8 mv_ddr_tip_sub_phy_byte_status_get(u32 if_id, u32 subphy_id);
 | |
| void mv_ddr_tip_sub_phy_byte_status_set(u32 if_id, u32 subphy_id, u8 byte_status_data);
 | |
| void ddr3_tip_print_bist_res(void);
 | |
| struct pattern_info *ddr3_tip_get_pattern_table(void);
 | |
| u16 *ddr3_tip_get_mask_results_dq_reg(void);
 | |
| u16 *ddr3_tip_get_mask_results_pup_reg_map(void);
 | |
| int mv_ddr_load_dm_pattern_to_odpg(enum hws_access_type access_type, enum hws_pattern pattern,
 | |
| 				   enum dm_direction dm_dir);
 | |
| int mv_ddr_pattern_start_addr_set(struct pattern_info *pattern_tbl, enum hws_pattern pattern, u32 addr);
 | |
| #endif /* _DDR3_TRAINING_IP_ENGINE_H_ */
 |