DSP56K(4) | Linux Programmer's Manual | DSP56K(4) |
dsp56k - DSP56001 のインターフェースデバイス
#include <asm/dsp56k.h> ssize_t read(int fd, void *data, size_t length); ssize_t write(int fd, void *data, size_t length); int ioctl(int fd, DSP56K_UPLOAD, struct dsp56k_upload *program); int ioctl(int fd, DSP56K_SET_TX_WSIZE, int wsize); int ioctl(int fd, DSP56K_SET_RX_WSIZE, int wsize); int ioctl(int fd, DSP56K_HOST_FLAGS, struct dsp56k_host_flags *flags); int ioctl(int fd, DSP56K_HOST_CMD, int cmd);
dsp56k デバイスは、メジャー番号 55、マイナー番号 0 の キャラクターデバイスである。
Motorola DSP56001 は、Atari Falcon030 互換のコンピュータで使われている フルプログラマブルな 24 ビットのデジタルシグナルプロセッサーである。 スペシャルファイル dsp56k は、DSP56001 の制御と 双方向ハンドシェイクホストポートでのデータの送受信のために使われる。
データストリームをシグナルプロセッサーに送信するためには、 デバイスに対して write(2) を使うこと。 処理されたデータを受信するためには、 read(2) を使うこと。 ホスト側では、データは 8, 16, 24, 32 ビット単位で送受信できるが、 DSP56001 内では、24 ビット単位で扱われる。
次の ioctl(2) コールが dsp56k デバイスを制御するために使われる。
ホストフラグにアクセスするためには、 ioctl(2) の 3 番目の引き数が 構造体 struct dsp56k_host_flags へのポインターでなければならない。 この構造体のメンバー dir のビット 0 または 1 が設定されると、 メンバー out の対応するビットの値がホストフラグに書き込まれる。 すべてのホストフラグの状態は、構造体のメンバー status の 下から 4 ビットとして返される。
/dev/dsp56k
linux/include/asm-m68k/dsp56k.h, linux/drivers/char/dsp56k.c, http://dsp56k.nocrew.org/, DSP56000/DSP56001 Digital Signal Processor User's Manual
この man ページは Linux man-pages プロジェクトのリリース 3.79 の一部 である。プロジェクトの説明とバグ報告に関する情報は http://www.kernel.org/doc/man-pages/ に書かれている。
2012-08-05 | Linux |