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

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

?? f12x_smbus_master_multibyte.c

?? C8051F120 MCU 的SMBUS總線通訊程序
?? C
?? 第 1 頁 / 共 2 頁
字號:
//-----------------------------------------------------------------------------
// F12x_SMBus_Master_Multibyte.c
//-----------------------------------------------------------------------------
// Copyright 2006 Silicon Laboratories, Inc.
// http://www.silabs.com
//
// Program Description:
//
// Example software to demonstrate the C8051F12x SMBus interface in
// Master mode.
// - Interrupt-driven SMBus implementation
// - Only master states defined (no slave or arbitration)
// - multiple-byte SMBus data holders used for each transmit and receive
// - Timer3 used by SMBus for SCL low timeout detection
// - SCL frequency defined by <SMB_FREQUENCY> constant
// - ARBLOST support included
// - supports multiple-byte writes and multiple-byte reads
// - Pinout:
//    P0.0 -> SDA (SMBus)
//    P0.1 -> SCL (SMBus)
//
//    P1.6 -> LED
//
//    all other port pins unused
//
// How To Test:
//
// 1) Download code to a 'F12x device that is connected to a SMBus slave.
// 2) Run the code:
//         a) The test will indicate proper communication with the slave by
//            toggling the LED on and off each time a value is sent and
//            received.
//         b) The best method to view the proper functionality is to run to
//            the indicated line of code in the TEST CODE section of main and
//            view the SMB_DATA_IN and SMB_DATA_OUT variable arrays in the
//            Watch Window.
//
//
// FID:            12X000018
// Target:         C8051F12x
// Tool chain:     Keil C51 7.50 / Keil EVAL C51
// Command Line:   None
//
// Release 1.0
//    -Initial Revision (TP)
//    -19 APR 2006
//

//-----------------------------------------------------------------------------
// Includes
//-----------------------------------------------------------------------------

#include <C8051F120.h>                 // SFR declarations

//-----------------------------------------------------------------------------
// Global CONSTANTS
//-----------------------------------------------------------------------------

#define  SYSCLK         6125000L       // System clock frequency in Hz

#define  SMB_FREQUENCY  10000L         // Target SCL clock rate
                                       // This example supports between 10kHz
                                       // and 100kHz

#define  WRITE          0x00           // WRITE direction bit
#define  READ           0x01           // READ direction bit

// Device addresses (7 bits, lsb is a don't care)
#define  SLAVE_ADDR     0xF0           // Device address for slave target

#define  MY_ADDR        0x02           // Address of this SMBus device
                                       // (dummy value since this device does
                                       // not have any defined slave states)

#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


#define  NUM_BYTES_WR   3              // Number of bytes to write
                                       // Master -> Slave
#define  NUM_BYTES_RD   3              // Number of bytes to read
                                       // Master <- Slave

//-----------------------------------------------------------------------------
// Global VARIABLES
//-----------------------------------------------------------------------------

// Global holder for SMBus data
// All receive data is written here
unsigned char SMB_DATA_IN[NUM_BYTES_RD];

// Global holder for SMBus data.
// All transmit data is read from here
unsigned char SMB_DATA_OUT[NUM_BYTES_WR];


unsigned char TARGET;                  // Target SMBus slave address

bit SMB_BUSY;                          // Software flag to indicate when the
                                       // SMB_Read() or SMB_Write() functions
                                       // have claimed the SMBus

bit SMB_RW;                            // Software flag to indicate the
                                       // direction of the current transfer

unsigned long NUM_ERRORS;              // Counter for the number of errors.

// 16-bit SFR declarations
sfr16    RCAP3    = 0xCA;              // Timer3 reload registers
sfr16    TMR3     = 0xCC;              // Timer3 counter registers

sbit LED = P1^6;                       // LED on P1.6

sbit SDA = P0^0;                       // SMBus on P0.0
sbit SCL = P0^1;                       // and P0.1

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

void SYSCLK_Init(void);
void Port_Init(void);
void SMBus_Init(void);
void Timer3_Init(void);

void SMBus_ISR(void);
void Timer3_ISR(void);

void SMB_Write (void);
void SMB_Read (void);
void T0_Wait_ms (unsigned char ms);

