📄 msp430x20x3_usi_09.s43
字号:
;******************************************************************************
; MSP430F20xx Demo - I2C Slave Transmitter, single byte
;
; Description: I2C Slave communicates with I2C Master using
; the USI. Slave data is sent and increments from 0x00 with each transmitted
; byte which is verified by the Master.
; LED off for address or data Ack; LED on for address or data NAck.
; ACLK = n/a, MCLK = SMCLK = Calibrated 1MHz
;
; ***THIS IS THE SLAVE CODE***
;
; Slave Master
; (msp430x20x3_usi_06.s43)
; MSP430F20x2/3 MSP430F20x2/3
; ----------------- -----------------
; /|\| XIN|- /|\| XIN|-
; | | | | | |
; --|RST XOUT|- --|RST XOUT|-
; | | | |
; LED <-|P1.0 | | |
; | | | P1.0|-> LED
; | SDA/P1.7|------->|P1.7/SDA |
; | SCL/P1.6|<-------|P1.6/SCL |
;
; Note: internal pull-ups are used in this example for SDA & SCL
;
; P. Thanigai
; Texas Instruments Inc.
; May 2007
; Built with IAR Embedded Workbench Version: 3.42A
;******************************************************************************
#include "msp430x20x2.h"
#define I2CState R4
#define slav_data R5
#define slav_add R6
;-------------------------------------------------------------------------------
RSEG CSTACK ; Define stack segment
;-------------------------------------------------------------------------------
RSEG CODE ; Assemble to Flash memory
EVEN
;-------------------------------------------------------------------------------
RESET mov.w #SFE(CSTACK),SP ; Initialize stackpointer
StopWDT mov.w #WDTPW+WDTHOLD,&WDTCTL ; Stop watchdog timer
SetupDCO mov.b &CALBC1_1MHZ,&BCSCTL1 ; Set DCO
mov.b &CALDCO_1MHZ,&DCOCTL
SetupP1 mov.b #0xC0,&P1OUT ; P1.6 & P1.7 pullups
bis.b #0xC0,&P1REN ; P1.6 & P1.7 Pullups
mov.b #0xFF,&P1DIR ; unused pins output direction
SetupP2 clr.b &P2OUT
mov.b #0xFF,&P2DIR
SetupUSI mov.b #USIPE6+USIPE7+USISWRST,&USICTL0; Port, I2C slave
mov.b #USIIE+USII2C+USISTTIE,&USICTL1 ; Enable I2C mode,interrupts
mov.b #USICKPL,&USICKCTL ; Setup clock polarity
bis.b #USIIFGCC,&USICNT ; Disable automatic clear control
bic.b #USISWRST,&USICTL0 ; Enable USI
bic.b #USIIFG,&USICTL1 ; Clear pending flag
clr.w I2CState
clr.b slav_data
mov.b #0x90,slav_add
Mainloop
bis.w #LPM0+GIE,SR ; Enter LPM0, enable interrupts
nop
jmp Mainloop ; Again
;-------------------------------------------------------------------------------
USI_ISR ;
;-------------------------------------------------------------------------------
bit.b #USISTTIFG,&USICTL1 ; Start entry?
jnc Check_State
bis.b #0x01,&P1OUT ; turn on LED, sequence start
mov.w #2,I2CState ; First I2C state, Rx address
Check_State add.w I2CState,PC ; I2C State Machine
jmp STATE0
jmp STATE2
jmp STATE4
jmp STATE6
jmp STATE8
jmp STATE10
jmp STATE12
STATE0 nop ; Idle, should not get here
bic.b #USIIFG,&USICTL1
reti
STATE2 ; Rx slave address
mov.b &USICNT,R8 ; Bit counter = 8, Rx address
and.b #0xE0,R8
add.b #0x8,R8
mov.b R8,&USICNT
bic.b #USISTTIFG,&USICTL1 ; Clear Start flag
mov.w #4,I2CState ; Go to next state, chk address
bic.b #USIIFG,&USICTL1
reti
STATE4 ; Process address and send (N)Ack
bit.b #0x01,&USISRL ; If read
jnc Chk_Add
inc.b slav_add ; Save R/W bit
Chk_Add bis.b #USIOE,&USICTL0 ; SDA = output
cmp.b slav_add,&USISRL ; Address match?
jnz Address_NACK
clr.b &USISRL ; Send Ack
bic.b #0x01,&P1OUT ; LED off
mov.w #8,I2CState ; Go to next state: Tx data
bis.b #0x01,&USICNT ; Bit counter = 1, Send Ack
bic.b #USIIFG,&USICTL1
reti
Address_NACK
mov.b #0xFF,&USISRL ; Send NACK
bis.b #0x1,&P1OUT ; LED on:error
mov.w #6,I2CState ; go to next state, prep stop
bis.b #0x01,&USICNT
bic.b #USIIFG,&USICTL1
reti
STATE6 ; Prep for Re-start condition
bic.b #USIOE,&USICTL0 ; SDA = input
mov.b #0x90,slav_add ; Reset Slave address
clr.w I2CState ; Reset state machine
bic.b #USIIFG,&USICTL1
reti
STATE8 ; Send Data byte
bis.b #USIOE,&USICTL0 ; SDA =output
mov.b slav_data,&USISRL ; send data byte
bis.b #0x8,&USICNT ; Bit counter = 1, SCL high, SDA low
mov.w #10,I2CState ; go to next state, generate stop
bic.b #USIIFG,&USICTL1
reti
STATE10 ; Rx Data (N)Ack
bic.b #USIOE,&USICTL0 ; SDA = input
bis.b #0x01,&USICNT ; Bit counter = 1, Rx data (N)Ack
mov.w #12,I2CState ; Go to next state: check (N)Ack
bic.b #USIIFG,&USICTL1
reti
STATE12 ; Process data (N)Ack
bit.b #0x01,&USISRL ; If Nack received
jnc Data_Rx ; else Ack received
bis.b #0x01,&P1OUT ; Led ON :error
bic.b #USIOE,&USICTL0 ; SDA = input
jmp STATE12_Exit
Data_Rx
bic.b #0x01,&P1OUT ; LED off
inc.b slav_data ; Increment slave data
bic.b #USIOE,&USICTL0 ; SDA = input
STATE12_Exit
mov.b #0x90,slav_add ; Reset slave address
clr.w I2CState ; Reset state machine
bic.b #USIIFG,&USICTL1
reti
;-------------------------------------------------------------------------------
; Interrupt Vectors Used MSP430x2013
;-------------------------------------------------------------------------------
COMMON INTVEC
ORG RESET_VECTOR ; MSP430 RESET Vector
DW RESET ;
ORG USI_VECTOR ; USICNT
DW USI_ISR ;
END
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -