YKNCT / YKNCT_I2C_lib

Dependents:   arim_AutoMachine

Committer:
TakushimaYukimasa
Date:
Mon May 20 08:50:57 2019 +0000
Revision:
25:0e92864e622a
Parent:
23:c4ba54d8f740
bug tubushi

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Tom0108 0:c555f844eb8d 1 #include "YKNCT_I2C.h"
Tom0108 0:c555f844eb8d 2
Tom0108 0:c555f844eb8d 3 Y_I2C::Y_I2C(PinName sda, PinName scl) : i2c(sda, scl)
Tom0108 0:c555f844eb8d 4 {
Tom0108 0:c555f844eb8d 5 i2c.frequency(100000);
Tom0108 0:c555f844eb8d 6 }
Tom0108 0:c555f844eb8d 7
Tom0108 11:c7c764e21224 8 void Y_I2C::Out_Set(OUT_I2C_Data_TypeDef *OUT_I2C_Data, uint8_t num, uint8_t value)
Tom0108 7:5b22492a5a13 9 {
Tom0108 15:23cf4a802b5b 10 (OUT_I2C_Data+num) -> out_data =value;
Tom0108 7:5b22492a5a13 11 }
Tom0108 7:5b22492a5a13 12
Tom0108 11:c7c764e21224 13 void Y_I2C::Out(OUT_I2C_Data_TypeDef *OUT_I2C_Data, uint8_t MAX)
Tom0108 7:5b22492a5a13 14 {
Tom0108 18:c631bf8fc741 15 int cnt=0; //何個出力したかを保存する
Tom0108 18:c631bf8fc741 16 int ad_cnt=0; //同じアドレスの数を保存する
Tom0108 11:c7c764e21224 17 while(cnt<MAX) {
Tom0108 11:c7c764e21224 18 char data=0;
TakushimaYukimasa 23:c4ba54d8f740 19 int tmp_address=(OUT_I2C_Data+cnt)->DevAddress+0x3B;
Tom0108 18:c631bf8fc741 20
Tom0108 18:c631bf8fc741 21 //同じアドレスの数を数える
Tom0108 18:c631bf8fc741 22 for(ad_cnt=0;; ad_cnt++) {
TakushimaYukimasa 23:c4ba54d8f740 23 if(tmp_address!=(OUT_I2C_Data+cnt+ad_cnt)->DevAddress+0x3B)
Tom0108 11:c7c764e21224 24 break;
Tom0108 11:c7c764e21224 25 }
Tom0108 18:c631bf8fc741 26 //一枚の基板に出力するデータを格納する
Tom0108 18:c631bf8fc741 27 for(int j=0; j<ad_cnt; j++) data|=(OUT_I2C_Data+cnt+j)->out_data<<j;
Tom0108 11:c7c764e21224 28
TakushimaYukimasa 23:c4ba54d8f740 29 i2c.write(((OUT_I2C_Data+cnt)->DevAddress+0x3B)<<1, &data, 1);
Tom0108 18:c631bf8fc741 30 cnt+=ad_cnt;
Tom0108 11:c7c764e21224 31 }
Tom0108 8:f7779710d64a 32 }
Tom0108 8:f7779710d64a 33
Tom0108 15:23cf4a802b5b 34 void Y_I2C::Servo_Set(SERVO_I2C_Data_TypeDef *SERVO_I2C_Data, uint8_t num, uint16_t pulse)
Tom0108 15:23cf4a802b5b 35 {
Tom0108 15:23cf4a802b5b 36 (SERVO_I2C_Data+num)->pulse=pulse;
Tom0108 15:23cf4a802b5b 37 }
Tom0108 15:23cf4a802b5b 38
Tom0108 15:23cf4a802b5b 39 //4biteづつ送信する
Tom0108 15:23cf4a802b5b 40 void Y_I2C::Servo(SERVO_I2C_Data_TypeDef *SERVO_I2C_Data, uint8_t MAX)
Tom0108 15:23cf4a802b5b 41 {
Tom0108 15:23cf4a802b5b 42 for(int i=0; i<(MAX+1)/2; i++) {
Tom0108 15:23cf4a802b5b 43 char data[4]= {0};
Tom0108 15:23cf4a802b5b 44
Tom0108 15:23cf4a802b5b 45 //MAXが奇数で最後の時
Tom0108 15:23cf4a802b5b 46 if(i==MAX/2 && MAX%2==1) {
Tom0108 15:23cf4a802b5b 47 for(int j=0; j<2; j++)
Tom0108 15:23cf4a802b5b 48 //16bitのpulse1つを8bitづつに分けてdataに保存する
Tom0108 15:23cf4a802b5b 49 data[j]=(SERVO_I2C_Data+i*2+j/2)->pulse>>(1-j%2)*8;
Tom0108 15:23cf4a802b5b 50 } else {
Tom0108 15:23cf4a802b5b 51 for(int j=0; j<4; j++)
Tom0108 15:23cf4a802b5b 52 //16bitのpulse2つを8bitづつに分けてdataに保存する
Tom0108 15:23cf4a802b5b 53 data[j]=(SERVO_I2C_Data+i*2+j/2)->pulse>>(1-j%2)*8;
Tom0108 15:23cf4a802b5b 54 }
TakushimaYukimasa 23:c4ba54d8f740 55 i2c.write(((SERVO_I2C_Data+i)->DevAddress+0x5D)<<1, data, 4);
Tom0108 15:23cf4a802b5b 56 }
Tom0108 15:23cf4a802b5b 57 }
Tom0108 15:23cf4a802b5b 58
Tom0108 8:f7779710d64a 59 void Y_I2C::In(IN_I2C_Data_TypeDef *IN_I2C_Data, uint8_t num)
Tom0108 8:f7779710d64a 60 {
Tom0108 11:c7c764e21224 61 char data;
Tom0108 10:49ffdd5cf82e 62 uint8_t array=(IN_I2C_Data+num)->Number;
Tom0108 11:c7c764e21224 63
TakushimaYukimasa 23:c4ba54d8f740 64 i2c.read(((IN_I2C_Data+num)->DevAddress+0x19)<<1, &data, 1);
Tom0108 11:c7c764e21224 65
Tom0108 11:c7c764e21224 66 (IN_I2C_Data+num)->in_data=data&1<<array;
Tom0108 1:67d5ea2ff6c1 67 }
Tom0108 1:67d5ea2ff6c1 68
Tom0108 8:f7779710d64a 69 void Y_I2C::Adc(ADC_I2C_Data_TypeDef *ADC_I2C_Data, uint8_t num)
Tom0108 0:c555f844eb8d 70 {
Tom0108 11:c7c764e21224 71 char data[8]= {0};
Tom0108 10:49ffdd5cf82e 72 uint8_t array=(ADC_I2C_Data+num)->Number;
Tom0108 0:c555f844eb8d 73
TakushimaYukimasa 25:0e92864e622a 74 i2c.read(((ADC_I2C_Data+num) -> DevAddress+42)<<1, data, 8);
Tom0108 11:c7c764e21224 75
Tom0108 11:c7c764e21224 76 (ADC_I2C_Data+num)->adc_data=data[array*2+1]<<8|data[array*2];
Tom0108 0:c555f844eb8d 77 }
Tom0108 0:c555f844eb8d 78
Tom0108 9:f892d57a6714 79 void Y_I2C::Enc(ENC_I2C_Data_TypeDef *ENC_I2C_Data, uint8_t num)
Tom0108 3:397a179b4d9e 80 {
Tom0108 11:c7c764e21224 81 char data[4]= {0};
Tom0108 3:397a179b4d9e 82
TakushimaYukimasa 23:c4ba54d8f740 83 i2c.read(((ENC_I2C_Data+num) -> DevAddress+0x4C)<<1, data, 4);
Tom0108 3:397a179b4d9e 84
Tom0108 9:f892d57a6714 85 (ENC_I2C_Data+num)->enc_data=data[3]<<24|data[2]<<16|data[1]<<8|data[0];
Tom0108 3:397a179b4d9e 86 }
Tom0108 3:397a179b4d9e 87
Tom0108 9:f892d57a6714 88 void Y_I2C::MD_I2C(MD_I2C_Data_TypeDef *MD_I2C_Data, uint8_t num)
Tom0108 2:f5faf991cd86 89 {
Tom0108 2:f5faf991cd86 90 /* 送信データ
Tom0108 2:f5faf991cd86 91 [0] [ MD出力更新 | 0 | 0 | 0 | 0 | ブレーキ | 回転方向 | MD指定 ]
Tom0108 2:f5faf991cd86 92 [1] PWM値(7bit)
Tom0108 2:f5faf991cd86 93 */
Tom0108 0:c555f844eb8d 94
Tom0108 2:f5faf991cd86 95 /* 送信データをMD更新フラグを立てて初期化 */
Tom0108 9:f892d57a6714 96 (MD_I2C_Data + num)->pData[0] = 0x80;
Tom0108 2:f5faf991cd86 97 /* モーターの駆動状態によってデータセット */
Tom0108 9:f892d57a6714 98 switch (MD_GET_DRIVE(MD_I2C_Data, num)) {
Tom0108 2:f5faf991cd86 99 /* ブレーキ,ブレーキビット 1,回転方向ビット 0 */
Tom0108 2:f5faf991cd86 100 /* 0b00000100 */
Tom0108 2:f5faf991cd86 101 case MD_BRAKE:
Tom0108 9:f892d57a6714 102 (MD_I2C_Data + num)->pData[0] |= 0x02 << 1;
Tom0108 2:f5faf991cd86 103 break;
Tom0108 2:f5faf991cd86 104 /* 正転,ブレーキビット 0,回転方向ビット 1 */
Tom0108 2:f5faf991cd86 105 /* 0b00000001 */
Tom0108 2:f5faf991cd86 106 case MD_FORWARD:
Tom0108 9:f892d57a6714 107 (MD_I2C_Data + num)->pData[0] |= 0x01 << 1;
Tom0108 2:f5faf991cd86 108 break;
Tom0108 2:f5faf991cd86 109 /* 逆転,ブレーキビット 0,回転方向ビット 0 */
Tom0108 2:f5faf991cd86 110 /* 0b00000000 */
Tom0108 2:f5faf991cd86 111 case MD_REVERSE:
Tom0108 9:f892d57a6714 112 (MD_I2C_Data + num)->pData[0] |= 0x00 << 1;
Tom0108 2:f5faf991cd86 113 break;
Tom0108 2:f5faf991cd86 114 }
Tom0108 0:c555f844eb8d 115
Tom0108 2:f5faf991cd86 116 /* PIC上の出力番号を指定 */
Tom0108 2:f5faf991cd86 117 /* 0b00000000 or 0b00000001 */
Tom0108 9:f892d57a6714 118 (MD_I2C_Data + num)->pData[0] |= (MD_I2C_Data + num)->Number;
Tom0108 2:f5faf991cd86 119 /* PWM値が100より大きかったら範囲内に補正 */
Tom0108 9:f892d57a6714 120 if (MD_GET_PWM(MD_I2C_Data, num) > 99)
Tom0108 9:f892d57a6714 121 MD_SET_PWM(MD_I2C_Data, num, 99);
Tom0108 1:67d5ea2ff6c1 122
Tom0108 2:f5faf991cd86 123 /* PWM(0~100)を0~127に変換して代入(オーバーフロー防止で16bitに一時変換) */
Tom0108 9:f892d57a6714 124 (MD_I2C_Data + num)->pData[1] = (uint8_t)((uint16_t)MD_GET_PWM(MD_I2C_Data, num) * 127 / 100);
Tom0108 2:f5faf991cd86 125
Tom0108 2:f5faf991cd86 126 /*8bitから7bitに変換*/
Tom0108 9:f892d57a6714 127 i2c.write((MD_I2C_Data + num)->DevAddress << 1,(MD_I2C_Data + num)->pData,2);
Tom0108 2:f5faf991cd86 128 }
Tom0108 1:67d5ea2ff6c1 129
Tom0108 2:f5faf991cd86 130 /**
Tom0108 2:f5faf991cd86 131 * @brief MDに通信確認用送信
Tom0108 2:f5faf991cd86 132 * @param MD_I2C_Data: I2C式MDデータ構造
Tom0108 9:f892d57a6714 133 * @param num: 使用MD番号
Tom0108 2:f5faf991cd86 134 * @retval なし
Tom0108 2:f5faf991cd86 135 * @detail I2C式MD側が通信が切れていないことを確認するために空データを送信する
Tom0108 2:f5faf991cd86 136 */
Tom0108 9:f892d57a6714 137 void Y_I2C::MD_I2C_Empty(MD_I2C_Data_TypeDef *MD_I2C_Data, uint8_t num)
Tom0108 2:f5faf991cd86 138 {
Tom0108 2:f5faf991cd86 139 /* 送信データをMD更新フラグを立てず初期化 */
Tom0108 9:f892d57a6714 140 (MD_I2C_Data+num)->pData[0] = 0;
Tom0108 1:67d5ea2ff6c1 141
Tom0108 2:f5faf991cd86 142 /* PIC上の出力番号を指定 */
Tom0108 2:f5faf991cd86 143 /* 0b00000000 or 0b00000001 */
Tom0108 9:f892d57a6714 144 (MD_I2C_Data+num)->pData[0] |= (MD_I2C_Data+num)->Number;
Tom0108 2:f5faf991cd86 145
Tom0108 2:f5faf991cd86 146 /*8bitから7bitに変換*/
Tom0108 9:f892d57a6714 147 i2c.write((MD_I2C_Data + num)->DevAddress << 1,(MD_I2C_Data + num)->pData,2);
Tom0108 2:f5faf991cd86 148 }