4
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

FPGA+SoC+LinuxでFPGA Managerを試してみた(まとめ2)

Last updated at Posted at 2016-07-14

注意(2017年7月29日追記)

この記事は Linux Kernel 4.4 時点に投稿したものであり、古い内容が含まれています。Linux Kernel 4.10 以降、FPGA 関連は大きく進歩しました。詳しくは「Linux Kernel 4.10 でのFPGAのサポート事情」を参照してください。

はじめに

次の記事で紹介したように、Linux Kernel 4.4.4 からFPGA Manager Framework が追加されました。

実際にどのようになっているのか、どうのように使うのかを調べるために、人柱的な感じで試用してみました。これらの実施例は次の記事を参考にしてください。

そして2016年5月の時点で 時期尚早 という結論を出しました。詳細は次の記事に書きました。

この記事ではその後ちょっと気になる情報を入手したので紹介します。

Linux Kernel for ARM Processors メーリングリストの記事

その後(2016年7月)、Linux Kernel for ARM Processors のメーリングリストに次のようなやりとりがありました。

atull (Alan Tull) という方は FPGA Manager の作者です。次のような資料も書いてらっしゃいます。

で、この方の返信に次のような記述があったのが気になりました。

Sysfs and char driver interfaces have been proposed and shot down
a few times already.

「SysFS と Char Driver interface が提案されたけど、すでに数回、撃墜されています(shot down)」

There will be use cases that will need various userspace interfaces.
It's been hard to get people who are already using FPGAs to agree
on using any one interface because they would have to change the
code they already have running.

「様々なユーザー空間インターフェースが必要なユースケースがあります。彼らが実行しているコードを変更する必要があるので、既にいずれかの FPGAのインターフェースを使用している人々の同意を得るのは困難です。」

所感

作者の投稿をみると、どうやら Linux Kernel の本家に FPGA manager user space interface が導入される見込みは低いようです。

個人的は Linux Kernel 本家が正式にフルサポートするのを期待していただけに非常に残念です。

現状では、FPGA manager はカーネル内からしか使えません。FPGA manager を使うためにはカーネルプログラム(デバイスドライバ)を書く必要があります。

どうしても使ってみたいと言う方は次の記事を参考にしてください。ユーザー空間から FPGA manager を制御する簡易的なデバイスドライバと使用例を提供しています。

4
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?