arm nop延時方法


條件,FCLK=200M

PCLK=100M,HCLK 100M

並且開啟MMU,內存進行映射的情況下

延時函數如下

void delay_pw(void) 3.25us
{
	int i,j;
       for(j=2;j>0;j--)
  {
	for(i=0;i<50;i++)
	   {
	   	__asm{
	   		nop
	   	          }
	   }
    }
}

void delay_Tb0(void)//8.33-3.25=5.08us,一個nop合計1.6/50us的時間
{
   	int i,j;
       for(j=3;j>0;j--)
  {
	for(i=0;i<53;i++)
	   {
	   	__asm{
	   		nop
	   	          }
	   }
    }
}


void delay_Tb1(void)//14.58-3.25=11.33us,一個nop合計1.6/50us的時間
{
   	int i,j;
       for(j=2;j>0;j--)
  {
	for(i=0;i<183;i++)
	   {
	   	__asm{
	   		nop
	   	          }
	   }
    }
}

void delay_Tdelimiter(void)//12.5us
{
	   	int i,j;
       for(j=2;j>0;j--)
  {
	for(i=0;i<203;i++)
	   {
	   	__asm{
	   		nop
	   	          }
	   }
    }
}


void delay_RT(void)//22.91-3.25=19.66us
{
int i,j;

 
	for(i=0;i<600;i++)
	   {
	   	__asm{
	   		nop
	   	          }
	   }//以上定時18.16us,還需定時1.5us
	   
	   for(i=0;i<47;i++)
	     __asm{
	     		nop
	     }//延時1.5us,搞定
  
}

發現代碼改變了之后,nop延時變得非常不准確了哦?

原來是cpu時鍾設置不對,當把cpu設置對了之后呢,結果就對了

應該是FCLK200M,HCLK,PCLK都是100M的干活。

得到的query圖形如下


注意!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。



 
  © 2014-2022 ITdaan.com 联系我们: