0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

在DS上启用分数T1环回检测

星星科技指导员 来源:ADI 作者:ADI 2023-02-22 10:08 次阅读

本应用笔记介绍如何使用DS31256的接收BERT功能执行分数T1(FT1)环路或环路下降检测(V.54),如分数T1.403附录B规范中所述。工作算法和编码示例说明了DS31256易于适应终端用户应用。

DS31256只有一个BERT引擎,但有16个V.54引擎(每个端口一个)。因此,如果测试多个端口,软件带宽必须处理所需的多路复用。

算法

下面图 1 和图 2 中的流程图详细描述了环上和下环操作。假定只有端口 0 在查找 FT1 模式。基本算法设置 BERT 以查找环路模式。同步后,算法检查以确保BERT在可编程周期(代码中为0.6秒)内同步,然后查找全一模式。然后,对循环代码遵循相同的同步和检查方法,然后是 all one 模式。

尽管此示例使用 0.6s 作为确保 BERT 同步的时间段,但必须根据 sync_loop 函数的执行速度调整此时间段。

poYBAGP1eSKACaHAAABR_FvcsyQ850.gif

图1.FT1(环上环和环下)探测器操作流程图。

poYBAGP1eSOAezpaAAA5KoVnbL4182.gif

图2.FT1(环上环和环下)检测器操作流程图(续)。

编码示例函数调用的定义

poYBAGP1fUyAG5r3AABsLgLY7Ng470.png

函数的编码示例

测试 FT1 的功能

void FT1Test()
{
	int status = 0;
	
	FT1Setting(0, 0); 				-- Configure the device for BERT
status = sync_loop(1, 300, 5000); 		-- FT1 loop-up test
if(status == 1) 				-- Return status is synced
{
  	status = sync_loop(3, 300, 5000);	-- FT1 all ones test
  	if(status == 1)
  	{
   	loopbackSetup(1);			-- Place channelized in network loopback
	status = sync_loop(2, 300, 5000);	-- FT1 loop-down test
	
	if(status == 1)
   	     {
status = sync_loop(3, 300, 5000); 	-- FT1 all ones test
    		if(status == 1)
loopbackSetup(0);			-- Take out from channelized loopback 
    		else
checkstatus(3);			-- Print out test status
   	} 
	else 
	{
checkstatus(2);			-- Print out test status
	}
  	} 
else 
{
checkstatus(3);			-- Print out test status
  	}
} 
else 
{
  	checkstatus(1);				-- Print out test status
}
}

1. 打印测试状态消息的功能

void checkstatus(int type)
{
	switch(type)
 	{
 	case 1: printf("Loopup pattern not found");	
  		break;
 	case 2: printf("Loopdown pattern not found");
  		break;
 	case 3: printf("All 1's pattern not found");
  		break;
 	}
}

2. 配置FT1的功能

此示例假定端口 0 用于 FT1 检测

void FT1Setting(int dev, int port)
{
int mc = 0;						-- Variables to be used
int ds0 = 0;
int rcfg = 0;
	
mc = read_reg (0x10);				-- Read Master Control(MC) 0x00 register
mc = mc & 0xf07f;	-- Mask out the read-back value from MC 
write_reg (0x10, mc); 	-- Assign the BERT to port 0 (MC.BPS4-0) 

write_reg(0x0304, 0x4000); 	-- Configure port 0 in receive port 
for(ds0 = 0; ds0 < 128; ds0 = ds0 + 1) 		-- Configure register 
{							--Assign timeslot R[0]CFG[ds0].RBERT bit  
write_ind_reg(0x0300, 0x0100 + ds0);	-- Assign all 128 ds0’s to RBERT 
	}				
printf("FT1 configuration completed."); 
}

3. 执行FT1测试的功能

