wwwxxx国产_337p日本欧洲亚洲大胆张筱雨_免费在线看成人av_日本黄色不卡视频_国产精品成熟老女人_99视频一区_亚洲精品97久久中文字幕_免费精品视频在线_亚洲色图欧美视频_欧美一区二三区

標題: MSP430F5529硬件IIC驅動IIC接口的OLED源碼 [打印本頁]

作者: 837877663    時間: 2018-7-17 10:01
標題: MSP430F5529硬件IIC驅動IIC接口的OLED源碼
  1. //******************************************************************************
  2. //   MSP430F552x Demo - USCI_B0, I2C Master multiple byte TX/RX
  3. //
  4. //   Description: I2C master communicates to I2C slave sending and receiving
  5. //   3 different messages of different length. I2C master will enter LPM0 mode
  6. //   while waiting for the messages to be sent/receiving using I2C interrupt.
  7. //   ACLK = NA, MCLK = SMCLK = DCO 16MHz.
  8. //
  9. //                                     /|\ /|\
  10. //                   MSP430F5529       4.7k |
  11. //                 -----------------    |  4.7k
  12. //            /|\ |             P3.1|---+---|-- I2C Clock (UCB0SCL)
  13. //             |  |                 |       |
  14. //             ---|RST          P3.0|-------+-- I2C Data (UCB0SDA)
  15. //                |                 |
  16. //                |                 |
  17. //                |                 |
  18. //                |                 |
  19. //                |                 |
  20. //                |                 |
  21. //
  22. //   Nima Eskandari
  23. //   Texas Instruments Inc.
  24. //   April 2017
  25. //   Built with CCS V7.0
  26. //******************************************************************************

  27. #include <msp430.h>
  28. #include <stdint.h>
  29. #include <stdbool.h>
  30. #include "oledfont.h"

  31. //******************************************************************************
  32. // Example Commands ************************************************************
  33. //******************************************************************************
  34. #define X_WIDTH         128
  35. #define Y_WIDTH         64
  36. #define OLED_CMD  0        //寫命令
  37. #define OLED_DATA 1        //寫數據
  38. #define SLAVE_ADDR  0x3C

  39. /* CMD_TYPE_X_SLAVE are example commands the master sends to the slave.
  40. * The slave will send example SlaveTypeX buffers in response.
  41. *
  42. * CMD_TYPE_X_MASTER are example commands the master sends to the slave.
  43. * The slave will initialize itself to receive MasterTypeX example buffers.
  44. * */

  45. #define CMD_TYPE_0_SLAVE      0
  46. #define CMD_TYPE_1_SLAVE      1
  47. #define CMD_TYPE_2_SLAVE      2

  48. #define CMD_TYPE_0_MASTER      3
  49. #define CMD_TYPE_1_MASTER      4
  50. #define CMD_TYPE_2_MASTER      5

  51. #define TYPE_0_LENGTH   1
  52. #define TYPE_1_LENGTH   2
  53. #define TYPE_2_LENGTH   6

  54. #define MAX_BUFFER_SIZE     20

  55. /* MasterTypeX are example buffers initialized in the master, they will be
  56. * sent by the master to the slave.
  57. * SlaveTypeX are example buffers initialized in the slave, they will be
  58. * sent by the slave to the master.
  59. * */

  60. uint8_t MasterType2 [TYPE_2_LENGTH] = {'F', '4', '1', '9', '2', 'B'};
  61. uint8_t MasterType1 [28] = {0xae,0x00,0x10,0x40,0x81,0xcf,0xa1,0xc8,0xa6,0xa8,0x3f,0xd3,0x00,0xd5,0x80,0xd9,0xf1,0xda,0x12,0xdb,0x40,0x20,0x02,0x8d,0x14,0xa4,0xa6,0xaf};
  62. uint8_t MasterType0 [1] = {0};


  63. uint8_t SlaveType2 [TYPE_2_LENGTH] = {0};
  64. uint8_t SlaveType1 [TYPE_1_LENGTH] = {0};
  65. uint8_t SlaveType0 [TYPE_0_LENGTH] = {0};

  66. void delay(unsigned int z)
  67. {
  68.   unsigned int x,y;
  69.   for(x=z;x>0;x--)
  70.     for(y=5000;y>0;y--);
  71. }

  72. //******************************************************************************
  73. // General I2C State Machine ***************************************************
  74. //******************************************************************************

  75. typedef enum I2C_ModeEnum{
  76.     IDLE_MODE,
  77.     NACK_MODE,
  78.     TX_REG_ADDRESS_MODE,
  79.     RX_REG_ADDRESS_MODE,
  80.     TX_DATA_MODE,
  81.     RX_DATA_MODE,
  82.     SWITCH_TO_RX_MODE,
  83.     SWITHC_TO_TX_MODE,
  84.     TIMEOUT_MODE
  85. } I2C_Mode;

  86. /* Used to track the state of the software state machine*/
  87. I2C_Mode MasterMode = IDLE_MODE;

  88. /* The Register Address/Command to use*/
  89. uint8_t TransmitRegAddr = 0;

  90. /* ReceiveBuffer: Buffer used to receive data in the ISR
  91. * RXByteCtr: Number of bytes left to receive
  92. * ReceiveIndex: The index of the next byte to be received in ReceiveBuffer
  93. * TransmitBuffer: Buffer used to transmit data in the ISR
  94. * TXByteCtr: Number of bytes left to transfer
  95. * TransmitIndex: The index of the next byte to be transmitted in TransmitBuffer
  96. * */
  97. uint8_t ReceiveBuffer[MAX_BUFFER_SIZE] = {0};
  98. uint8_t RXByteCtr = 0;
  99. uint8_t ReceiveIndex = 0;
  100. uint8_t TransmitBuffer[MAX_BUFFER_SIZE] = {0};
  101. uint8_t TXByteCtr = 0;
  102. uint8_t TransmitIndex = 0;

  103. /* I2C Write and Read Functions */

  104. /* For slave device with dev_addr, writes the data specified in *reg_data
  105. *
  106. * dev_addr: The slave device address.
  107. *           Example: SLAVE_ADDR
  108. * reg_addr: The register or command to send to the slave.
  109. *           Example: CMD_TYPE_0_MASTER
  110. * *reg_data: The buffer to write
  111. *           Example: MasterType0
  112. * count: The length of *reg_data
  113. *           Example: TYPE_0_LENGTH
  114. *  */
  115. I2C_Mode I2C_Master_WriteReg(uint8_t dev_addr, uint8_t reg_addr, uint8_t *reg_data, uint8_t count);

  116. /* For slave device with dev_addr, read the data specified in slaves reg_addr.
  117. * The received data is available in ReceiveBuffer
  118. *
  119. * dev_addr: The slave device address.
  120. *           Example: SLAVE_ADDR
  121. * reg_addr: The register or command to send to the slave.
  122. *           Example: CMD_TYPE_0_SLAVE
  123. * count: The length of data to read
  124. *           Example: TYPE_0_LENGTH
  125. *  */
  126. I2C_Mode I2C_Master_ReadReg(uint8_t dev_addr, uint8_t reg_addr, uint8_t count);
  127. void CopyArray(uint8_t *source, uint8_t *dest, uint8_t count);

  128. I2C_Mode I2C_Master_ReadReg(uint8_t dev_addr, uint8_t reg_addr, uint8_t count)
  129. {
  130.     /* Initialize state machine */
  131.     MasterMode = TX_REG_ADDRESS_MODE;
  132.     TransmitRegAddr = reg_addr;
  133.     RXByteCtr = count;
  134.     TXByteCtr = 0;
  135.     ReceiveIndex = 0;
  136.     TransmitIndex = 0;

  137.     /* Initialize slave address and interrupts */
  138.     UCB0I2CSA = dev_addr;
  139.     UCB0IFG &= ~(UCTXIFG + UCRXIFG);       // Clear any pending interrupts
  140.     UCB0IE &= ~UCRXIE;                       // Disable RX interrupt
  141.     UCB0IE |= UCTXIE;                        // Enable TX interrupt

  142.     UCB0CTL1 |= UCTR + UCTXSTT;             // I2C TX, start condition
  143.     __bis_SR_register(LPM0_bits + GIE);              // Enter LPM0 w/ interrupts

  144.     return MasterMode;

  145. }


  146. I2C_Mode I2C_Master_WriteReg(uint8_t dev_addr, uint8_t reg_addr, uint8_t *reg_data, uint8_t count)
  147. {
  148.     /* Initialize state machine */
  149.     MasterMode = TX_REG_ADDRESS_MODE;
  150.     TransmitRegAddr = reg_addr;

  151.     //Copy register data to TransmitBuffer
  152.     CopyArray(reg_data, TransmitBuffer, count);

  153.     TXByteCtr = count;
  154.     RXByteCtr = 0;
  155.     ReceiveIndex = 0;
  156.     TransmitIndex = 0;

  157.     /* Initialize slave address and interrupts */
  158.     UCB0I2CSA = dev_addr;
  159.     UCB0IFG &= ~(UCTXIFG + UCRXIFG);       // Clear any pending interrupts
  160.     UCB0IE &= ~UCRXIE;                       // Disable RX interrupt
  161.     UCB0IE |= UCTXIE;                        // Enable TX interrupt

  162.     UCB0CTL1 |= UCTR + UCTXSTT;             // I2C TX, start condition
  163.     __bis_SR_register(LPM0_bits + GIE);              // Enter LPM0 w/ interrupts

  164.     return MasterMode;
  165. }

  166. void CopyArray(uint8_t *source, uint8_t *dest, uint8_t count)
  167. {
  168.     uint8_t copyIndex = 0;
  169.     for (copyIndex = 0; copyIndex < count; copyIndex++)
  170.     {
  171.         dest[copyIndex] = source[copyIndex];
  172.     }
  173. }

  174. //******************************************************************************
  175. // Device Initialization *******************************************************
  176. //******************************************************************************

  177. void initClockTo16MHz()
  178. {
  179.     UCSCTL3 |= SELREF_2;                      // Set DCO FLL reference = REFO
  180.     UCSCTL4 |= SELA_2;                        // Set ACLK = REFO
  181.     __bis_SR_register(SCG0);                  // Disable the FLL control loop
  182.     UCSCTL0 = 0x0000;                         // Set lowest possible DCOx, MODx
  183.     UCSCTL1 = DCORSEL_5;                      // Select DCO range 16MHz operation
  184.     UCSCTL2 = FLLD_0 + 487;                   // Set DCO Multiplier for 16MHz
  185.                                               // (N + 1) * FLLRef = Fdco
  186.                                               // (487 + 1) * 32768 = 16MHz
  187.                                               // Set FLL Div = fDCOCLK
  188.     __bic_SR_register(SCG0);                  // Enable the FLL control loop

  189.     // Worst-case settling time for the DCO when the DCO range bits have been
  190.     // changed is n x 32 x 32 x f_MCLK / f_FLL_reference. See UCS chapter in 5xx
  191.     // UG for optimization.
  192.     // 32 x 32 x 16 MHz / 32,768 Hz = 500000 = MCLK cycles for DCO to settle
  193.     __delay_cycles(500000);//
  194.     // Loop until XT1,XT2 & DCO fault flag is cleared
  195.     do
  196.     {
  197.         UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); // Clear XT2,XT1,DCO fault flags
  198.         SFRIFG1 &= ~OFIFG;                          // Clear fault flags
  199.     }while (SFRIFG1&OFIFG);                         // Test oscillator fault flag
  200. }


  201. void initGPIO()
  202. {
  203.     //I2C Pins
  204.     P3SEL |= BIT0 + BIT1;                     // P3.0,1 option select

  205. }

  206. void initI2C()
  207. {
  208.     UCB0CTL1 |= UCSWRST;                      // Enable SW reset(復位使能)
  209.     UCB0CTL0 = UCMST + UCMODE_3 + UCSYNC;     //  Master, I2C,synchronous mode(同步模式)
  210.     UCB0CTL1 = UCSSEL_2 + UCSWRST;            // Use SMCLK, keep SW reset
  211.     UCB0BR0 = 160;                            // fSCL = SMCLK/160 = ~100kHz
  212.     UCB0BR1 = 0;
  213.     UCB0I2CSA = SLAVE_ADDR;                   // Slave Address is 048h
  214.     UCB0CTL1 &= ~UCSWRST;                     // Clear SW reset, resume operation
  215.     UCB0IE |= UCNACKIE;                       //使能中斷
  216. }

  217. void OLED_WrCmd(unsigned char IIC_Command)
  218. {
  219.         MasterType0[0]=IIC_Command;
  220.       I2C_Master_WriteReg(SLAVE_ADDR, 0x00,MasterType0, 1);
  221. }

  222. void OLED_WrDat(unsigned char IIC_Data)
  223. {
  224.         MasterType0[0]=IIC_Data;
  225.       I2C_Master_WriteReg(SLAVE_ADDR, 0x40,MasterType0, 1);
  226. }

  227. //******************************************************************************
  228. // Main ************************************************************************
  229. // Send and receive three messages containing the example commands *************
  230. //******************************************************************************

  231. void OLED_Fill(unsigned char bmp_dat)
  232. {
  233.         unsigned char y,x;
  234.         for(y=0;y<8;y++)
  235.         {
  236.                 OLED_WrCmd(0xb0+y);
  237.                 OLED_WrCmd(0x01);
  238.                 OLED_WrCmd(0x10);
  239.                 for(x=0;x<128;x++)
  240.                 OLED_WrDat(bmp_dat);
  241.         }
  242. }

  243. void OLED_Set_Pos(unsigned char x, unsigned char y)
  244. {
  245.         OLED_WrCmd(0xb0+y);
  246.         OLED_WrCmd(((x&0xf0)>>4)|0x10);
  247.         OLED_WrCmd((x&0x0f)|0x01);
  248. }

  249. void OLED_Init(void)
  250. {
  251.         unsigned char i=0;
  252.         for(;i<28;i++)
  253.         {
  254.           MasterType0[0]=MasterType1[i];
  255.           I2C_Master_WriteReg(SLAVE_ADDR, 0x00,MasterType0, 1);
  256.         }
  257.         OLED_Fill(0x00); //初始清屏
  258.         OLED_Set_Pos(0,0);
  259. }

  260. void OLED_WR_Byte(unsigned dat,unsigned cmd)
  261. {
  262.         if(cmd)
  263.                         {

  264.    OLED_WrDat(dat);
  265.    
  266.                 }
  267.         else {
  268.    OLED_WrCmd(dat);
  269.                
  270.         }
  271. }


  272. void OLED_ShowChar(unsigned char x,unsigned char y,unsigned char chr,unsigned char Char_Size)
  273. {           
  274.         unsigned char c=0,i=0;       
  275.                 c=chr-' ';//得到偏移后的值                       
  276.                 if(x>128-1){x=0;y=y+2;}
  277.                 if(Char_Size ==16)
  278.                         {
  279.                         OLED_Set_Pos(x,y);       
  280.                         for(i=0;i<8;i++)
  281.                         OLED_WR_Byte(F8X16[c*16+i],OLED_DATA);
  282.                         OLED_Set_Pos(x,y+1);
  283.                         for(i=0;i<8;i++)
  284.                         OLED_WR_Byte(F8X16[c*16+i+8],OLED_DATA);
  285.                         }
  286.                         else {       
  287.                                 OLED_Set_Pos(x,y);
  288.                                 for(i=0;i<6;i++)
  289.                                 OLED_WR_Byte(F6x8[c][i],OLED_DATA);
  290.                                
  291.                         }
  292. }

  293. void OLED_U32toU16(unsigned char x,unsigned char y ,unsigned int n,unsigned char k)
  294. {
  295.         switch(n)
  296.         {
  297.                 case 0 :OLED_ShowChar(x,y,'0',k);break;
  298.                 case 1 :OLED_ShowChar(x,y,'1',k);break;
  299.                 case 2 :OLED_ShowChar(x,y,'2',k);break;
  300.                 case 3 :OLED_ShowChar(x,y,'3',k);break;
  301.                 case 4 :OLED_ShowChar(x,y,'4',k);break;
  302.                 case 5 :OLED_ShowChar(x,y,'5',k);break;
  303.                 case 6 :OLED_ShowChar(x,y,'6',k);break;
  304.                 case 7 :OLED_ShowChar(x,y,'7',k);break;
  305.                 case 8 :OLED_ShowChar(x,y,'8',k);break;
  306.                 case 9 :OLED_ShowChar(x,y,'9',k);break;
  307.         }
  308. }

  309. void OLED_Show_Number(unsigned char x,unsigned char y ,unsigned int a,unsigned char n)
  310. {
  311.         unsigned int b,c,d,e,f,g;
  312.         b=a/100000;
  313.         c=a%100000/10000;
  314.         d=a%10000/1000;
  315.         e=a%1000/100;
  316.         f=a%100/10;
  317.         g=a%10;
  318.         if(b!=0)
  319.         {
  320.                 OLED_U32toU16(x,y,b,n);
  321.                 OLED_U32toU16(x+n/2,y,c,n);
  322.                 OLED_U32toU16(x+n,y,d,n);
  323.                 OLED_U32toU16(x+(n/2)*3,y,e,n);
  324.                 OLED_U32toU16(x+2*n,y,f,n);
  325.                 OLED_U32toU16(x+(n/2)*5,y,g,n);
  326.         }else if(b==0&&c!=0)
  327.         {
  328.                 OLED_U32toU16(x,y,c,n);
  329.                 OLED_U32toU16(x+n/2,y,d,n);
  330.                 OLED_U32toU16(x+n,y,e,n);
  331.                 OLED_U32toU16(x+(n/2)*3,y,f,n);
  332.                 OLED_U32toU16(x+2*n,y,g,n);
  333.         }else if(b==0&&c==0&&d!=0)
  334.         {
  335.                 OLED_U32toU16(x,y,d,n);
  336.                 OLED_U32toU16(x+n/2,y,e,n);
  337.                 OLED_U32toU16(x+n,y,f,n);
  338.                 OLED_U32toU16(x+(n/2)*3,y,g,n);
  339.         }else if(b==0&&c==0&&d==0&&e!=0)
  340.         {
  341.                 OLED_U32toU16(x,y,e,n);
  342.                 OLED_U32toU16(x+n/2,y,f,n);
  343.                 OLED_U32toU16(x+n,y,g,n);
  344.         }else if(b==0&&c==0&&d==0&&e==0&&f!=0)
  345.         {
  346.                 OLED_U32toU16(x,y,f,n);
  347.                 OLED_U32toU16(x+n/2,y,g,n);
  348.         }else
  349.         {
  350.                 OLED_U32toU16(x,y,g,n);
  351.         }
  352. }

  353. int main(void) {

  354.     WDTCTL = WDTPW | WDTHOLD;                 // Stop watchdog timer

  355.     initClockTo16MHz();                        //配置系統時鐘為16Mhz
  356.     initGPIO();
  357.     initI2C();
  358.     delay(500);
  359.     OLED_Init();
  360.     OLED_Show_Number(0,0,500,16);
  361.     __bis_SR_register(LPM0_bits + GIE);
  362. }

  363. //******************************************************************************
  364. // I2C Interrupt ***************************************************************
  365. //******************************************************************************

  366. #if defined(__TI_COMPILER_VERSION__) || defined(__IAR_SYSTEMS_ICC__)
  367. #pragma vector=USCI_B0_VECTOR
  368. __interrupt void USCI_B0_ISR(void)
  369. #elif defined(__GNUC__)
  370. void __attribute__ ((interrupt(USCI_B0_VECTOR))) USCI_B0_ISR (void)
  371. #else
  372. #error Compiler not supported!
  373. #endif
  374. {
  375.   //Must read from UCB0RXBUF
  376.   uint8_t rx_val = 0;

  377.   switch(__even_in_range(UCB0IV,0xC))
  378.   {
  379.     case USCI_NONE:break;                             // Vector 0 - no interrupt
  380.     case USCI_I2C_UCALIFG:break;                      // Interrupt Vector: I2C Mode: UCALIFG
  381.     case USCI_I2C_UCNACKIFG:break;                    // Interrupt Vector: I2C Mode: UCNACKIFG
  382.     case USCI_I2C_UCSTTIFG:break;                     // Interrupt Vector: I2C Mode: UCSTTIFG
  383.     case USCI_I2C_UCSTPIFG:break;                     // Interrupt Vector: I2C Mode: UCSTPIFG
  384.     case USCI_I2C_UCRXIFG:
  385.         rx_val = UCB0RXBUF;
  386.         if (RXByteCtr)
  387.         {
  388.           ReceiveBuffer[ReceiveIndex++] = rx_val;
  389.           RXByteCtr--;
  390.         }

  391.         if (RXByteCtr == 1)
  392.         {
  393.           UCB0CTL1 |= UCTXSTP;
  394.         }
  395.         else if (RXByteCtr == 0)
  396.         {
  397.           UCB0IE &= ~UCRXIE;
  398.           MasterMode = IDLE_MODE;
  399.           __bic_SR_register_on_exit(CPUOFF);      // Exit LPM0
  400.         }
  401.         break;                      // Interrupt Vector: I2C Mode: UCRXIFG
  402.     case USCI_I2C_UCTXIFG:
  403.         switch (MasterMode)
  404.         {
  405.           case TX_REG_ADDRESS_MODE:
  406.               UCB0TXBUF = TransmitRegAddr;
  407.               if (RXByteCtr)
  408.                   MasterMode = SWITCH_TO_RX_MODE;   // Need to start receiving now
  409.               else
  410.                   MasterMode = TX_DATA_MODE;        // Continue to transmission with the data in Transmit Buffer
  411.               break;

  412.           case SWITCH_TO_RX_MODE:
  413.               UCB0IE |= UCRXIE;              // Enable RX interrupt
  414.               UCB0IE &= ~UCTXIE;             // Disable TX interrupt
  415.               UCB0CTL1 &= ~UCTR;            // Switch to receiver
  416.               MasterMode = RX_DATA_MODE;    // State state is to receive data
  417.               UCB0CTL1 |= UCTXSTT;          // Send repeated start
  418.               if (RXByteCtr == 1)
  419.               {
  420.                   //Must send stop since this is the N-1 byte
  421.                   while((UCB0CTL1 & UCTXSTT));
  422.                   UCB0CTL1 |= UCTXSTP;      // Send stop condition
  423.               }
  424.               break;

  425.           case TX_DATA_MODE:
  426.               if (TXByteCtr)
  427.               {
  428.                   UCB0TXBUF = TransmitBuffer[TransmitIndex++];
  429.                   TXByteCtr--;
  430.               }
  431.               else
  432.               {
  433.                   //Done with transmission
  434.                   UCB0CTL1 |= UCTXSTP;     // Send stop condition
  435.                   MasterMode = IDLE_MODE;
  436.                   UCB0IE &= ~UCTXIE;                       // disable TX interrupt
  437.                   __bic_SR_register_on_exit(CPUOFF);      // Exit LPM0
  438.               }
  439.               break;

  440.           default:
  441.               __no_operation();
  442.               break;
  443.         }
  444.         break;                      // Interrupt Vector: I2C Mode: UCTXIFG
  445.     default: break;
  446.   }
  447. }
