亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? ecc_encrypt.c

?? 基于msp430的橢圓曲線加密器程序
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
			{
				bufferyes=1;
				break;
			}
		}
		
		*pmx=mw;
		*pmy=(unsigned char)sqrt(x3);
	}	
	*yes=bufferyes;
}




int oula(unsigned char mwdel)
{   
	unsigned char p1=0;
	unsigned char p1_2=0;
	unsigned char result=0;
    //unsigned char result_p=0;
	unsigned char h1=1;
	unsigned char h2=2;

	
	p1=sub(p,h1);
	p1_2=division(p1,h2);//(p-1)/2


	pow_p(mwdel,p1_2,&result);
    
	
	
	if(result==1)
		return 1;
	else
		return 0;
	
}



void pow_p(unsigned char bottom,unsigned char top,unsigned char *result)
{
    unsigned char bit_pro[4]={0};
    unsigned char mul_tmp=0;

	int j;

	longth(top,bit_pro);     //l??????
	if(bit_pro[3]==1)
	    mul_tmp=bottom;
	else
	    mul_tmp=1;
	for(j=2;j>=0;j--)
	{
		mul_tmp=mul(mul_tmp,mul_tmp);
		if(bit_pro[j]==1)
		mul_tmp=mul(mul_tmp,bottom);
	}
	*result=mul_tmp;  
}





void longth(unsigned char pv_key,unsigned char *bit)
{
    unsigned char bit_pro[4]={0};
	unsigned char h1=1;
	unsigned char result=0;
	int i;
	for(i=0;i<=3;i++)
	{
	    result=pv_key&h1;
	    if(result==1)
		    bit_pro[i]=1;
		pv_key=pv_key>>1;
	}
	//bit=bit_pro;
	for(i=0;bit_pro[i]!='\0';i++)
	{
		bit[i]=bit_pro[i];
	}
}




void kp(unsigned char pv_key,unsigned char pb_key_x,unsigned char pb_key_y,unsigned char *pv_pb_key_x,unsigned char *pv_pb_key_y)
{
	int i;
	unsigned char bit_pro[4]={0};
	unsigned char buf_Q_x=1;
	unsigned char buf_Q_y=0;
	longth(pv_key,bit_pro);
    for(i=0;i<=3;i++)
	{
		if(bit_pro[i]==1)
		    addition(buf_Q_x,buf_Q_y,pb_key_x,pb_key_y,&buf_Q_x,&buf_Q_y);
		square(pb_key_x,pb_key_y,&pb_key_x,&pb_key_y);
	}
	*pv_pb_key_x=buf_Q_x;
    *pv_pb_key_y=buf_Q_y;

}





void encryption(unsigned char mw,unsigned char qbx,unsigned char qby,unsigned char *cx,unsigned char *cy,unsigned char *yes)
{
	unsigned char pmx=0;
	unsigned char pmy=0;
	unsigned char daqbx=0;
	unsigned char daqby=0;
	unsigned char bufferyes=0;
	unsigned char cx_tmp=0;
	unsigned char cy_tmp=0;

	proclaimed(mw,&pmx,&pmy,&bufferyes);
	*yes=bufferyes;
	kp(g_encrypt_private_key,qbx,qby,&daqbx,&daqby);
    addition(daqbx,daqby,pmx,pmy,&cx_tmp,&cy_tmp);
	*cx=cx_tmp;
	*cy=cy_tmp;
    
}




void decode(unsigned char cx,unsigned char cy,unsigned char qax,unsigned char qay,unsigned char yes,unsigned char *mx)
{
    unsigned char dbqax=0;
	unsigned char dbqay=0;
	unsigned char mx_tmp=0;
	unsigned char my=0;

	kp(g_decrypt_private_key,qax,qay,&dbqax,&dbqay);
	dbqay=sub(p,dbqay);
	addition(cx,cy,dbqax,dbqay,&mx_tmp,&my);
	*mx=mx_tmp;

}



void SHA_a_4(unsigned char time_ws,unsigned char *pv_key_a)
{
	unsigned char pv_pro=0;
	
	srand(time_ws); 
	pv_pro= rand() ; 
	pv_pro=pv_pro&15;
	*pv_key_a=pv_pro;

}




void SHA_b_4(unsigned char time_ws, unsigned char *pv_key_b)
{
	unsigned char pv_pro=0;
	//srand((unsigned)time(NULL)); 
	
	srand(time_ws); 
	pv_pro= rand() ; 
	pv_pro=pv_pro&15;
	*pv_key_b=pv_pro;

}

//**************************************************************
//函數(shù)名稱: void Software_delay3(unsigned int i)
//函數(shù)說(shuō)明: 軟件延時(shí)程序
//參數(shù)說(shuō)明: 延時(shí)時(shí)間單位:微秒為單位,8MHz為主時(shí)鐘
//返回值  : 無(wú)  
//**************************************************************
Software_delay3(unsigned int nValue)
{
unsigned int ii; 
for(ii = nValue;ii > 0;ii--)
{
_NOP();//1Tj
_NOP();//1Tj
} 
return;//8000000*0.000001/(6+2)=1
}

//**************************************************************
//函數(shù)名稱: void Delay(void)
//函數(shù)說(shuō)明: 延時(shí)程序,用于消除抖動(dòng)
//參數(shù)說(shuō)明: 無(wú)
//返回值  : 無(wú)  
//**************************************************************
void Delay(void)
{
    int i;
    for(i = 15000;i > 0;i--) ;//延時(shí)一點(diǎn)時(shí)間
}


//-------------------------------------可調(diào)用函數(shù)(子程序)結(jié)束--------------------------//

//*************************************主函數(shù)體********************************
//函數(shù)名稱: void main(void)
//函數(shù)說(shuō)明: 主函數(shù)
//*****************************************************************************
void main(void)
{
    unsigned int i;

    //====================================
    //全局變量初始化
    //====================================
    g_encrypt_pk_x=0;
    g_encrypt_pk_y=0;
    g_encrypt_private_key=0;
    
    g_decrypt_pk_x=0;
    g_decrypt_pk_y=0;
    g_decrypt_private_key=0;
    
    px=1;
    py=5;
    yes=0;
    
    g_recv_flag = 0;
    g_recv_count = 0;
    g_UartCommand = 0;
    g_uart_answer = 0;
    
    
    WDTCTL = WDTPW + WDTHOLD;                     // Stop WDT  關(guān)看門狗 ?

    //-----------------------------------MCU系統(tǒng)初始化-----------------------------------//
    DCOCTL = SYS_DCOCTL_INIT;                     //采用DOC來(lái)作時(shí)鐘控制  
    BCSCTL1 = SYS_XTCL1_INIT;
    
    //BCSCTL1 |= XT2OFF ;                         // XTon   (選擇晶振1)
     
    do                                            //??????(是否需要)
    {
        IFG1 &= ~OFIFG;                           // Clear OSCFault flag
        for (i = 0xFF; i > 0; i--);               // Time for flag to set
    }
    while ((IFG1 & OFIFG));                       // OSCFault flag still set?
    
    BCSCTL2 = SYS_XTCL2_INIT;
    //BCSCTL2 |= SELM_3 + SELS;                     // MCLK = SMCLK = XT2 (主時(shí)鐘和子時(shí)鐘選擇) 
       
    //---------------------------------串口設(shè)置程序9600 ,32768HZ--------------------------//
    UCTL0  = SWRST;                               // Set the reset bit to hold inactive
    UBR00 = UART_BAUD_BYTE_L;                     // 32768hz/2400 
    UBR10 = UART_BAUD_BYTE_H;                     //
    UMCTL0 = UART_BAUD_FINE;                      // Modulation 
    UCTL0 = SWRST+CHAR;                           // P=none, 8 bits, 1 stop
    UTCTL0 = SSEL0;                               // UCLK = ACLK
    URCTL0 = 0;                                   // wake on all correct rx
    ME1 |= UTXE0 + URXE0;                         // Enable USART0 TXD/RXD
    P3SEL_INIT_SETUP;                             // P3.4,5 = USART0 TXD/RXD
    P3DIR_SETUP_OUTPUT;                           // P3.0,4 = OUT
    UCTL0 &= ~SWRST;                              // Initialize USART state machine
    IE1 |= URXIE0;                                // Enable USART0 RX interrupt

    //---------------------------------P2口初始設(shè)置--------------------------------------//
    P2DIR_FIRST_SETUP;                             //P2口初始化

//.................................中斷使用(初始配置).................................. 
//    P2INIT_FLAG_SET;                               // 打開無(wú)線接收中斷(P2口的設(shè)置)
//    P2INIT_EDGE_SET;
//    P2INIT_ENABLE_SET;                             //開中斷 P2.2 = DR1 
//.....................................................................................

      P2DIR_DATA_RECV;                              //P2口設(shè)置為射頻接收
    
    _EINT();                                      //開所有中斷使能

    Software_delay(POWERUP_DELAY_TIME);           //軟件延時(shí)
    //send_uart_a_byte(NORMAL);                     //上電正常顯示表示
    

    while(1)
    {
        
        if( g_recv_flag == 1 )                    //串口收到一幀數(shù)據(jù)中斷標(biāo)志
        {
            uart_command_prog();                  //串口命令處理,

           // send_uart_a_byte(g_uart_answer);
            g_uart_answer = 0;
            
            g_recv_count = 0;
            g_recv_flag = 0;
            g_UartCommand = 0;
            
            IE1 |= URXIE0;                        //開打串口中斷
        }

    }


}
//------------------------------------主函數(shù)體結(jié)束----------------------------------------//