int sync_loop(int pattern, int sync_cnt, int timeout) 
{  
int timeCnt = 0; 					-- Variables will be used
int cnt = 0;
int status = 0;
int temp = 0;
int sync = 0; 
int bertc0 = 0; 
int bertec0 = 0;

BertSetup(pattern);					-- Set up the BERT

bertc0 = read_reg (0x500);				-- Toggle RESYNC
bertc0 = bertc0 | 0x0001;	-- Mask the read BERTC0 value 
write_reg (0x500, bertc0);				-- Write a 1 into BERTC0.RESYNC
bertc0 = bertc0 & 0xfffe;				-- Mask out read-back value
write_reg (0x500, bertc0);				-- Write 0 into BERTC0.RESYNC

bertc0 = read_reg (0x500);				-- Read BERTC0
bertec0 = read_reg (0x518);				-- Read BERTEC0
sync = ((bertec0 & 0x0001) == 0x0001);  		
timeCnt = timeCnt + 1;

while(cnt= timeout)
   	{
printf("Time Out while searching for pattern.");
return status = 0;
   	}
       }
	delay(2000);
	timeCnt = timeCnt +1;
	bertec0 = read_reg (0x518); 			-- Read value of BERTEC0
	temp = ((bertec0 & 0x0010) == 0x0010);	-- Check BERTEC0.RLOS 
	
	if(temp == 1)
     {
            sync = 0;
   	cnt = 0;
	}
	else
	{
   	cnt = cnt+1;
	}

	if(cnt == sync_cnt)
	{
   	printf("Synced to pattern.");
   	return status = 1;
}
 }
 return 0;
}

4. 在BERT寄存器中设置模式

void BertSetup(int pattern) 
{  
	switch (pattern)  
	{
  	case 1:
write_reg (0x500, 0x0 & 0x003c);	-- Disable BERTC0.RINV 
break;					-- Set 2E7-1 pattern
case 2:
write_reg (0x500, 0x0020 & 0x003c);--Enable BERTC0.RINV 
break;					-- Set 2E7-1 pattern
  	default:
write_reg (0x508, 0xffff);		-- Set BERT Repetitive Pattern Set 
write_reg (0x50C, 0xffff);		-- in BERTBRP0-1
write_reg (0x500, 0x0010 & 0x003c);-- Disable BERTC0.RINV
   		break;					-- Set to repetitive pattern
 	}
}

5. 设置环回模式的功能

此示例假定端口 0 放置在环回中。

void loopbackSetup(int val)
{
	int a = 0; 
	int tmp = 0;
	
	tmp = val<<11;
	write_reg(0x0304, tmp); 	-- Set port and channel 0 
 	for (a = 0; a < 128; a++)	-- Set T[0]CFG[a].CNLB to place channel in 
	{	-- loopback  
write_ind_reg(0x0300, 0x0200 + a);		 
	}

	if(val ==1)
	{
write_reg(0x0200, 0x0008); 			-- Enable TP[0]CR.TFDA1 to allow data to 
printf("Loopup detected");			-- be transmitted normally
printf("Channel placed in loopback");	
	}
	else
	{
write_reg(0x0200, 0x0000); 			-- Disable TP[0]CR.TFDA1 bit 
printf("Loopdown detected");
  	printf("Channel taken out from loopback");
	} 
}

结论

本应用笔记介绍了如何在DS31256中使用接收BERT功能。示例代码和软件算法说明了执行FT1环路或环路检测是多么容易。

审核编辑:郭婷

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    30

    文章

    5028

    浏览量

    117719
  • 端口
    +关注

    关注

    4

    文章

    820

    浏览量

    31588
  • 引擎
    +关注

    关注

    1

    文章

    344

    浏览量

    22276