//-----------------------------------------------------------------------------
// MAIN Routine
//-----------------------------------------------------------------------------

void MAIN (void)
{
   volatile unsigned char dat;         // Test counter
   volatile unsigned char data_count;  // SMB_DATA_IN and SMB_DATA_OUT counter
   unsigned char i;                    // Dummy variable counters

   WDTCN = 0xde;                       // Disable watchdog timer
   WDTCN = 0xad;

   SYSCLK_Init ();                     // Set internal oscillator to a setting
                                       // of 6125000 Hz

   // If slave is holding SDA low because of an improper SMBus reset or error
   while(!SDA)
   {
      // Provide clock pulses to allow the slave to advance out
      // of its current state. This will allow it to release SDA.
      XBR1 = 0x40;                     // Enable Crossbar
      SCL = 0;                         // Drive the clock low
      for(i = 0; i < 255; i++);        // Hold the clock low
      SCL = 1;                         // Release the clock
      while(!SCL);                     // Wait for open-drain
                                       // clock output to rise
      for(i = 0; i < 10; i++);         // Hold the clock high
      XBR1 = 0x00;                     // Disable Crossbar
   }

   Port_Init ();                       // Initialize Crossbar and GPIO

   // Turn off the LED before the test starts
   LED = 0;

   SMBus_Init ();                      // Configure and enable SMBus

   Timer3_Init ();                     // Configure and enable Timer3

   EIE1 |= 0x02;                       // Enable the SMBus interrupt

   EA = 1;                             // Global interrupt enable


   SFRPAGE = SMB0_PAGE;
   SI = 0;

// TEST CODE-------------------------------------------------------------------

   dat = 0;                            // Output data counter
   NUM_ERRORS = 0;                     // Error counter
   while (1)
   {
      // SMBus Write Sequence
      for (data_count = 0; data_count < NUM_BYTES_WR; data_count++)
      {
         SMB_DATA_OUT[data_count] = dat; // Define next outgoing byte
         dat++;
      }
      TARGET = SLAVE_ADDR;             // Target the Slave for next SMBus
                                       // transfer
      SMB_Write();                     // Initiate SMBus write

      // SMBus Read Sequence
      TARGET = SLAVE_ADDR;             // Target the Slave for next SMBus
                                       // transfer
      SMB_Read();

      // Check transfer data
      for (data_count = 0; data_count < NUM_BYTES_RD; data_count++)
      {
         // Received data match transmit data?
         if(SMB_DATA_IN[data_count] != SMB_DATA_OUT[data_count])
         {
            NUM_ERRORS++;              // Increment error counter if no
                                       // match
         }
      }

      // Indicate that an error has occurred (LED no longer lit)
      if (NUM_ERRORS > 0) {
         LED = 0;
      }
      else {
         LED = ~LED;
      }

      // run to here to view the SMB_DATA_IN and SMB_DATA_OUT variable arrays

      T0_Wait_ms (1);
   }

// END TEST CODE---------------------------------------------------------------

}

//-----------------------------------------------------------------------------
// Initialization Routines
//-----------------------------------------------------------------------------

//-----------------------------------------------------------------------------
// SYSCLK_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// This routine initializes the system clock to use the internal oscillator
// at 6.125 MHz (24.5 / 4 MHz).
//
void SYSCLK_Init (void)
{
   char SFRPAGE_SAVE = SFRPAGE;        // Save Current SFR page

   SFRPAGE = CONFIG_PAGE;              // Set SFR page

   OSCICN = 0x81;                      // Set internal oscillator to run
                                       // at 1/4 its maximum frequency

   CLKSEL = 0x00;                      // Select the internal osc. as
                                       // the SYSCLK source

   SFRPAGE = SFRPAGE_SAVE;             // Restore SFR page
                                       // detector
}

