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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sp3530.c

?? c8051f單片機以太網測控資料
?? C
字號:
#include <c8051f020.h>					// SFR declarations
#include <intrins.h>
//------------------------------------------------------------------------------------
// Global CONSTANTS
//------------------------------------------------------------------------------------

#define 	WRITE	0x00						// SMBus WRITE command
#define		READ 	0x01						// SMBus READ command

// Device addresses (7 bits, lsb is a don't care)
#define		CLOCK3530_ADDRESS_RESET		0x60		//1 ack
#define		CLOCK3530_ADDRESS_STATUS	0x62		//2 ack
#define		CLOCK3530_ADDRESS_DATEHOUR	0x64		//8 ack  year month day week hour minute second
#define		CLOCK3530_ADDRESS_HOUR		0x66		//4 ack  hour minute second
#define		CLOCK3530_ADDRESS_INT1		0x68		//3 ack  
#define		CLOCK3530_ADDRESS_INT2		0x6A		//3 ack  

union 
{
unsigned char ClockString[7];
struct RealClock
	{
		unsigned char Year,Month,Day,Week,Hour,Minute,Second;
	} RT;
} RealTime;


// SMBus states:
// MT = Master Transmitter
// MR = Master Receiver
#define	SMB_BUS_ERROR	0x00			// (all modes) BUS ERROR
#define	SMB_START		0x08			// (MT & MR) START transmitted
#define	SMB_RP_START	0x10			// (MT & MR) repeated START
#define	SMB_MTADDACK	0x18			// (MT) Slave address + W transmitted;
										//  ACK received
#define	SMB_MTADDNACK	0x20			// (MT) Slave address + W transmitted;
										//  NACK received
#define	SMB_MTDBACK		0x28			// (MT) data byte transmitted; ACK rec'vd
#define	SMB_MTDBNACK	0x30			// (MT) data byte transmitted; NACK rec'vd
#define	SMB_MTARBLOST	0x38			// (MT) arbitration lost
#define	SMB_MRADDACK	0x40			// (MR) Slave address + R transmitted;
										//  ACK received
#define	SMB_MRADDNACK	0x48			// (MR) Slave address + R transmitted;
										//  NACK received
#define	SMB_MRDBACK		0x50			// (MR) data byte rec'vd; ACK transmitted
#define	SMB_MRDBNACK	0x58			// (MR) data byte rec'vd; NACK transmitted


//-----------------------------------------------------------------------------------
//Global VARIABLES
//-----------------------------------------------------------------------------------
char COMMAND;			// Holds the slave address + R/W bit for use in the SMBus ISR.

unsigned char *I2CDataBuff;						

char BYTE_NUMBER;							// Used by ISR to check what data has just been
												// sent - High address byte, Low byte, or data byte

unsigned char HIGH_ADD, LOW_ADD;		// High & Low byte for EEPROM memory address
				
bit SM_BUSY;								// This bit is set when a send or receive
												// is started. It is cleared by the
												// ISR when the operation is finished.


//------------------------------------------------------------------------------------
// Function PROTOTYPES
//------------------------------------------------------------------------------------

void SMBus_ISR (void);								

//------------------------------------------------------------------------------------
// MAIN Routine
//------------------------------------------------------------------------------------
//
// Main routine configures the crossbar and SMBus, and tests
// the SMBus interface between the three EEPROMs


void ResetRealClock(void)
{
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 0;									// 2 address bytes.
	COMMAND = (CLOCK3530_ADDRESS_RESET | READ);		// Chip select + READ
	STA = 1;											// Start transfer
	while (SM_BUSY);									// Wait for transfer to finish
}

//======================寫S-3530A內部實時數據寄存器程序=====================
//功能:將設定年、月、日、星期、時、分、秒數據寫入S-3530A                  |
//入口:發送數據放在年、月、日、星期、時、分、秒各寄存器                   |
//出口:NONE                                                               |
//==========================================================================
void SetRealClock(void)
{
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 7;									// 2 address bytes.
	COMMAND = (CLOCK3530_ADDRESS_DATEHOUR | WRITE);		// Chip select + WRITE
	I2CDataBuff = &RealTime.ClockString[0];				// Data to be writen
	STA = 1;
	while (SM_BUSY);											// Start transfer
}

//==================讀S-3530A實時數據寄存器子程序===========================
//功能:從S-3530A讀入當前時間數據                                          |
//入口:NONE                                                               |
//出口:接收數據放在年、月、日、星期、時、分、秒各寄存器                   |
//==========================================================================
void GetRealClock(void)
{
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 7;									// 2 address bytes.
	COMMAND = (CLOCK3530_ADDRESS_DATEHOUR | READ);		// Chip select + READ
	I2CDataBuff = &RealTime.ClockString[0];				// Data to be writen
	STA = 1;											// Start transfer
	while (SM_BUSY);									// Wait for transfer to finish
}

//============================寫狀態寄存器程序==============================
//功能:讀/寫S-3530A狀態寄存器,對S-3530A進行設置                          |
//入口:NONE           出口:NONE                                          |
//==========================================================================
unsigned char  GetRealClockStatus(void)
{
	unsigned char result; 
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 1;									
	COMMAND = (CLOCK3530_ADDRESS_STATUS | READ);		
	I2CDataBuff = &result;								
	STA = 1;											// Start transfer
	while (SM_BUSY);									// Wait for transfer to finish
	return result;
}
void SetRealClockStatus(unsigned char status)
{
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 1;									
	COMMAND = (CLOCK3530_ADDRESS_STATUS | WRITE);		
	I2CDataBuff = &status;								
	STA = 1;											// Start transfer
}

void  SetRealClockINT1(unsigned int Int1)
{
	while (SM_BUSY);									// Wait for SMBus to be free.
	SM_BUSY = 1;										// Occupy SMBus (set to busy)
	SMB0CN = 0x44;										// SMBus enabled, ACK on acknowledge cycle
	BYTE_NUMBER = 2;									
	COMMAND = (CLOCK3530_ADDRESS_INT1 | WRITE);		
	I2CDataBuff = (unsigned char*)&Int1;								
	STA = 1;											// Start transfer
}

#include "INTRINS.H"

unsigned char revolve(unsigned char val)
{
char i;
unsigned char val1=0;
	for (i=0;i<8;i++)
	{
		if (val&0x1)
			val1++;
		val1=_crol_(val1,1);
		val=_cror_(val,1);
	}
	val1=_cror_(val1,1);
	return val1;
}

void main (void)
{
unsigned char var ;
	WDTCN = 0xde;									// disable watchdog timer
	WDTCN = 0xad;
	
	OSCICN |= 0x03;								// Set internal oscillator to highest setting
														// (16 MHz)

	XBR0 |= 0x07;									// Route SMBus to GPIO pins through crossbar
	XBR2 |= 0x44;									// Enable crossbar and weak pull-ups

    P0MDOUT |= 0x1D; 
    P1MDOUT |= 0x01; 
	SMB0CN=0x00;
	SMB0CN = 0x44;									// Enable SMBus with ACKs on acknowledge cycle
	SMB0CR = -80;									// SMBus clock rate = 100kHz.
     //SMB0CN &=0x7f;
	EIE1 |= 2;										// SMBus interrupt enable
	EA = 1;											// Global interrupt enable

	SM_BUSY = 0;									// Free SMBus for first transfer.
    if(!BUSY)
	BUSY=1;
	BUSY=1;
	_nop_();
	_nop_();
	BUSY=0;
	BUSY=0;
	_nop_();
	_nop_();
//	SetRealClockINT1(0x8000);
	var = GetRealClockStatus();
	ResetRealClock();
	var = GetRealClockStatus();
	SetRealClockStatus(0xa2);
	var = GetRealClockStatus();
	SetRealClockINT1(0x8000);
	RealTime.RT.Year=0x02;	
	RealTime.RT.Month=0x06;	
	RealTime.RT.Day=0x05;	
	RealTime.RT.Week=0x03;	
	RealTime.RT.Hour=0x11;	
	RealTime.RT.Minute=0x59;	
	RealTime.RT.Second=0x45;	
	SetRealClock();
//	RealTime.RT.Year=0x0;	
//	RealTime.RT.Month=0x0;	
//	RealTime.RT.Day=0x0;	
//	RealTime.RT.Week=0x0;	
//	RealTime.RT.Hour=0x0;	
//	RealTime.RT.Minute=0x0;	
//	RealTime.RT.Second=0x0;	
	GetRealClock();
/*	RealTime.RT.Year=0x02;	
	RealTime.RT.Month=0x06;	
	RealTime.RT.Day=0x05;	
	RealTime.RT.Week=0x02;	
	RealTime.RT.Hour=0x11;	
	RealTime.RT.Minute=0x14;	
	RealTime.RT.Second=0x45;	
*/
//	SetRealClock();
	GetRealClock();
	GetRealClock();
	GetRealClock();
	GetRealClock();
	while(1)
	{
	  GetRealClock();
	}
}


