⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 codec.c

📁 u-boot-1.1.6 源码包
💻 C
📖 第 1 页 / 共 3 页
字号:
	cmd[1] = regno;	cmd[2] = (unsigned char)(val >> 8);	cmd[3] = (unsigned char)val;	codsp_send(duslic_id, cmd, 4, 0, 0);}void codsp_write_sop_int(int duslic_id, int channel, unsigned char regno, unsigned int val){	unsigned char cmd[5];	cmd[0] = CODSP_WR | CODSP_ADR(channel) | CODSP_CMD_SOP;	cmd[1] = regno;	cmd[2] = (unsigned char)(val >> 24);	cmd[3] = (unsigned char)(val >> 16);	cmd[4] = (unsigned char)(val >> 8);	cmd[5] = (unsigned char)val;	codsp_send(duslic_id, cmd, 6, 0, 0);}unsigned char codsp_read_sop_char(int duslic_id, int channel, unsigned char regno){	unsigned char cmd[3];	unsigned char res[2];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_SOP;	cmd[1] = regno;	codsp_send(duslic_id, cmd, 2, res, 2);	return res[1];}unsigned short codsp_read_sop_short(int duslic_id, int channel, unsigned char regno){	unsigned char cmd[2];	unsigned char res[3];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_SOP;	cmd[1] = regno;	codsp_send(duslic_id, cmd, 2, res, 3);	return ((unsigned short)res[1] << 8) | res[2];}unsigned int codsp_read_sop_int(int duslic_id, int channel, unsigned char regno){	unsigned char cmd[2];	unsigned char res[5];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_SOP;	cmd[1] = regno;	codsp_send(duslic_id, cmd, 2, res, 5);	return ((unsigned int)res[1] << 24) | ((unsigned int)res[2] << 16) | ((unsigned int)res[3] << 8) | res[4];}/****************************************************************************/void codsp_write_cop_block(int duslic_id, int channel, unsigned char addr, const unsigned char *block){	unsigned char cmd[10];	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	memcpy(cmd + 2, block, 8);	codsp_send(duslic_id, cmd, 10, 0, 0);}void codsp_write_cop_char(int duslic_id, int channel, unsigned char addr, unsigned char val){	unsigned char cmd[3];	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	cmd[2] = val;	codsp_send(duslic_id, cmd, 3, 0, 0);}void codsp_write_cop_short(int duslic_id, int channel, unsigned char addr, unsigned short val){	unsigned char cmd[3];	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	cmd[2] = (unsigned char)(val >> 8);	cmd[3] = (unsigned char)val;	codsp_send(duslic_id, cmd, 4, 0, 0);}void codsp_read_cop_block(int duslic_id, int channel, unsigned char addr, unsigned char *block){	unsigned char cmd[2];	unsigned char res[9];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	codsp_send(duslic_id, cmd, 2, res, 9);	memcpy(block, res + 1, 8);}unsigned char codsp_read_cop_char(int duslic_id, int channel, unsigned char addr){	unsigned char cmd[2];	unsigned char res[2];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	codsp_send(duslic_id, cmd, 2, res, 2);	return res[1];}unsigned short codsp_read_cop_short(int duslic_id, int channel, unsigned char addr){	unsigned char cmd[2];	unsigned char res[3];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR(channel) | CODSP_CMD_COP;	cmd[1] = addr;	codsp_send(duslic_id, cmd, 2, res, 3);	return ((unsigned short)res[1] << 8) | res[2];}/****************************************************************************/#define MAX_POP_BLOCK	50void codsp_write_pop_block (int duslic_id, int channel, unsigned char addr,			    const unsigned char *block, int len){	unsigned char cmd[2 + MAX_POP_BLOCK];	if (len > MAX_POP_BLOCK)	/* truncate */		len = MAX_POP_BLOCK;	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = addr;	memcpy (cmd + 2, block, len);	codsp_send (duslic_id, cmd, 2 + len, 0, 0);}void codsp_write_pop_char (int duslic_id, int channel, unsigned char regno,			   unsigned char val){	unsigned char cmd[3];	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	cmd[2] = val;	codsp_send (duslic_id, cmd, 3, 0, 0);}void codsp_write_pop_short (int duslic_id, int channel, unsigned char regno,			    unsigned short val){	unsigned char cmd[4];	cmd[0] = CODSP_WR | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	cmd[2] = (unsigned char) (val >> 8);	cmd[3] = (unsigned char) val;	codsp_send (duslic_id, cmd, 4, 0, 0);}void codsp_write_pop_int (int duslic_id, int channel, unsigned char regno,			  unsigned int val){	unsigned char cmd[5];	cmd[0] = CODSP_WR | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	cmd[2] = (unsigned char) (val >> 24);	cmd[3] = (unsigned char) (val >> 16);	cmd[4] = (unsigned char) (val >> 8);	cmd[5] = (unsigned char) val;	codsp_send (duslic_id, cmd, 6, 0, 0);}unsigned char codsp_read_pop_char (int duslic_id, int channel,				   unsigned char regno){	unsigned char cmd[3];	unsigned char res[2];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	codsp_send (duslic_id, cmd, 2, res, 2);	return res[1];}unsigned short codsp_read_pop_short (int duslic_id, int channel,				     unsigned char regno){	unsigned char cmd[2];	unsigned char res[3];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	codsp_send (duslic_id, cmd, 2, res, 3);	return ((unsigned short) res[1] << 8) | res[2];}unsigned int codsp_read_pop_int (int duslic_id, int channel,				 unsigned char regno){	unsigned char cmd[2];	unsigned char res[5];	cmd[0] = CODSP_RD | CODSP_OP | CODSP_ADR (channel) | CODSP_CMD_POP;	cmd[1] = regno;	codsp_send (duslic_id, cmd, 2, res, 5);	return (((unsigned int) res[1] << 24) |		((unsigned int) res[2] << 16) |		((unsigned int) res[3] <<  8) |		res[4] );}/****************************************************************************/struct _coeffs {	unsigned char addr;	unsigned char values[8];};struct _coeffs ac_coeffs[11] = {	{ 0x60, {0xAD,0xDA,0xB5,0x9B,0xC7,0x2A,0x9D,0x00} }, /* 0x60 IM-Filter part 1 */	{ 0x68, {0x10,0x00,0xA9,0x82,0x0D,0x77,0x0A,0x00} }, /* 0x68 IM-Filter part 2 */	{ 0x18, {0x08,0xC0,0xD2,0xAB,0xA5,0xE2,0xAB,0x07} }, /* 0x18 FRR-Filter	      */	{ 0x28, {0x44,0x93,0xF5,0x92,0x88,0x00,0x00,0x00} }, /* 0x28 AR-Filter	      */	{ 0x48, {0x96,0x38,0x29,0x96,0xC9,0x2B,0x8B,0x00} }, /* 0x48 LPR-Filter	      */	{ 0x20, {0x08,0xB0,0xDA,0x9D,0xA7,0xFA,0x93,0x06} }, /* 0x20 FRX-Filter	      */	{ 0x30, {0xBA,0xAC,0x00,0x01,0x85,0x50,0xC0,0x1A} }, /* 0x30 AX-Filter	      */	{ 0x50, {0x96,0x38,0x29,0xF5,0xFA,0x2B,0x8B,0x00} }, /* 0x50 LPX-Filter	      */	{ 0x00, {0x00,0x08,0x08,0x81,0x00,0x80,0x00,0x08} }, /* 0x00 TH-Filter part 1 */	{ 0x08, {0x81,0x00,0x80,0x00,0xD7,0x33,0xBA,0x01} }, /* 0x08 TH-Filter part 2 */	{ 0x10, {0xB3,0x6C,0xDC,0xA3,0xA4,0xE5,0x88,0x00} }  /* 0x10 TH-Filter part 3 */};struct _coeffs ac_coeffs_0dB[11] = {	{ 0x60, {0xAC,0x2A,0xB5,0x9A,0xB7,0x2A,0x9D,0x00} },	{ 0x68, {0x10,0x00,0xA9,0x82,0x0D,0x83,0x0A,0x00} },	{ 0x18, {0x08,0x20,0xD4,0xA4,0x65,0xEE,0x92,0x07} },	{ 0x28, {0x2B,0xAB,0x36,0xA5,0x88,0x00,0x00,0x00} },	{ 0x48, {0xAB,0xE9,0x4E,0x32,0xAB,0x25,0xA5,0x03} },	{ 0x20, {0x08,0x20,0xDB,0x9C,0xA7,0xFA,0xB4,0x07} },	{ 0x30, {0xF3,0x10,0x07,0x60,0x85,0x40,0xC0,0x1A} },	{ 0x50, {0x96,0x38,0x29,0x97,0x39,0x19,0x8B,0x00} },	{ 0x00, {0x00,0x08,0x08,0x81,0x00,0x80,0x00,0x08} },	{ 0x08, {0x81,0x00,0x80,0x00,0x47,0x3C,0xD2,0x01} },	{ 0x10, {0x62,0xDB,0x4A,0x87,0x73,0x28,0x88,0x00} }};struct _coeffs dc_coeffs[9] = {	{ 0x80, {0x25,0x59,0x9C,0x23,0x24,0x23,0x32,0x1C} }, /* 0x80 DC-Parameter     */	{ 0x70, {0x90,0x30,0x1B,0xC0,0x33,0x43,0xAC,0x02} }, /* 0x70 Ringing	      */	{ 0x90, {0x3F,0xC3,0x2E,0x3A,0x80,0x90,0x00,0x09} }, /* 0x90 LP-Filters	      */	{ 0x88, {0xAF,0x80,0x27,0x7B,0x01,0x4C,0x7B,0x02} }, /* 0x88 Hook Levels      */	{ 0x78, {0x00,0xC0,0x6D,0x7A,0xB3,0x78,0x89,0x00} }, /* 0x78 Ramp Generator   */	{ 0x58, {0xA5,0x44,0x34,0xDB,0x0E,0xA2,0x2A,0x00} }, /* 0x58 TTX	      */	{ 0x38, {0x33,0x49,0x9A,0x65,0xBB,0x00,0x00,0x00} }, /* 0x38 TG1	      */	{ 0x40, {0x33,0x49,0x9A,0x65,0xBB,0x00,0x00,0x00} }, /* 0x40 TG2	      */	{ 0x98, {0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00} }  /* 0x98 Reserved	      */};void program_coeffs(int duslic_id, int channel, struct _coeffs *coeffs, int tab_size){	int i;	for (i = 0; i < tab_size; i++)	codsp_write_cop_block(duslic_id, channel, coeffs[i].addr, coeffs[i].values);}#define SS_OPEN_CIRCUIT			0#define SS_RING_PAUSE			1#define SS_ACTIVE			2#define SS_ACTIVE_HIGH			3#define SS_ACTIVE_RING			4#define SS_RINGING			5#define SS_ACTIVE_WITH_METERING		6#define SS_ONHOOKTRNSM			7#define SS_STANDBY			8#define SS_MAX				8static void codsp_set_slic(int duslic_id, int channel, int state){	unsigned char v;	v = codsp_read_sop_char(duslic_id, channel, BCR1_ADDR);	switch (state) {		case SS_ACTIVE:			codsp_write_sop_char(duslic_id, channel, BCR1_ADDR, (v & ~BCR1_ACTR) | BCR1_ACTL);			codsp_set_ciop_m(duslic_id, channel, CODSP_M_ANY_ACT);			break;		case SS_ACTIVE_HIGH:			codsp_write_sop_char(duslic_id, channel, BCR1_ADDR, v & ~(BCR1_ACTR | BCR1_ACTL));			codsp_set_ciop_m(duslic_id, channel, CODSP_M_ANY_ACT);			break;		case SS_ACTIVE_RING:		case SS_ONHOOKTRNSM:			codsp_write_sop_char(duslic_id, channel, BCR1_ADDR, (v & ~BCR1_ACTL) | BCR1_ACTR);			codsp_set_ciop_m(duslic_id, channel, CODSP_M_ANY_ACT);			break;		case SS_STANDBY:			codsp_write_sop_char(duslic_id, channel, BCR1_ADDR, v & ~(BCR1_ACTL | BCR1_ACTR));			codsp_set_ciop_m(duslic_id, channel, CODSP_M_SLEEP_PWRDN);			break;		case SS_OPEN_CIRCUIT:			codsp_set_ciop_m(duslic_id, channel, CODSP_M_PWRDN_HIZ);			break;		case SS_RINGING:			codsp_set_ciop_m(duslic_id, channel, CODSP_M_RING);			break;		case SS_RING_PAUSE:			codsp_set_ciop_m(duslic_id, channel, CODSP_M_RING_PAUSE);			break;	}}const unsigned char Ring_Sin_28Vrms_25Hz[8] = { 0x90, 0x30, 0x1B, 0xC0, 0xC3, 0x9C, 0x88, 0x00 };const unsigned char Max_HookRingTh[3] = { 0x7B, 0x41, 0x62 };void retrieve_slic_state(int slic_id){	int duslic_id = slic_id >> 1;	int channel = slic_id & 1;	/* Retrieve the state of the SLICs */	codsp_write_sop_char(duslic_id, channel, LMCR2_ADDR, 0x00);	/* wait at least 1000us to clear the LM_OK and 500us to set the LM_OK ==> for the LM to make the first Measurement */	udelay(10000);	codsp_write_sop_char(duslic_id, channel, LMCR1_ADDR, LMCR1_LM_THM | LMCR1_LM_MASK);	codsp_set_slic(duslic_id, channel, SS_ACTIVE_HIGH);	codsp_write_sop_char(duslic_id, channel, LMCR3_ADDR, 0x40);	/* Program Default Hook Ring thresholds */	codsp_write_cop_block(duslic_id, channel, dc_coeffs[1].addr, dc_coeffs[1].values);	/* Now program Hook Threshold while Ring and ac RingTrip to max values */	codsp_write_cop_block(duslic_id, channel, dc_coeffs[3].addr, dc_coeffs[3].values);	codsp_write_sop_short(duslic_id, channel, OFR1_ADDR, 0x0000);	udelay(40000);}int wait_level_metering_finish(int duslic_id, int channel){	int cnt;	for (cnt = 0; cnt < 1000 &&		(codsp_read_sop_char(duslic_id, channel, INTREG2_ADDR) & LM_OK_SRC_IRG_2) == 0; cnt++) { }	return cnt != 1000;}int measure_on_hook_voltages(int slic_id, long *vdd,		long *v_oh_H, long *v_oh_L, long *ring_mean_v, long *ring_rms_v){	short LM_Result, Offset_Compensation;	/* Signed 16 bit */	long int VDD, VDD_diff, V_in, V_out, Divider_Ratio, Vout_diff ;	unsigned char err_mask = 0;	int duslic_id = slic_id >> 1;	int channel = slic_id & 1;	int i;	/* measure VDD */	/* Now select the VDD level Measurement (but first of all Hold the DC characteristic) */	codsp_write_sop_char(duslic_id, channel, TSTR5_ADDR, TSTR5_DC_HOLD);	/* Activate Test Mode ==> To Enable DC Hold !!! */	/* (else the LMRES is treated as Feeding Current and the Feeding voltage changes */	/* imediatelly (after 500us when the LMRES Registers is updated for the first time after selection of (IO4-IO3) measurement !!!!))*/	codsp_write_sop_char(duslic_id, channel, LMCR1_ADDR, LMCR1_TEST_EN | LMCR1_LM_THM | LMCR1_LM_MASK);	udelay(40000);	/* Now I Can select what to measure by DC Level Meter (select IO4-IO3) */	codsp_write_sop_char(duslic_id, channel, LMCR2_ADDR, LMCR2_LM_SEL_VDD);	/* wait at least 1000us to clear the LM_OK and 500us to set the LM_OK ==> for the LM to make the first Measurement */	udelay(10000);	/* Now Read the LM Result Registers */	LM_Result = codsp_read_sop_short(duslic_id, channel, LMRES1_ADDR);	VDD = (-1)*((((long int)LM_Result) * 390L ) >> 15) ;	/* VDDx100 */	*vdd = VDD;	VDD_diff = VDD - TARGET_VDDx100;	if (VDD_diff < 0)		VDD_diff = -VDD_diff;	if (VDD_diff > VDD_MAX_DIFFx100)		err_mask |= 1;	Divider_Ratio = TARGET_V_DIVIDER_RATIO_x100;	codsp_write_sop_char(duslic_id, channel, LMCR2_ADDR, 0x00);	codsp_write_sop_char(duslic_id, channel, LMCR1_ADDR, LMCR1_LM_THM | LMCR1_LM_MASK);	codsp_set_slic(duslic_id, channel, SS_ACTIVE_HIGH); /* Go back to ONHOOK Voltage */	udelay(40000);	codsp_write_sop_char(duslic_id, channel,		LMCR1_ADDR, LMCR1_TEST_EN | LMCR1_LM_THM | LMCR1_LM_MASK);	udelay(40000);	/* Now I Can select what to measure by DC Level Meter (select IO4-IO3) */	codsp_write_sop_char(duslic_id, channel, LMCR2_ADDR, LMCR2_LM_SEL_IO4_MINUS_IO3);	/* wait at least 1000us to clear the LM_OK and 500us to set the LM_OK ==> for the LM to make the first Measurement */	udelay(10000);	/* Now Read the LM Result Registers */	LM_Result = codsp_read_sop_short(duslic_id, channel, LMRES1_ADDR);	V_in = (-1)* ((((long int)LM_Result) * V_AD_x10000 ) >> 15) ;  /* Vin x 10000*/	V_out = (V_in * Divider_Ratio) / 10000L ;	/* Vout x100 */	*v_oh_H = V_out;	Vout_diff = V_out - TARGET_ONHOOK_BATH_x100;	if (Vout_diff < 0)		Vout_diff = -Vout_diff;	if (Vout_diff > V_OUT_BATH_MAX_DIFFx100)		err_mask |= 2;	codsp_set_slic(duslic_id, channel, SS_ACTIVE); /* Go back to ONHOOK Voltage */	udelay(40000);	/* Now Read the LM Result Registers */	LM_Result = codsp_read_sop_short(duslic_id, channel, LMRES1_ADDR);	V_in = (-1)* ((((long int)LM_Result) * V_AD_x10000 ) >> 15) ;  /* Vin x 10000*/	V_out = (V_in * Divider_Ratio) / 10000L ;	/* Vout x100 */	*v_oh_L = V_out;	Vout_diff = V_out - TARGET_ONHOOK_BATL_x100;	if (Vout_diff < 0)		Vout_diff = -Vout_diff;	if (Vout_diff > V_OUT_BATL_MAX_DIFFx100)		err_mask |= 4;	/* perform ring tests */	codsp_write_sop_char(duslic_id, channel, LMCR2_ADDR, 0x00);	codsp_write_sop_char(duslic_id, channel, LMCR1_ADDR, LMCR1_LM_THM | LMCR1_LM_MASK);	udelay(40000);	codsp_write_sop_char(duslic_id, channel, LMCR3_ADDR, LMCR3_RTR_SEL | LMCR3_RNG_OFFSET_NONE);	/* Now program RO1 =0V , Ring Amplitude and frequency and shift factor K = 1 (LMDC=0x0088)*/	codsp_write_cop_block(duslic_id, channel, RING_PARAMS_START_ADDR, Ring_Sin_28Vrms_25Hz);	/* By Default RO1 is selected when ringing RNG-OFFSET = 00 */	/* Now program Hook Threshold while Ring and ac RingTrip to max values */	for(i = 0; i < sizeof(Max_HookRingTh); i++)		codsp_write_cop_char(duslic_id, channel, HOOK_THRESH_RING_START_ADDR + i, Max_HookRingTh[i]);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -