DioEchoBackMultiBit


機能

出力ビットの状態を複数ビット入力します。

書式

Ret = DioEchoBackMultiBit ( Id , &BitNo[0], BitNum , &Data[0] )

引数

Id [ C, C++: short ] [ Python: ctypes.c_short ]
DioInitで取得したデバイスIDを指定します。

BitNo [ C, C++: short * ] [ Python: ctypes.POINTER(ctypes.c_short) ]
出力論理ビット番号を配列に入れて、その配列の先頭アドレスを指定します。

BitNum [ C, C++: short ] [ Python: ctypes.c_short ]
BitNoで指定したビット数を指定します。ビット数の最大値は256です。

Data [ C, C++: unsigned char *] [ Python: ctypes.POINTER(ctypes.c_ubyte) ]
出力データを格納する配列の先頭アドレスを指定します。出力データは0か1が返ります。

戻り値

Ret [ C, C++: long ] [ Python: ctypes.c_long ]

定義

[Dec]

意味

DIO_ERR_SUCCESS

0

正常終了

DIO_ERR_DLL_INVALID_ID

10001

無効なIDが指定されました。

DIO_ERR_DLL_CALL_DRIVER

10002

ドライバを呼び出せません(ioctlに失敗)。

DIO_ERR_DLL_BUFF_ADDRESS

10100

データバッファアドレスが不正です。

DIO_ERR_SYS_NOT_SUPPORTED

20001

このデバイスではこの関数は使用できません。

DIO_ERR_SYS_BIT_NO

20102

ビット番号が指定可能範囲を超えています。

DIO_ERR_SYS_BIT_NUM

20103

ビット数が指定可能範囲を超えています。

その他のエラー(参照:エラーコード詳細

初期値

出力データの初期値は、リセット後は0です。

説明

出力ビットの状態を複数ビット入力します。

この関数を呼び出す前に、BitNoで指定する配列に、入力したい出力論理ビット番号を設定しておく必要があります。
配列Dataには、BitNoで指定した論理ビットの順番にデータが格納されます。出力データは0か1が返ります。

出力されている内容をモニタする場合に使用します。

使用例

出力ビット0, 1の状態を入力します。

C, C++

long Ret;

short BitNo[2]
unsigned char Data[2];
BitNo[0] = 0;
BitNo[1] = 1;

Ret = DioEchoBackMultiBit(Id, &BitNo[0], 2, &Data[0]);
 

Python

Ret = ctypes.c_long()

BitNoType = ctypes.c_short * 2
BitNo = BitNoType()
DataType = ctypes.c_ubyte * 2
Data = DataType()
BitNo[0] = 0
BitNo[1] = 1

Ret.value = cdio.DioEchoBackMultiBit(Id, BitNo, 2, Data)
 

関連項目

DioOutByte DioOutBit DioEchoBackByte DioEchoBackBit DioOutMultiByte DioOutMultiBit DioEchoBackMultiByte 論理ビット