C#用のインターフェースとしてクラスライブラリを提供しています。
ドライバーの関数は、クラスライブラリのメソッドから呼び出されます。
クラスライブラリ中のメソッドは、元の関数からプレフィクスを除いた形で定義されています。
元の関数からプレフィクスを除いた名称のメソッドを呼び出してください。
例)DiotInit関数の場合
Ret = dio.Init();
※ユニバーサル Windows プラットフォーム (UWP) には対応しておりません
各関数の引数、戻り値の内容は開発言語に依存せず共通です。
詳細は関数リファレンスをご参照下さい。
Visual C# ではコールバック関数による割り込みやトリガの通知を行う場合、
コールバック関数のメモリアドレスを固定するための処理を追加する必要があります。
これらの処理のために必要なコード例として、割り込み処理の場合を例として示します。
詳細はサンプルプログラムを参照してください。
■グローバル変数として宣言します。
GCHandle gCh;
PINTCALLBACK pdelegate_func;
IntPtr pfunc;
■Loadメソッドの中で割り込み処理用デリゲートを初期化し、ガベージコレクションにより破棄されないように参照を追加。
pdelegate_func= new PINTCALLBACK(CallBackProc);
gCh= GCHandle.Alloc(pdelegate_func);
■Closedメソッドの中でハンドルを開放します。
gCh.Free();
■関数の固定ポインタを取得します。
pfunc = Marshal.GetFunctionPointerForDelegate(pdelegate_func);
■DioSetInterruptCallBackProcでは取得した固定ポインタを指定します。
Ret = dio.SetInterruptCallBackProc(Id, pfunc, Temp);
Visual C#.NETではバスマスタ転送で使用するバッファに対してメモリアドレスを固定するための処理を追加する必要があります。
これらの処理のために必要なコード例を示します。詳細はサンプルプログラムを参照してください。
■グローバル変数として宣言します。
const int DATA_SIZE = 1000; //バスマスタ用バッファサイズ
GCHandle gCh;
static uint[] DataBuff = new uint[DATA_SIZE]; //バスマスタ用バッファ
IntPtr pDataBuff;
■Loadメソッドの中でバッファにPinned型のハンドルを割り当てます。
if(gCh.IsAllocated == false)
{
gCh = GCHandle.Alloc(DataBuff, GCHandleType.Pinned);
}
■Closedメソッドの中でハンドルを開放します。
if(gCh.IsAllocated == true)
{
gCh.Free();
}
■オブジェクトの固定ポインタを取得します。
pDataBuff = gCh.AddrOfPinnedObject();
■DioDmSetBufferでは取得した固定ポインタを指定します。
Ret = dio.DmSetBuffer(m_Id, Direction, pDataBuff, DATA_SIZE, (short)CdioConst.DIODM_WRITE_ONCE);