復制代碼


IIC&amp;OLED.rar

399.04 KB, 下載次數: 410, 下載積分: 黑幣 -5


作者: 1106998808    時間: 2018-7-20 23:45
用keil5打開亂碼咋回事
作者: 837877663    時間: 2018-7-24 01:37
1106998808 發表于 2018-7-20 23:45
用keil5打開亂碼咋回事

是用IAR編寫的
作者: 安仔碼頭    時間: 2018-8-9 09:26
是個好貼 我準備下載下來試試

作者: tiger_work    時間: 2018-10-29 22:50
好貼,可惜積分不夠,很想下載來試一下。
作者: tiger_work    時間: 2018-10-31 10:54
剛好有個其他LCD要硬件IIC接口,在樓主的基礎上改了一下測試OK,謝謝樓主分享!
作者: tiger_work    時間: 2018-11-7 15:58
發現有個問題,在運行1-2小時后會宕機,屏幕顯示刷新一部分后面刷新不動,重啟運行又是正常的,I2C頻率改慢也是一樣的,上拉電阻使用4.7K.
作者: 胡日日    時間: 2019-6-16 12:40
switch(__even_in_range(UCB0IV,0xC))因為我用的芯片頭文件里沒有找到UCB0IV,可以用其他的
作者: 胡日日    時間: 2019-6-16 12:44
switch(__even_in_range(UCB0IV,0xC)),因為用的不是F5529,在頭文件中沒有找到UCB0IV,可以用其他的代替嗎?
作者: slg17    時間: 2019-7-2 23:33
這個我最近在用不錯
作者: 佩西范    時間: 2019-7-27 19:40
這是官方例程嗎
作者: 請問POI自行車    時間: 2019-10-14 17:44
謝謝,太有用了!!!
作者: 燭龍...    時間: 2020-3-23 08:32
能顯示漢自嗎?
作者: abcque    時間: 2020-9-24 11:33
請問下OLED這個怎么作為子函數使用啊
作者: 15638859771    時間: 2021-6-25 16:20
您好 為什么我的IIC配置進不去中斷呢?
作者: 哈哈哈嘞    時間: 2021-7-23 17:52
1106998808 發表于 2018-7-20 23:45
用keil5打開亂碼咋回事

msp430好像只能用ccs或者iar for msp430
作者: wj520yyj    時間: 2021-7-25 09:58
怎么接線
作者: 2759986970    時間: 2021-7-27 15:59
driverlib.h顯示找不到是怎么回事
作者: 慕風    時間: 2021-7-30 21:07
想問一下移植了您的程序為什么程序會卡在這里不動啊  if (RXByteCtr == 1)         {           UCB0CTL1 |= UCTXSTP;《----這一行         }         else if (RXByteCtr == 0) 我只不過用的是ccs啊
作者: 時間里的螳螂    時間: 2021-8-3 20:20
問一下,sda和scl的io接口3.0和3.1換成別打接口(比如3.5和3.6),程序怎么改,我直接改mainc里面那個gpio沒用
作者: wyy2546676927    時間: 2022-3-10 15:05
好代碼,下載用用了
作者: hyh500    時間: 2022-7-1 17:39
837877663 發表于 2018-7-24 01:37
是用IAR編寫的

可以用gcc打開

作者: 吳維榮    時間: 2023-7-28 00:35
1106998808 發表于 2018-7-20 23:45
用keil5打開亂碼咋回事

軟件編碼改一下就可以了
作者: 2210002313    時間: 2023-8-1 22:11
tiger_work 發表于 2018-10-29 22:50
好貼,可惜積分不夠,很想下載來試一下。