//------------------------------------------------------------------------------------
// Interrupt Service Routine
//------------------------------------------------------------------------------------
void SMBUS_ISR (void) interrupt 7
{
	switch (SMB0STA)
		{ 	// SMBus 狀態碼SMB0STA 寄存器
			// 主發送器/接收器起始條件已發送
		case SMB_START:
			SMB0DAT = COMMAND ; // 裝入要訪問的從器件的地址
			STA = 0; 			// 手動清除START 位
			break;
			//主發送器/接收器重復起始條件已發送
			// 該狀態只應在讀操作期間出現在存儲器地址已發送并得到確認之后 ?
		case SMB_RP_START:
			SMB0DAT = COMMAND; // COMMAND 中應保持從地址 + R.
			STA = 0;
			break;
			// 主發送器從地址 + WRITE 已發送收到ACK
		case SMB_MTADDACK:
			// 主發送器數據字節已發送收到ACK
		case SMB_MTDBACK:
			if (BYTE_NUMBER)
			{
					SMB0DAT = revolve(*I2CDataBuff);					// If R/W=WRITE, load byte to write.
					I2CDataBuff++;
					BYTE_NUMBER--;			
			}
			else
			{
				STO = 1;	SM_BUSY = 0;						// Free SMBus
			}
			break;
			// 主發送器從地址 + WRITE 已發送收到NACK
			// 從器件不應答發送STOP + START 重試
		case SMB_MTADDNACK:
			STO = 1;			STA = 1;
		break;
			// 主發送器數據字節已發送收到NACK
			// 從器件不應答發送STOP + START 重試
		case SMB_MTDBNACK:
			STO = 1;			STA = 1;
		break;
			// 主發送器競爭失敗
			// 不應出現如果出現重新開始傳輸過程
		case SMB_MTARBLOST:
			STO = 1;			STA = 1;
		break;

			// 主接收器從地址 + READ 已發送,收到ACK
		case SMB_MRADDACK:
			AA = 1; // 在應答周期ACK
			if (!BYTE_NUMBER)
			{	
				STO = 1;	SM_BUSY = 0; // 釋放SMBus
			}
		break;
			// 主接收器從地址 + READ 已發送收到NACK
			// 從器件不應答發送重復起始條件重試
		case SMB_MRADDNACK:
			STA = 1;
		break;
			// 收到數據字節ACK 已發送
			// 該狀態不應出現因為AA 已在前一狀態被清0 如果出現發送停止條件
		case SMB_MRDBACK:
			if (BYTE_NUMBER)
			{
				*I2CDataBuff=revolve(SMB0DAT);		
				I2CDataBuff++;
				BYTE_NUMBER--;			
			}
			if (!BYTE_NUMBER)	AA= 0;
		break;
			// 收到數據字節NACK 已發送
			// 讀操作已完成讀數據寄存器后發送停止條件
		case SMB_MRDBNACK:
			STO = 1;
			SM_BUSY = 0; // 釋放SMBus
		break;
			// 在本應用中所有其它狀態碼沒有意義通信復位
		default:
			STO = 1; // 通信復位
			SM_BUSY = 0; 
		break;
		}
	SI=0; // 清除中斷標志
}
/*
{
	switch (SMB0STA){			// Status code for the SMBus (SMB0STA register)
		case SMB_START:					
			SMB0DAT = COMMAND;					// COMMAND should hold slave address + R.
			break;
		case SMB_MTADDNACK:
			STO = 1;
			STA = 1;
			break;
		case SMB_RP_START:
//			SMB0DAT = COMMAND;					// COMMAND should hold slave address + R.
//			STA = 0;											
//			break;
		case SMB_MTADDACK:
		case SMB_MTDBACK:
			if (BYTE_NUMBER)
			{
					if (COMMAND & 0x01)					// If R/W=READ, 
					{
						STA = 1;
					}
					else
					{
						SMB0DAT = *I2CDataBuff;					// If R/W=WRITE, load byte to write.
						I2CDataBuff++;
						BYTE_NUMBER--;			
					}
			}
			else
			{
				STO = 1;
				SM_BUSY = 0;						// Free SMBus
			}
			break;
		
		// Master Transmitter: Data byte transmitted.  NACK received.
		// Slave not responding.  Send STOP followed by START to try again.
		case SMB_MTDBNACK:
			STO = 1;
			STA = 1;
			break;
		
		// Master Transmitter: Arbitration lost.
		// Should not occur.  If so, restart transfer.
		case SMB_MTARBLOST:
			STO = 1;
			STA = 1;
			break;

		// Master Receiver: Slave address + READ transmitted.  NACK received.
		// Slave not responding.  Send repeated start to try again.
		case SMB_MRADDNACK:
			STA = 1;
			break;

		// Data byte received.  ACK transmitted.
		// State should not occur because AA is set to zero in previous state.
		// Send STOP if state does occur.
		case SMB_MRDBACK:
			STO = 1;
			SM_BUSY = 0;
			break;

		// Master Receiver: Slave address + READ transmitted.  ACK received.
		// Set to transmit NACK after next transfer since it will be the last (only) byte.
		case SMB_MRADDACK:
//			AA = 0;										// NACK sent on acknowledge cycle.
//			break;

		// Data byte received.  NACK transmitted.
		// Read operation has completed.  Read data register and send STOP.
		case SMB_MRDBNACK:
			if (BYTE_NUMBER)
			{
					if (COMMAND & 0x01)					// If R/W=READ, 
					{
						*I2CDataBuff=SMB0DAT;		
						I2CDataBuff++;
					}
					BYTE_NUMBER--;			
			}
			else
			{
				STO = 1;
				SM_BUSY = 0;						// Free SMBus
			}
			break;
		// All other status codes meaningless in this application. Reset communication.
		default:
			STO = 1;										// Reset communication.
			SM_BUSY = 0;
			break;
		}
	
	SI=0;													// clear interrupt flag
}*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
18成人在线观看| 在线不卡的av| 久久国产精品无码网站| 亚洲综合免费观看高清完整版 | 欧美日韩午夜在线视频| 欧美性视频一区二区三区| av一区二区久久| 99综合电影在线视频| 不卡一二三区首页| 91美女片黄在线| 欧美视频在线一区二区三区| 欧美日韩精品是欧美日韩精品| 欧美影院一区二区三区| 欧美私人免费视频| 666欧美在线视频| 日韩一区二区在线观看视频播放| 日韩欧美国产综合在线一区二区三区| 日韩一区二区三区视频| 精品国产青草久久久久福利| 精品国产一区二区三区四区四 | 国产欧美一区二区精品忘忧草| 欧美精品一区二区久久婷婷| 国产欧美一区二区精品秋霞影院| 国产精品久久综合| 亚洲制服欧美中文字幕中文字幕| 亚洲成人激情av| 国产美女在线精品| 91污在线观看| 日韩一级视频免费观看在线| 久久精品亚洲精品国产欧美kt∨ | 精品国产乱码久久久久久闺蜜| 国产日韩欧美不卡在线| 一区二区成人在线视频| 七七婷婷婷婷精品国产| 丁香六月久久综合狠狠色| 一本大道久久a久久综合| 911国产精品| 国产精品女人毛片| 日日夜夜免费精品| 国产乱子伦视频一区二区三区| 91视频观看视频| 91精品国产色综合久久不卡蜜臀| 国产女主播视频一区二区| 亚洲一区免费视频| 国产精品亚洲人在线观看| 欧美亚洲综合在线| 国产亚洲精品超碰| 日本人妖一区二区| 色综合久久中文综合久久97| 久久综合九色综合欧美98| 亚洲伊人色欲综合网| 国产suv精品一区二区6| 欧美日韩国产精品成人| 中文字幕高清不卡| 精品一二三四在线| 欧美乱妇20p| 亚洲天堂免费在线观看视频| 看国产成人h片视频| 欧美成人综合网站| 国产精品日产欧美久久久久| 久久精品国产精品青草| 欧美亚洲国产一区二区三区| 国产精品美日韩| 国产精品99久| 精品黑人一区二区三区久久 | 555夜色666亚洲国产免| 亚洲精品国产第一综合99久久 | 久久爱另类一区二区小说| 在线观看中文字幕不卡| 亚洲欧洲综合另类| 91亚洲午夜精品久久久久久| 国产日韩在线不卡| 久久66热re国产| 欧美v国产在线一区二区三区| 日韩vs国产vs欧美| 日韩一区二区视频| 日欧美一区二区| 777午夜精品视频在线播放| 一级日本不卡的影视| 99riav久久精品riav| 久久噜噜亚洲综合| 国产a视频精品免费观看| 国产精品色哟哟| 成人av网在线| 亚洲欧美日韩国产综合在线| 91在线高清观看| 综合欧美亚洲日本| 91成人在线免费观看| 亚洲成人资源在线| 日韩欧美国产精品一区| 激情小说欧美图片| 2021中文字幕一区亚洲| 丁香婷婷综合激情五月色| 国产女主播视频一区二区| 91免费国产视频网站| 一区二区三区四区高清精品免费观看| 欧美视频在线观看一区二区| 日产精品久久久久久久性色| 日韩精品一区二区三区四区视频 | 1024成人网| 欧美色区777第一页| 视频一区二区不卡| 久久久噜噜噜久噜久久综合| 成人午夜伦理影院| 亚洲成av人片观看| 久久久久国色av免费看影院| 日本黄色一区二区| 久久69国产一区二区蜜臀 | 91黄视频在线观看| 热久久久久久久| 久久久亚洲高清| 欧美三区在线视频| 国产剧情一区二区| 亚洲男同性恋视频| 精品国产成人在线影院| 成人黄色国产精品网站大全在线免费观看| 中文字幕亚洲综合久久菠萝蜜| 欧美色图12p| 国产精品一品视频| 亚洲妇熟xx妇色黄| 国产精品麻豆一区二区| 欧美另类一区二区三区| 福利电影一区二区三区| 国内精品视频666| 亚洲国产精品综合小说图片区| 精品国产欧美一区二区| 色悠久久久久综合欧美99| 久久精品99国产精品| 亚洲一区二区影院| 国产精品欧美久久久久一区二区| 日韩欧美一区在线观看| 色综合久久中文字幕综合网| 国产成人精品三级麻豆| 亚洲444eee在线观看| 亚洲日本一区二区三区| 欧美国产日韩在线观看| 欧美精品一区二| 欧美高清一级片在线| 欧美在线一二三| 色综合色综合色综合| av中文字幕在线不卡| 国产成人午夜高潮毛片| 韩国三级电影一区二区| 美女视频黄久久| 日韩av一级片| 视频一区二区中文字幕| 一区二区三区在线视频播放| 自拍偷拍亚洲激情| 国产精品你懂的| 国产精品美女久久久久aⅴ| 久久美女艺术照精彩视频福利播放| 欧美一区二区视频免费观看| 在线观看一区二区视频| 91久久一区二区| 91行情网站电视在线观看高清版| av成人免费在线| 风间由美一区二区三区在线观看 | 欧美激情在线免费观看| 久久久久久久久久电影| 久久精品网站免费观看| 久久久久久久久一| 日本一区二区三区四区| 久久精品国产秦先生| 欧美成人艳星乳罩| 欧美男女性生活在线直播观看| 欧美视频一区二区三区四区 | 欧美日韩日本视频| 精品国产乱码久久久久久夜甘婷婷| 国产精品超碰97尤物18| 久久精品久久综合| 欧美综合亚洲图片综合区| 日本一区二区三区四区在线视频| 日本强好片久久久久久aaa| 色中色一区二区| 中文字幕乱码久久午夜不卡| 美脚の诱脚舐め脚责91 | 精品一区二区在线观看| 91福利精品视频| 国产精品你懂的| 国产在线视频一区二区| 欧美一区二区三区视频在线观看| 18成人在线视频| 国产成人免费9x9x人网站视频| 欧美精品在线一区二区三区| 亚洲婷婷综合色高清在线| 高清在线观看日韩| 欧美成人三级电影在线| 日韩福利视频导航| 欧美日韩精品久久久| 亚洲丝袜美腿综合| 国产成人在线观看| 久久―日本道色综合久久| 蜜桃av一区二区在线观看| 欧美一区二区视频网站| 国产日韩亚洲欧美综合| 色88888久久久久久影院按摩| 国产精品麻豆视频| 成人av动漫在线| 中文字幕欧美日韩一区| 国产jizzjizz一区二区|