STM32F4シリーズを使ってみる2 -STM32F4のメモリ構成を理解し基礎を作る-
20111201追:
つい最近複数の方からメールでご指摘いただきましたが、私はこのwikiとは関係ありません。
私の今回の記事からいくつかの文章をコピペしてたようですが、私が後日誤りに
気付いて修正した内容は修正されずにそのままになっているようなので注意してください。
20111201追:
今回は前回述べたとおり192kByteに増強された内蔵SRAMをどのように使うかを決定し、
お約束の標準関数の使用やFPUを用いた浮動小数点の計算をSTM32F4 Discovery
上で実践してみます。
STM32F4系は192kByteのSRAMを持っていますが、実際は112kByte,16kByte,64kByte
の3ブロックに分かれています。後で図示しますが、112kByte分はAHBバスマトリクスに
接続された汎用SRAMで,16kByte分は同じくAHBバスマトリクスに接続されているものの
112kByte分のSRAMと同時に読み書きができるように(主にEtherNetMAC&USB-OTG(HS)
用に特化されているようです)なっています。アドレスは連続しているのでEthernetや
USB-OTG(HS)を使うつもりがない人は128kByte分まるまる汎用SRAMとして使用する
ことが出来ます。
その他細かい制約があるので各自データシートやマニュアルを参照のこと(丸投げ!)。
もうひとつの64kByte分はCore-Coupled Memory(CCM)と呼ばれ、Cortex-M4Fのコアに直
接接続されています。このSRAM領域はAHBバスマトリクス上にはなく、マニュアルを読
む限りではDMAの読み書き先としてこの領域を使用できないようです。
(20111026追:実際に試しましたがHardFaultになったりDMAが完了しなかったりで、
やはりDMA用のメモリとして使用できませんでした)
また、128kByte分の汎用SRAMもSTM32F4のコアクロックと同様の168MHzでアクセスできる
ので俗に言うTCM(Tightly-Coupled Memory)としての速度的優位差もほとんどないでしょう。
以上の点を踏まえて、STM32F4系でつぶしが利くようにねむいさんはSRAMの構成を下図
のようにしてみました。
64kByteもある広大なスタック領域を君はどうつかうのか!?
注:CCM領域はDMAできません!!大事なことだから2度言います!!
この構想をリンカスクリプトに落とすと下図のような感じです。
この下にも長−く各セクションの定義が続きますが省略。
この構成で前回のTFT-LCDの表示テストも改めてクリア・またprintf系の標準関数も
UARTにリターゲットして動作を確認しました。
次にFPUを使って浮動小数点の演算のテストに取り掛かりました。
Cortex-M4Fは単精度の浮動小数点ユニットを持っています。GCCコンパイラからこの機能
を使うためには浮動小数点命令に落とし込むようにフラグを与えてあげないといけません。
具体的にどういうフラグを与えるかについては酔漢氏が昨年に考察されていました。
氏の情報を元に私の環境では以下の箇所の変更で浮動小数点命令に切り替わりました。
-msoft-float("-mfloat-abi=soft"と同じ意味)
↓
-mfloat-abi=softfp -mfpu=fpv4-sp-d16
-mfpu=fpv4-sp-d16は必須です。これが無いと倍精度の命令を使ってしまい、実行
したとたんにHardFaultになってしまいます。
ちなみに-mfloat-abi=※※※※ の意味はそれぞれ以下のように表されます。
-mfloat-abi=soft :浮動小数点の演算に整数命令のみで構成された浮動小数
点演算ライブラリ(soft-float)を使う。
-mfloat-abi=softfp :浮動小数点の演算に浮動小数点演算命令を使うが、floatを
引数にする関数の呼び出し規約はsoft-floatと同じく汎用
レジスタを使って値を渡す(ソフトウエア・リンケージ)。
-mfloat-abi=hard :浮動小数点の演算に浮動小数点演算命令を使い、floatを
引数にする関数は浮動小数点レジスタを使って値を渡す。
酔漢氏のページでは"-mfloat-abi=hard"となっていました(GCC4.5.xからこのオプショ
ンが利用可能)が、無償で利用できるSourceryCodebenchLite版にある標準関数等のラ
イブラリはsoft-floatでビルドされているため、標準関数を絡めるとリンク時に引数渡し
の不整合がおきてエラーになります。これを回避するためにはCodebenchLite版のビルド済
ライブラリを使わない設定(-nostdlibオプションを付ける)を付与し、同じ機能を持つライブ
ラリを一から"-mfloat-abi=hard"でビルドしなおさなければなりません。
というわけでいちいちビルドするのめどいので以後は"-mfloat-abi=softfp"で。
20131226追:
GNU Tools for ARM Embedded Processorsなら"-mfloat-abi=hard"が使用可能です!!
これでFPUの命令を含むプログラムがビルドできるようになりましためでたしめでたし
・・・と言いたい と こ ろ だ が !
ここも嵌ると思うので記しておきます。Cortex-M4Fの仕様によるとFPUは浮動小数点命令
が行われる前に(つまり起動時)に有効にしてやらないといけません。
STM32F4xxのサンプルではsystem_stm32f4xx.cのSystemInit()の最初で実行されている
ものもありますが、テンプレートからsystem_stm32f4xx.cを生成するとこの記述が欠け
ているのでほとんどの場合は自分で追加しないといけません。
20120410変更:
実際にコンパイルオプションを変えて浮動小数点演算の箇所のアセンブラリストを
比較してみました。Launchpad提供のGNUToolchainを使用しています。
●-mfloat-abi=soft
FPUを一切使用しない場合です。FPUのレジスタは一切使用されず、また浮動小数点
演算ルーチンが呼ばれています。
●-mfloat-abi=softfp -mfpu=fpv4-sp-d16
FPUを使用する場合(SoftFP)です。関数の値は汎用レジスタで渡されています。
●-mfloat-abi=hard -mfpu=fpv4-sp-d16
FPUを使用する場合(HardFP)です。関数の値もFPUレジスタで渡されています。
printf関数は暗黙の型変換によってfloat値を渡してもdouble型に強制変換されます。
単精度のFPUしかもたないSTM32F4ではdouble型に変換するための__aeabi_f2dルーチンが
必ず挿入されます。
ってわけでこれでほぼ完全にCortex-M4Fとして開発を行う下地が整いました!
現在はSDカードとSPI接続のTFT-LCDとUARTをつなげていつものをこしらえるところまで
進みました。STM32F4 Discoveryの回路構成の都合で、SDIOとFSMCが使用できない
のでSDカードもTFTLCDもSPI接続です。はやくこいこいSTM32F407ZGT6!
あ、そうそう、Chan氏のTJpegDecも組み込ませてもらってます。
連絡・質問・免責は↑のリンクを
↓SNSもやってます↓
- ARM/STM32 (97)
- OpenOCD (25)
- ARM/NxP (34)
- ARM/Cypress (5)
- ARM/Others (3)
- AVR (6)
- FPGA (4)
- GPS/GNSS (18)
- MISC (62)
- Wirelessなアレ (16)
- ブラウザベンチマーク (28)
- 日本の自然歩道 (18)
- Windows10対応軽量シンプルな環境でARMマイコンをInsightとOpenOCDを使ってデバッグする(2020年度版)
⇒ ねむい (06/15) - いろいろ試す39(with2019年反省会)
⇒ ねむい (01/03) - いろいろ試す39(with2019年反省会)
⇒ ひかわ (01/02) - いろいろ試す39(with2019年反省会)
⇒ ひかわ (01/01) - OpenOCD小ネタ24 -ビルドするときの小ネタとかも-
⇒ あぷろ (12/27) - OpenOCD小ネタ24 -ビルドするときの小ネタとかも-
⇒ ねむい (12/20) - OpenOCD小ネタ24 -ビルドするときの小ネタとかも-
⇒ あぷろ (12/13) - OpenOCD小ネタ24 -ビルドするときの小ネタとかも-
⇒ ねむい (12/11) - OpenOCD小ネタ24 -ビルドするときの小ネタとかも-
⇒ あぷろ (12/11) - STM32H7を使ってみる4 -キャッシュ・ワンダリング(中篇)-
⇒ ねむい (11/27)
- Windows10対応軽量シンプルな環境でARMマイコンをInsightとOpenOCDを使ってデバッグする(2020年度版)