//-----------------------------------------------------------------------------
// PORT_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// Configure the Crossbar and GPIO ports.
//
// P0.0   digital   open-drain    SMBus SDA
// P0.1   digital   open-drain    SMBus SCL
//
// P1.6   digital   push-pull     LED
//
// all other port pins unused
//
// Note: If the SMBus is moved, the SCL and SDA sbit declarations must also
// be adjusted.
//
void PORT_Init (void)
{
   char SFRPAGE_SAVE = SFRPAGE;        // Save Current SFR page

   SFRPAGE = CONFIG_PAGE;

   P0MDOUT = 0x00;                     // All P0 pins open-drain output

   P1MDOUT |= 0x40;                    // Make the LED (P1.6) a push-pull
                                       // output

   XBR0 = 0x01;                        // Enable SMBus on the crossbar
   XBR2 = 0x40;                        // Enable crossbar and weak pull-ups

   P0 = 0xFF;

   SFRPAGE = SFRPAGE_SAVE;             // Restore SFR page detector
}

//-----------------------------------------------------------------------------
// SMBus_Init
//-----------------------------------------------------------------------------
//
// Return Value : None
// Parameters   : None
//
// The SMBus peripheral is configured as follows:
// - SMBus enabled
// - Assert Acknowledge low (AA bit = 1b)
// - Free and SCL low timeout detection enabled
//
void SMBus_Init (void)
{
   char SFRPAGE_SAVE = SFRPAGE;        // Save Current SFR page

   SFRPAGE = SMB0_PAGE;

   SMB0CN = 0x07;                      // Assert Acknowledge low (AA bit = 1b);
                                       // Enable SMBus Free timeout detect;
                                       // Enable SCL low timeout detect

   // SMBus clock rate (derived approximation from the Tlow and Thigh equations
   // in the SMB0CR register description)
   SMB0CR = 257 - (SYSCLK / (8 * SMB_FREQUENCY));

   SMB0ADR = MY_ADDR;                  // Set own slave address.

   SMB0CN |= 0x40;                     // Enable SMBus;

   SFRPAGE = SFRPAGE_SAVE;             // Restore SFR page detector
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人午夜影院| 色噜噜夜夜夜综合网| av中文一区二区三区| 欧美日韩美少妇| 欧美激情一区二区三区四区| 香蕉av福利精品导航| 成人av资源网站| 精品日韩99亚洲| 日韩精品一二三| 色悠悠久久综合| 国产精品丝袜一区| 99久久精品国产网站| 制服丝袜一区二区三区| 亚洲色图在线视频| 国产伦精品一区二区三区免费迷| 日本精品免费观看高清观看| 日本一区二区免费在线| 免费人成在线不卡| 欧美日韩国产区一| 亚洲专区一二三| 色综合久久中文字幕综合网| 国产精品麻豆一区二区| 九色综合狠狠综合久久| 日韩一区二区在线播放| 亚欧色一区w666天堂| 91福利国产成人精品照片| 亚洲欧洲日韩在线| 99re8在线精品视频免费播放| 久久精品一区四区| 国产精品18久久久| 久久久久久久久久电影| 国产米奇在线777精品观看| 精品国产电影一区二区| 国内精品久久久久影院色| 欧美成人精精品一区二区频| 美女一区二区在线观看| 2023国产精品自拍| 国模套图日韩精品一区二区| 久久久久久久综合色一本| 国产在线精品免费| 国产亚洲精品福利| 成人黄色小视频在线观看| 国产精品美女久久久久久久久久久 | 亚洲地区一二三色| 精品视频在线免费观看| 午夜欧美一区二区三区在线播放| 欧美理论在线播放| 蜜桃一区二区三区四区| 久久综合九色综合97婷婷女人| 国产乱码字幕精品高清av| 一区二区三区在线看| 欧美日韩一区三区| 久久99精品一区二区三区| 久久精品夜夜夜夜久久| 成人性生交大片免费看视频在线| 18成人在线观看| 9191久久久久久久久久久| 老司机精品视频导航| 国产亚洲欧美色| 91国产丝袜在线播放| 日本va欧美va欧美va精品| 久久综合成人精品亚洲另类欧美 | 欧美精品一区二区三区在线播放| 国产一区二区美女诱惑| 亚洲色大成网站www久久九九| 欧美日韩成人在线一区| 国产中文字幕一区| 亚洲欧美日韩国产另类专区| 欧美一区二区三区在线看| 高清在线不卡av| 亚洲第一电影网| 久久精品网站免费观看| 在线这里只有精品| 国产一区二区美女诱惑| 亚洲一区二区美女| 久久九九久久九九| 欧美高清激情brazzers| 国产成人福利片| 日韩主播视频在线| 中文字幕日本乱码精品影院| 欧美成人在线直播| 色8久久精品久久久久久蜜| 欧美在线观看视频一区二区| jizzjizzjizz欧美| 免费观看在线色综合| 亚洲日本在线a| 久久久久久久久久电影| 欧美一级搡bbbb搡bbbb| 色婷婷综合中文久久一本| 韩国v欧美v亚洲v日本v| 亚洲成人在线免费| 亚洲欧洲色图综合| 久久日韩精品一区二区五区| 欧美美女视频在线观看| 99精品1区2区| 国产成人午夜电影网| 久热成人在线视频| 日韩黄色免费电影| 亚洲午夜在线观看视频在线| 中文字幕一区二区三区在线不卡 | 看片的网站亚洲| 亚洲大型综合色站| 亚洲一区二区不卡免费| 亚洲伦在线观看| 国产精品成人午夜| 中文字幕精品在线不卡| 久久美女艺术照精彩视频福利播放| 欧美日韩第一区日日骚| 欧美午夜在线观看| 欧美体内she精视频| 色综合天天做天天爱| 亚洲精品综合在线| 亚洲视频一区二区在线| 国产精品毛片无遮挡高清| 中文欧美字幕免费| 国产精品色哟哟| 国产精品不卡在线观看| 亚洲视频免费看| 国产精品成人在线观看| 国产精品高潮呻吟| 亚洲欧美日韩久久精品| 精品中文字幕一区二区小辣椒| 亚洲国产三级在线| 五月天一区二区三区| 日本伊人精品一区二区三区观看方式| 视频一区在线播放| 日本欧美在线观看| 捆绑变态av一区二区三区| 国产一区二区三区在线观看免费视频| 国产精品自拍av| 99久久精品国产毛片| 色吧成人激情小说| 91精品国产91久久久久久最新毛片| 欧美电影在哪看比较好| 日韩精品中文字幕在线不卡尤物 | 蜜桃av一区二区三区电影| 理论片日本一区| 国产精一品亚洲二区在线视频| 粉嫩aⅴ一区二区三区四区五区| 91网站在线观看视频| 欧美日韩国产影片| 久久精品人人做人人爽人人| 国产精品国产三级国产aⅴ入口| 亚洲永久精品大片| 久99久精品视频免费观看| 成a人片亚洲日本久久| 色播五月激情综合网| 欧美电影免费观看高清完整版在 | 一区二区在线观看免费视频播放| 亚洲成av人影院| 精品亚洲成av人在线观看| a亚洲天堂av| 欧美一区三区二区| 中文字幕一区不卡| 美腿丝袜亚洲三区| 91天堂素人约啪| 日韩免费高清av| 亚洲猫色日本管| 狠狠久久亚洲欧美| 在线观看欧美黄色| 国产偷v国产偷v亚洲高清| 亚洲国产精品久久人人爱蜜臀| 韩国毛片一区二区三区| 欧美影院午夜播放| 亚洲国产激情av| 免费看欧美女人艹b| 色诱亚洲精品久久久久久| 26uuu欧美日本| 亚洲国产aⅴ天堂久久| 粉嫩高潮美女一区二区三区| 777精品伊人久久久久大香线蕉| 国产精品久久久久精k8| 狠狠色狠狠色综合| 欧美一区二区三区四区视频| 亚洲三级电影网站| 国产精品一区在线| 日韩一区二区精品葵司在线| 一区二区在线观看免费视频播放| 国产乱人伦偷精品视频不卡| 欧美一级国产精品| 亚洲国产另类精品专区| 99热99精品| 国产精品国产三级国产普通话蜜臀| 精品亚洲国产成人av制服丝袜| 欧美精品一二三区| 亚洲综合图片区| 91视频在线观看免费| 国产精品久久久久国产精品日日| 国模娜娜一区二区三区| 欧美精品一区男女天堂| 蜜芽一区二区三区| 欧美精品日韩一本| 亚洲成av人片观看| 欧美日韩中字一区| 亚洲午夜久久久久久久久电影网 | 一区二区三区在线看| 99久久久久免费精品国产| 国产精品美女久久久久av爽李琼| 国产精品中文字幕欧美| 国产亚洲欧美激情|