1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright (C) 2015 Marek Vasut <marex@denx.de> 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0+ 5*4882a593Smuzhiyun */ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #include <common.h> 8*4882a593Smuzhiyun #include <errno.h> 9*4882a593Smuzhiyun #include <asm/arch/clock_manager.h> 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun /* Board-specific header. */ 12*4882a593Smuzhiyun #include <qts/iocsr_config.h> 13*4882a593Smuzhiyun iocsr_get_config_table(const unsigned int chain_id,const unsigned long ** table,unsigned int * table_len)14*4882a593Smuzhiyunint iocsr_get_config_table(const unsigned int chain_id, 15*4882a593Smuzhiyun const unsigned long **table, 16*4882a593Smuzhiyun unsigned int *table_len) 17*4882a593Smuzhiyun { 18*4882a593Smuzhiyun switch (chain_id) { 19*4882a593Smuzhiyun case 0: 20*4882a593Smuzhiyun *table = iocsr_scan_chain0_table; 21*4882a593Smuzhiyun *table_len = CONFIG_HPS_IOCSR_SCANCHAIN0_LENGTH; 22*4882a593Smuzhiyun break; 23*4882a593Smuzhiyun case 1: 24*4882a593Smuzhiyun *table = iocsr_scan_chain1_table; 25*4882a593Smuzhiyun *table_len = CONFIG_HPS_IOCSR_SCANCHAIN1_LENGTH; 26*4882a593Smuzhiyun break; 27*4882a593Smuzhiyun case 2: 28*4882a593Smuzhiyun *table = iocsr_scan_chain2_table; 29*4882a593Smuzhiyun *table_len = CONFIG_HPS_IOCSR_SCANCHAIN2_LENGTH; 30*4882a593Smuzhiyun break; 31*4882a593Smuzhiyun case 3: 32*4882a593Smuzhiyun *table = iocsr_scan_chain3_table; 33*4882a593Smuzhiyun *table_len = CONFIG_HPS_IOCSR_SCANCHAIN3_LENGTH; 34*4882a593Smuzhiyun break; 35*4882a593Smuzhiyun default: 36*4882a593Smuzhiyun return -EINVAL; 37*4882a593Smuzhiyun } 38*4882a593Smuzhiyun 39*4882a593Smuzhiyun return 0; 40*4882a593Smuzhiyun } 41