收藏 人收藏

    评论

    相关推荐

    新手求助T0,T1计数器

    本帖最后由 wg555555 于 2014-3-11 10:24 编辑 代码如下:正在学习51单片机C编程,准备用STC89C52弄个两路计数器,发现T1能正常计数,T0每次+1必须在T
    发表于 03-11 10:19

    定时器T1的溢出率

    谁能仔细解释一下51单片机定时器T1的溢出率?
    发表于 06-07 15:26

    串口通信的时候,为什么T1T0会发生冲突呢,但是单独...

    串口通信的时候,为什么T1T0会发生冲突呢,但是单独都可以工作,这是为什么,大家版帮忙
    发表于 11-02 13:22

    如图,怎样由PXI 6115板卡,labview2016软件测得T1T6?

    如图,怎样由PXI 6115板卡,labview2016软件测得T1T6?转子旋转一周产生如图T1T6的6个正弦波,T1为第一个正弦波,
    发表于 11-29 22:19

    如图波形频率测量,怎样把T1T6测出来

    如图所示的波形由不规则六边形磁场中旋转产生,六边形转子旋转一周产生T1T6六个类似正弦的波形,其中六边形较短的边产生的类正弦波幅值要比同周期的其他幅值要小,比如T1
    发表于 12-19 22:14

    基于51单片机定时器T1的中断服务程序

    **************************************************************/ void main(void) { EA=1;//开总中断 ET1=1;//定时器
    发表于 07-19 05:53

    铜绞线原材料紫铜牌号T1T2、T3是什么意思

    铜绞线原材料一般都选用紫铜,因为紫铜导电率、导电导热相比黄铜有更加优越的性能。但是紫铜又有T1T2、T3之分。那么他们之间有什么区别呢?郑州华威金属小编为你做详细解答:紫铜(工业纯
    发表于 11-08 14:56

    怎么ML605使用FM-S14 C子卡进行通信?

    接口之间的GTX,然后通过chipcope查看波形。它运作良好。 现在,我想使用FM-S14 C子卡(光纤)ML605板上进行相同的通信。所以,这次我的GTX都来自FMC-HPC。但是,它不
    发表于 09-05 13:21

    T1系统的传输速率为多少

    1T1系统的传输速率为__1.544Mbps,___ ,E1系统的数据传输速率为 2.048Mbps_2、被称为计算机网络技术发展里程碑的计算机网络系统是ARPA网3、采用同步 TDM时,为了区分
    发表于 07-22 06:09

    【晶心科技ADP-Corvette-T1开发板试用体验】corvette T1的多任务调度学习

    调度器来实现T1开发板下的多任务调度,主要用到TaskScheduler这个库,管理库中搜索并安装即可。先演示下其中的示例,打开个库中的Scheduler_example00_Blink这个示例
    发表于 07-10 23:36

    使用HAL接口STM32F4启用闪存读保护(级别 1)时出现问题怎么解决?

    我正在尝试使用以下 HAL 代码 STM32F411VET6 启用闪存读保护(级别 1): FLASH_OBProgramInitTy
    发表于 12-26 06:38

    dTSEC是否支持远程MAC

    对于 P5040 处理器,可能会回答以下查询。 1. dTSEC 是否支持远程 MAC ? 2. DPAARM中提到“ Carrier extend symbols in full duplex
    发表于 04-23 08:18

    linux-imx内核启用RT行为的路径是什么?

    和输出音频之间使用 Pipewire 中的,然后对 Jack 服务器执行相同操作。两种情况都会出现同样的问题。 使用 cyclictest 测试 RT 功能,具有 1 亿个周期(~5H):最大延迟为
    发表于 05-05 06:55

    LS1046如果要在测试板对XFI1和XFI2 10G信号进行出厂测试测试版应该如何设计?

    到 XFP 连接器。 2、 如果要在测试板对XFI1和XFI2 10G信号进行出厂测试测试版
    发表于 05-19 08:29

    DS31256的分数T1 (FT1)环回检测

    这篇应用笔记介绍了利用DS31256的接收BERT功能实现分数T1 (FT1)上环回或下环回检测(V.54)的方法,详细说明请参考分数级T
    的头像 发表于 06-16 15:35 482次阅读
    <b class='flag-5'>DS</b>31256的<b class='flag-5'>分数</b>级<b class='flag-5'>T1</b> (FT1)环回<b class='flag-5'>检测</b>