很容易得的
作者: wwgl    時間: 2024-7-17 23:40
1106998808 發表于 2018-7-20 23:45
用keil5打開亂碼咋回事

編譯語言錯了,換一種就可以
作者: bai_yun_123    時間: 2025-6-13 00:04
先下載再說,多謝分享, 好用再回來留言




歡迎光臨 (http://www.izizhuan.cn/bbs/) Powered by Discuz! X3.1
久久久精品区| 天天综合天天做天天综合| av不卡一区二区| 福利在线视频导航| 精品国产一区二区三区不卡在线| 日本天堂在线视频| 成人一区二区三区仙踪林| 懂色av粉嫩av蜜臀av| 国产欧美一区二区三区视频| 亚洲国产91色在线| 亚洲成人av中文| xnxx国产精品| 麻豆精品一区二区综合av| re久久精品视频| 台湾成人免费视频| 午夜毛片在线| 97国产在线| 午夜高潮免费视频| 亚洲奶汁xxxx哺乳期| 久久网免费视频| 色天使在线视频| 国产高清视频网站| 免费国产成人看片在线| 成人黄色av播放免费| 美女性感视频久久久| 日韩欧美国产成人一区二区| 99精品国产一区二区三区| 四虎国产精品免费久久| av2020不卡| 最新97超碰在线| 美乳中文字幕| 九九夜夜操妹子| 欧美做爰猛烈大尺度视频| 一级黄色小视频| 91浏览器在线观看| 夫妻性生活毛片| 国产精品无码一区二区三区免费| av污在线观看| 久久久久久久久久久视频| 午夜探花在线观看| 亚洲欧洲日夜超级视频| 久久久综合香蕉尹人综合网| 亚洲aa中文字幕| 国产精品成久久久久三级| 高清欧美性猛交xxxx黑人猛交| 蜜桃视频免费观看一区| 韩日精品视频| 一区二区三区在线| 日韩综合精品| 欧美特黄一级大片| 国产九一精品| 加勒比久久综合| 国产精品探花在线观看| www.丝袜精品| 国内毛片久久| 东京久久高清| 大桥未久女教师av一区二区| 亚洲精品一区在线| av综合网页| 国产精品久久久网站| 99精品国产一区二区三区2021| 国产精品美女久久久久| 精品国产一区二| 亚洲伊人影院| 琪琪久久久久日韩精品| 天堂成人娱乐在线视频免费播放网站 | 欧美大片免费高清观看| 午夜激情在线播放| 黄瓜视频成人app免费| 深夜成人在线| 成人午夜一级| 91视频亚洲| 免费欧美网站| 亚洲香蕉视频| 国产精品一区二区99| 精品日韩毛片| 欧美三区不卡| 翔田千里一区二区| 久久国产精品免费| 丁香婷婷综合激情五月色| 97精品电影院| 亚洲视频资源在线| 亚洲va韩国va欧美va精品| 婷婷中文字幕综合| 欧美日韩一级大片网址| 精品福利在线导航| 永久免费看mv网站入口亚洲| 久久资源免费视频| 国产91精品久久久久久久| 欧美一区中文字幕| 亚洲国产91色在线| 欧美成人自拍视频| 国产精品一区二区三区毛片淫片| 999久久久| 亚洲一区二区三区色| 成人性生活视频免费看| 999这里有精品| 熟女俱乐部一区二区视频在线| 日韩高清dvd碟片| 国产精品欧美综合| 在线天堂中文www视软件| 全部免费的黄色毛片| 天海翼女教师无删减版电影| 中文字幕日本在线观看| 92国产精品| 欧美日韩一区二区三区不卡视频| 欧美高清日韩| 国产最新精品免费| 国产精品美女久久福利网站| 日韩欧美精品网站| 免费在线日韩av| 99re视频这里只有精品| 亚洲一区二区三区不卡国产欧美| 欧美日韩一区二区在线观看视频| 日韩精品中文字幕视频在线| 久久久久久久久久久免费精品| 国产精品一区专区欧美日韩| 日韩高清av电影| 黄色片久久久久| 午夜理伦三级做爰电影| 亚洲精品男人的天堂| 中文在线天堂网www| 天堂色在线视频| 1024在线播放| 国产精品一区二区三区美女| 亚洲三级电影在线观看| 97久久人人超碰| 91成人在线免费观看| 中文字幕视频一区二区在线有码| 国产日本欧美一区| 999久久欧美人妻一区二区| 亚洲av午夜精品一区二区三区| 久久老司机精品视频| 在线亚洲日本| 美日韩在线观看| 国产免费不卡| 欧美1区免费| 久久久国际精品| 欧美男男青年gay1069videost| 欧美黑人极品猛少妇色xxxxx| 国产伦视频一区二区三区| 久久婷婷国产91天堂综合精品| 国产精品18在线| 囯产精品久久久久久| 亚洲an天堂an在线观看| 人在线成免费视频| 欧美+亚洲+精品+三区| 欧美韩国日本不卡| 精品国产免费人成在线观看| 欧美黄色www| 日韩高清av| 亚洲一区二区三区三州| 无码人妻久久一区二区三区| 国产美女在线看| 2019中文字幕在线视频| 日韩av中文字幕一区| 亚洲一区国产| 午夜日韩在线观看| 中文字幕亚洲欧美日韩高清| 国产精品日韩欧美一区二区| 最新av免费在线观看| 日韩欧美性视频| 久热中文字幕在线精品首页| 黄色大片在线看| 琪琪久久久久日韩精品| 免费的成人av| 欧美视频一区在线| 欧美高清视频免费观看| 精品久久久无码人妻字幂| 东方伊人免费在线观看| 蜜桃久久一区二区三区| 首播影院在线观看免费观看电视| 精品一区二区三区在线观看视频 | 亚洲国产欧美91| 97久久久久久久| 丰满少妇在线观看网站| 黄色软件视频在线观看| 午夜av一区| 国产精品久久久久久久久久久免费看 | 香蕉精品视频在线观看| 国产精品电影一区二区| 亚洲色图第三页| 欧美极品日韩| 日韩深夜福利| 97se在线视频| 国产95亚洲| 高清免费成人av| 久久国产精品露脸对白| 亚洲精品福利视频网站| 久久亚洲欧美日韩精品专区| 免费观看视频www| 777午夜精品电影免费看| 99久久久久久| 国内精品小视频| 岛国大片在线免费观看| 美女高潮黄又色高清视频免费| 亚洲免费一区三区| 亚洲天堂免费看| 成人激情在线观看| 久久久久久久极品内射| 青青草视频免费在线观看| 亚洲午夜在线| 日韩电影视频免费| 亚洲 中文字幕 日韩 无码| 无码精品视频一区二区三区| 在线看欧美视频| 国产网站一区二区| 国产在线a不卡| 私库av在线播放| 在线影视一区| 欧美亚洲一级| 亚洲色图15p| 少妇高潮一69aⅹ| 人人干人人爱人人爱| 日韩在线理论| 日韩一区二区在线观看视频播放| 亚洲熟妇av日韩熟妇在线| 香蕉久久视频| 偷拍自拍亚洲色图| 91久久精品一区二区三| 中文字幕一区二区三区精彩视频 | 欧美裸体男粗大视频在线观看 | 69久久夜色| 国产成人在线视频免费播放| 青青a在线精品免费观看| 午夜爱爱毛片xxxx视频免费看| 伊人免费在线| 久久精品日产第一区二区三区高清版| 成人a免费视频| 日韩精选在线观看| 国产欧美在线观看免费| 欧美日韩中文字幕在线| av一区二区三区免费观看| 人与动物性xxxx| 免费一级在线观看| 99riav久久精品riav| 国产不卡一区二区在线观看| 国产精品丝袜黑色高跟鞋| 国产精品一区免费在线| 欧美影院精品一区| 91av俱乐部| 91大神影片| 国产综合色在线| 亚洲一区二区三区在线视频 | 美女精品视频在线| 日韩一二三区视频| 日本少妇一区二区三区| 午夜美女福利视频| 亚洲精品国模| 亚洲性线免费观看视频成熟| 成人网站免费观看| 亚洲小说区图片| 亚洲国产精品精华液网站| 亚洲美免无码中文字幕在线 | 日韩和欧美一区二区三区| 538国产精品一区二区在线| 国产真实的和子乱拍在线观看| 唐人社导航福利精品| 欧美日韩视频不卡| 宇都宫紫苑在线播放| 国产www.大片在线| 亚洲三级小视频| 福利视频一二区| 国产三级视频| www.性欧美| 亚洲亚洲精品三区日韩精品在线视频| 国产精品冒白浆免费视频| 麻豆成人精品| 91成人免费看| 亚洲欧美另类色图| 久久福利精品| yy111111少妇影院日韩夜片| 777片理伦片在线观看| 1024成人| 欧美日韩精品二区| 免费在线激情视频| 中文字幕乱在线伦视频乱在线伦视频| 久久久久久97三级| 国产片侵犯亲女视频播放| 人人做人人爽| 久久久久久久综合| av在线免费观看国产| 激情六月婷婷| 国产偷国产偷亚洲高清人白洁| 欧美一级中文字幕| 116美女写真午夜一级久久| 国产欧美视频一区二区| 久久亚洲国产成人精品无码区| 好吊的妞视频这里都有| 国产欧美精品国产国产专区| www.日本少妇| 涩涩视频在线观看免费| 亚洲一区视频在线| 日本中文字幕观看| 超碰人人在线| 欧美高清一级片在线| 黄色av片三级三级三级免费看| 日韩电影免费观看高清完整版在线观看| 亚洲国产精品一区二区三区| 欧美精品99久久久| 精品成人自拍视频| 国模gogo一区二区大胆私拍| 国产a级免费视频| 一区二区91| 久久久一本精品99久久精品66| 春意影院午夜免费入口| 国产日韩在线不卡| 波多野结衣天堂| 丝袜国产在线| 精品国产91亚洲一区二区三区婷婷| 九九这里只有精品视频| 美腿丝袜亚洲图片| 欧洲日韩成人av| 日韩国产成人| 成人免费视频视频| www国产黄色| 欧美草逼视频| 日韩精品视频三区| 天天天天天天天干| 亚洲国产一区二区三区高清| 99中文字幕| 天天做天天摸天天爽天天爱| 亚洲欧美另类综合偷拍| 国产视频精品视频| 精品视频在线播放一区二区三区| 久久高清视频免费| 日韩在线视频第一页| 国产精品99久久久久久宅男| 精品久久一二三| 天堂va在线| 精品亚洲aⅴ在线观看| 一区二区视频网站| 日韩和欧美的一区| 成人免费a级片| 怡红院在线观看| 亚洲男人天堂2019| 亚洲天堂国产精品| 日韩国产精品大片| 国产免费一区二区视频| 成人在线影视| 亚洲片av在线| 老牛影视av牛牛影视av| 国产盗摄一区二区三区| 密臀av一区二区三区| 亚洲免费福利| 欧美激情精品久久久久久| 亚洲综合爱爱久久网| 国产亚洲欧美色| 国产 xxxx| 天堂资源在线亚洲| 91精品国产一区二区三区动漫 | 麻豆传媒一区二区三区| 免费一级特黄毛片| av在线网页| 另类天堂视频在线观看| 亚洲精品天堂在线| 国产精品视频在线看| 精品少妇人妻一区二区黑料社区| 九九综合久久| 精品欧美一区二区久久久伦| 亚洲日本高清| 日韩成人av网| 黄色aaa毛片| 久久一留热品黄| 无码人妻精品一区二区三区温州 | 一区二区日韩精品| 人人妻人人澡人人爽人人欧美一区| 国产99久久精品| 亚洲视频天天射| 欧美精品乱码| 亚洲成人精品电影在线观看| 麻豆视频在线播放| 久久精品久久精品亚洲人| 精品午夜福利视频| 99在线精品免费视频九九视| 免费拍拍拍网站| 精品网站在线| 国产一区视频在线| 在线欧美一级视频| 日韩成人av一区| www.四虎网站| 午夜国产精品一区| 老熟妇一区二区三区| 国产成人精品1024| 无码任你躁久久久久久老妇| 日韩精品午夜| 天天做天天躁天天躁| 欧美极品在线| 动漫美女被爆操久久久| 欧美日韩国产综合视频| 中文字幕亚洲无线码在线一区| 国产秒拍福利视频露脸| 欧美性猛交xxxx免费看| 中国女人真人一级毛片| 成人国产在线观看| 中文字幕第24页| 日韩电影免费在线看| 久久久久亚洲av无码网站| 日韩欧美网站| 国产精品12345|