ランダム性は、暗号セキュリティからゲームやシミュレーションまで、多くの組み込みアプリケーションで重要な役割を果たしています。
しかし、コンフィギュラブルロジックブロック(CLB)を使用して、ハードウェアベースの疑似乱数生成器(PRNG)を8ビットマイクロコントローラ上に直接実装できることをご存知でしょうか。
この記事では、CLBとSPIペリフェラルを活用したPRNGの作成方法を探ります。このハードウェア主導のアプローチにより、最小限のCPUオーバーヘッドで効率的かつ連続的な乱数生成が実現します。
PRNGとは何ですか?
疑似乱数生成器(PRNG)は、決定論的アルゴリズムによって生成される、真のランダム性を疑似した数値のシーケンスを生成します。これらのシーケンスは再現性があるため、効率的かつ制御されたランダム性が設計に不可欠な、リソースに制約のある環境に最適です。
最初の図は、PRNGの全体的な動作に必要なロジックを示しています。2番目の図は、擬似乱数シーケンスを生成する重要なコンポーネントである8ビットリニアフィードバックシフトレジスタに必要なロジックをハイライトしています。
図1:LFSR、CLB、およびSPIにより構成されるPRNG実装の概念図
図2:PRNG生成のためのLFSRコンフィギュレーションブロック図
動作の仕組み
PRNGは、以下を用いて実装しています。
- リニアフィードバックシフトレジスタ(LFSR): 特定のタップによって決定されるフィードバック関数に基づいて擬似乱数シーケンスを生成します。
- SPI: シフトレジスタとして機能し、出力を効率的に処理します。
PRNGはオールゼロ以外のシード値で初期化され、連続した動作を確保し、実行中のロックアップを防止します。
実装の概要
ハードウェア要件
- マイクロコントローラPIC16F13145、CLBおよびSPIペリフェラル付き
- Curiosity Nano開発ボード
- その他、CLBとSPIペリフェラル付きPIC16Fマイクロコントローラ
コンフィギュレーション用の MPLAB® Code Configurator (MCC)
コンフィギュレーション手順
- CLBを構成:PRNGと8ビットLFSRサブモジュールに必要なロジックを実装するようにCLBを構成します。上記の図を参照してください。SPIをモード1で使用して、疑似ランダム出力をシフトし、観測します。
- ペリフェラルを駆動するために安定したクロック源(例えばHFINTOSC)を割り当てます。
コードの例
PRNGは、MCC SPI APIを使用してオンボードスイッチでトリガされ、SPI(SS、SDI、SCK)およびUARTを介して、確認済みの疑似乱数を出力します。
int main(void) {
SYSTEM_Initialize();
SPI_Open(CLIENT_CONFIG);
__delay_ms(100);
while (1) {
if (SWITCH_GetValue() == 0) {
if (SPI1_IsRXReady()) printf("\n\rRead byte: %x", SPI1_ByteRead());
}
}
}
テストおよび結果
UARTまたはオシロスコープでSPIピンの出力を観測してPRNGを確認して下さい。生成されたシーケンスは、以下のように安定した擬似ランダム動作を示します。
図3:テスト中にキャプチャされたPRNGの出力例
CLBベースPRNGのアプリケーション
- 暗号機能
- データスクランブリング
- ゲームアルゴリズム
- シミュレーションとモデリング
このアプローチは、ハードウェアベースのロジックを活用することで、CPUの負荷を軽減し、システム設計を簡素化します。
詳細はこちら
PRNGの実装やその他のコンフィギュラブルロジックブロックの例については、こちらをご覧ください。
- Pseudo-Random Number Generator CLB File
- Configurable Logic Block Peripheral Overview
- https://mchp.us/40KL1zK