- December 2020 (3)
- November 2020 (1)
- October 2020 (1)
- September 2020 (1)
- August 2020 (1)
- July 2020 (1)
- June 2020 (2)
- May 2020 (1)
- April 2020 (1)
- March 2020 (1)
- February 2020 (1)
- January 2020 (1)
- December 2019 (3)
- November 2019 (1)
- October 2019 (1)
- September 2019 (2)
- August 2019 (1)
- July 2019 (1)
- June 2019 (1)
- May 2019 (1)
- April 2019 (1)
- March 2019 (1)
- February 2019 (1)
- January 2019 (1)
- December 2018 (3)
- November 2018 (2)
- October 2018 (1)
- September 2018 (1)
- August 2018 (1)
- July 2018 (1)
- June 2018 (1)
- May 2018 (1)
- April 2018 (2)
- March 2018 (1)
- February 2018 (1)
- January 2018 (1)
- December 2017 (2)
- November 2017 (2)
- October 2017 (1)
- September 2017 (1)
- August 2017 (1)
- July 2017 (1)
- June 2017 (1)
- May 2017 (1)
- April 2017 (1)
- March 2017 (2)
- February 2017 (2)
- January 2017 (2)
- December 2016 (7)
- November 2016 (2)
- October 2016 (2)
- September 2016 (1)
- August 2016 (1)
- July 2016 (1)
- June 2016 (1)
- May 2016 (2)
- April 2016 (1)
- March 2016 (2)
- February 2016 (1)
- January 2016 (1)
- December 2015 (3)
- November 2015 (1)
- October 2015 (3)
- September 2015 (2)
- August 2015 (2)
- July 2015 (3)
- June 2015 (3)
- May 2015 (4)
- April 2015 (2)
- March 2015 (4)
- February 2015 (1)
- January 2015 (3)
- December 2014 (3)
- November 2014 (2)
- October 2014 (1)
- September 2014 (2)
- August 2014 (2)
- July 2014 (3)
- June 2014 (2)
- May 2014 (1)
- April 2014 (1)
- March 2014 (4)
- February 2014 (4)
- January 2014 (3)
- December 2013 (5)
- November 2013 (4)
- October 2013 (3)
- September 2013 (2)
- August 2013 (2)
- July 2013 (2)
- June 2013 (3)
- May 2013 (2)
- April 2013 (2)
- March 2013 (2)
- February 2013 (2)
- January 2013 (3)
- December 2012 (4)
- November 2012 (2)
- October 2012 (2)
- September 2012 (4)
- August 2012 (1)
- July 2012 (3)
- June 2012 (2)
- May 2012 (3)
- April 2012 (3)
- March 2012 (2)
- February 2012 (3)
- January 2012 (3)
- December 2011 (5)
- November 2011 (3)
- October 2011 (2)
- September 2011 (2)
- August 2011 (2)
- July 2011 (2)
- June 2011 (2)
- May 2011 (2)
- April 2011 (2)
- March 2011 (2)
- February 2011 (2)
- January 2011 (3)
- December 2010 (7)
- November 2010 (1)
- October 2010 (1)
- September 2010 (1)
- August 2010 (3)
- July 2010 (4)
- May 2010 (1)
- April 2010 (2)
- March 2010 (2)
- February 2010 (2)
- January 2010 (3)
- December 2009 (3)
- November 2009 (8)
- October 2009 (7)
- September 2009 (5)
- August 2009 (4)
- July 2009 (6)
- June 2009 (7)
- May 2009 (14)
- January 1970 (1)


Comments
最近Cortex-m4fの開発をはじめた者です。
やりたいことは
Audio IF -> (A/D Converter) -> DMA転送 FSMC経由 SRAM 書き込み
FSMC経由 SRAM 読み込み -> FFT -> 出力
です。
FSMCのサンプルはSTMに置いてあったので
読んでいるのですが、いまいちどう使っていいのか
分からない状態です。
なにか、参考になる付属ドキュメント以外での
ポインタはありますでしょうか。
よろしくお願いします。
関西人様、はじめまして、ねむいです。
アナログ信号の処理はちょうど手を出そうと思っていた
分野で、私も現在資料集めしてる真っ最中なのでお力添え
出来なくてすみません。
あとFSMC経由で外部SRAMを大容量データメモリとして使う
試みは実は私もSTM32F1系の頃から何度も何度もチャレンジして
いますがいまだ安定化出来ていません(泣)。
使いこなしてる方もきっと居るのでしょうけど個人のノウ
ハウとなるので表にはなかなか出てこないと思います。
京美人様
最近STM32F4Discoveryを購入したyufitと申します。
本職はLSI設計エンジニアですが、趣味の電子工作は
dsPIC,mbed等でのプログラミング経験くらいで、
STM32F4は初挑戦です。
DiscoveryボードとPCをUSBケーブルで接続し、
Teraterm(もしくはHyperTerminal)で仮想COMポート経由で
通信する方法を探しております。
Discoveryボード上のUSBコネクタ(mini-USB or micro-USB)
に接続してUSART(?)で通信する事は可能でしょうか?
もしご存知でしたら教えて頂けませんでしょうか?
yufit様
ねむいです。はじめまして。
お問い合わせの件ですが、STM32F4Discovery用のVCPのデモは現在まだ公開
されていないようです。しかし、STM32F2とF4のペリフェラルは酷似していて
STM32F2用のVCPのデモは存在します。こちらを参考にF4用に作り込むことは
可能だと思います。
www.st.com/internet/mcu/product/245079.jspの下あたりに
“STM32F105/7 and STM32F2xx USB on-the-go Host and device library (UM1021)”
というUSBライブラリがそれにあたりますので参考にしてみてください。
ねむい様
ご連絡ありがとうございます。
なるほど、STM32F4用のVCPは正式版はリリースされてないのですね。
上記のURLを参考にしてみます。きっかけができたので助かりました。
ありがとうございました。ブログ頑張って下さい。
Post a Comment