//-------------------------------------中斷服務(wù)程序---------------------------------------//

//**********************************************************************************//
//  函數(shù)名稱: void usart0_rx                                                       //
//  函數(shù)說(shuō)明: 串口接收命令中斷服務(wù)程序                                             //
//  參數(shù)說(shuō)明: 無(wú)                                                                   //
//  返回值  : 無(wú)                                                                   //
//  調(diào)用函數(shù): void recv_spi_string(void)                                           //
//  全局變量: g_recv_count; g_UartCommand; g_Uartdata2; g_recv_flag; g_buf[32];    //
//  函數(shù)功能說(shuō)明:將串口接收到的第一個(gè)字節(jié)g_UartCommand和                           //
//                第二個(gè)字節(jié)分別做為命令字和字節(jié)長(zhǎng)度g_Uartdata2.                    //
//                其中,g_UartCommand只能取01,02,03三個(gè)數(shù);2 <= g_Uartdata2;      //
//**********************************************************************************//
#pragma vector=UART0RX_VECTOR
__interrupt void usart0_rx (void)
{
   
    
    if(g_recv_count == 0)                         //串口接收第一個(gè)命令字節(jié)(命令字節(jié)),
    {
        g_UartCommand = RXBUF0;              
        g_recv_count++;
       
        if((g_UartCommand == 0) || (g_UartCommand > 6))//錯(cuò)誤命令轉(zhuǎn)做錯(cuò)誤處理
        {
            g_recv_flag = 1;
            g_uart_answer = 1;                    //錯(cuò)誤
            IE1 &= ~URXIE0;
        }
      
    }
    else if(g_recv_count == 1)                    //串口接收第二個(gè)字節(jié)數(shù)(數(shù)據(jù)長(zhǎng)度)。
    {
        g_Uartdata2 = RXBUF0;
        g_recv_count++;  
        
        switch (g_UartCommand)
        {
        case  GET_ENCRYPT_PK_COMD:
              {
                      if(g_Uartdata2 != 3)
                      {
                          g_recv_flag = 1;
                          g_uart_answer = 1;
                          IE1 &= ~URXIE0;
                      }
                      break;
                  
               }
        case SENT_DECRYPT_PK_COMD:
             {
                      if(g_Uartdata2 != 4)
                      {
                          g_recv_flag = 1;
                          g_uart_answer = 1;
                          IE1 &= ~URXIE0;
                      }
                      break;
                  
               }

        case GET_DECRYPT_PK_COMD:
             {
                      if(g_Uartdata2 = 3)
                      {
                          g_recv_flag = 1;
                          g_uart_answer = 1;
                          IE1 &= ~URXIE0;
                      }
                      break;
                  
               }
         case SENT_ENCRYPT_PK_COMD:
             {
                      if(g_Uartdata2 != 4)
                      {
                          g_recv_flag = 1;
                          g_uart_answer = 1;
                          IE1 &= ~URXIE0;
                      }
                      break;
                  
               }
         default:
           {
                  //g_recv_flag = 1;                    //若接收到03命令則命令處理做待機(jī)
                  //IE1 &= ~URXIE0;                     //關(guān)uart中斷
           }
        }
    }
    else                                        //串口接收數(shù)據(jù)字節(jié)
    {     
        g_buf[g_recv_count-2] = RXBUF0;
        g_recv_count++;
       
        if(g_recv_count == g_Uartdata2 )        //串口命令一幀數(shù)據(jù)結(jié)束
        {
            g_recv_flag = 1;
            IE1 &= ~URXIE0;
        }
       
    }
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品伦理一区二区| 亚洲一区二区三区美女| 欧美性xxxxx极品少妇| 麻豆91小视频| 成人免费一区二区三区在线观看| 欧美日韩高清一区| 成人av免费网站| 看片网站欧美日韩| 亚洲韩国精品一区| 国产精品另类一区| 久久亚洲一区二区三区明星换脸| 在线观看视频欧美| 99视频在线观看一区三区| 久久精品国产一区二区| 性做久久久久久免费观看| 中文字幕视频一区| 国产视频一区二区在线| 精品日韩99亚洲| 在线综合亚洲欧美在线视频| 91国内精品野花午夜精品 | 国产欧美一区二区在线| 7777精品伊人久久久大香线蕉超级流畅 | 欧美一级生活片| 在线免费视频一区二区| 99久久777色| 成人精品一区二区三区四区| 国产精品一二三四五| 激情综合色播五月| 麻豆精品国产91久久久久久| 天堂一区二区在线| 亚洲一区二区成人在线观看| 亚洲男人的天堂一区二区 | 日韩成人精品在线观看| 亚洲一区在线观看网站| 亚洲激情男女视频| 亚洲视频免费观看| 亚洲男人天堂一区| 一区二区三区四区在线播放| 亚洲日本在线观看| 亚洲精品五月天| 亚洲一区二区三区中文字幕在线| 亚洲日本va在线观看| 亚洲精品日日夜夜| 午夜欧美电影在线观看| 五月婷婷激情综合网| 肉肉av福利一精品导航| 舔着乳尖日韩一区| 日本不卡一二三| 久久精品72免费观看| 精品一区二区三区久久| 国产福利视频一区二区三区| 懂色一区二区三区免费观看 | 色综合天天综合网天天看片| 93久久精品日日躁夜夜躁欧美| 色噜噜狠狠成人中文综合| 欧美丝袜丝交足nylons| 欧美视频完全免费看| 在线电影欧美成精品| 日韩亚洲欧美高清| 久久九九久久九九| 日韩理论片一区二区| 亚洲一二三级电影| 美女性感视频久久| 国产成人午夜精品影院观看视频| 成人性生交大片免费看视频在线| 91在线免费视频观看| 欧美日韩中文字幕一区| 欧美mv日韩mv国产网站| 日本一区二区三区免费乱视频 | 欧美一区二区观看视频| 久久久久亚洲蜜桃| 亚洲欧美激情插 | 国产精品午夜电影| 一区二区三区四区亚洲| 奇米在线7777在线精品 | 国产一区二区三区电影在线观看 | 欧美日韩大陆在线| 久久这里只有精品视频网| 综合电影一区二区三区| 日韩精品一区第一页| 成人免费av资源| 欧美日韩和欧美的一区二区| 久久久久国产精品麻豆ai换脸| 亚洲精品视频在线看| 美女在线观看视频一区二区| av一区二区久久| 日韩一区二区高清| 亚洲欧美另类久久久精品| 久久超碰97中文字幕| 99久久久国产精品| 欧美一区二视频| 亚洲欧美另类久久久精品2019| 另类小说视频一区二区| 91香蕉国产在线观看软件| 日韩久久久久久| 一区二区三区欧美| 国产成人超碰人人澡人人澡| 欧美日韩一区精品| 国产精品欧美久久久久无广告| 日韩成人精品在线| 色婷婷狠狠综合| 欧美激情一区二区三区在线| 男人的天堂久久精品| 在线一区二区视频| 中文字幕永久在线不卡| 久久精品99国产精品日本| 欧美色中文字幕| 国产精品成人一区二区艾草| 国产一区二区三区黄视频| 91精品国产综合久久蜜臀| 国产精品毛片高清在线完整版| 老司机精品视频线观看86| 欧美性大战久久| 日韩毛片视频在线看| 国产精品自拍毛片| 精品日韩一区二区| 免费在线观看视频一区| 欧美日韩国产首页| 亚洲午夜免费福利视频| 91在线免费看| 自拍偷拍国产亚洲| aaa欧美大片| 中文字幕国产一区| 国产成人精品亚洲日本在线桃色| 日韩欧美一区二区久久婷婷| 亚洲成a人片综合在线| 日本乱人伦aⅴ精品| 日韩一区在线播放| www.亚洲人| 国产精品理论片| 9i在线看片成人免费| 国产精品美女久久久久高潮| 成人动漫精品一区二区| 国产欧美一二三区| 成人一级片网址| 国产精品久久福利| 99精品久久99久久久久| 自拍偷拍欧美精品| 色综合视频一区二区三区高清| 《视频一区视频二区| 色综合久久综合网欧美综合网 | 久久影院电视剧免费观看| 强制捆绑调教一区二区| 日韩欧美一二区| 国产在线精品一区二区不卡了| 精品对白一区国产伦| 国产一本一道久久香蕉| 国产午夜精品久久久久久免费视 | 91福利区一区二区三区| 亚洲午夜激情网页| 欧美一区二区三区视频在线观看| 日本视频中文字幕一区二区三区| 欧美精品电影在线播放| 精品一区二区三区欧美| 国产拍欧美日韩视频二区| 99久久精品国产导航| 亚洲午夜久久久久久久久电影院| 欧美日韩免费不卡视频一区二区三区| 亚洲成人资源网| 精品日韩成人av| 成人av在线资源网| 亚洲一区二区中文在线| 日韩一区二区在线播放| 大美女一区二区三区| 亚洲一区二区三区国产| 欧美成人激情免费网| 成人一区二区三区中文字幕| 亚洲免费av观看| 日韩免费观看高清完整版在线观看| 国产福利一区二区三区视频在线| 亚洲日本一区二区三区| 3d动漫精品啪啪一区二区竹菊| 精品无人码麻豆乱码1区2区| 亚洲国产成人一区二区三区| 欧美午夜精品一区二区蜜桃| 久久97超碰色| 亚洲美女免费在线| 欧美成人性福生活免费看| a美女胸又www黄视频久久| 日韩专区欧美专区| 国产精品私人自拍| 欧美一区二区三区在线视频| 不卡一区在线观看| 秋霞成人午夜伦在线观看| 亚洲私人黄色宅男| 日韩精品一区二区三区三区免费| 99久久综合国产精品| 日本午夜一本久久久综合| 亚洲欧美影音先锋| 久久蜜桃av一区二区天堂| 欧美在线视频你懂得| 国产福利不卡视频| 日韩精品乱码免费| 亚洲色图在线看| 久久综合九色欧美综合狠狠| 欧美日韩一区国产| 91网页版在线| 国产99一区视频免费| 日本大胆欧美人术艺术动态| 亚洲激情图片一区|