Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
メモリと遊んでみた Pert2
Search
akira345
June 11, 2016
Technology
89
0
Share
メモリと遊んでみた Pert2
LT駆動開発 26 - Extended 報告会 後朝祭
にて、SRAMをArduinoで制御してみたので報告しました。
akira345
June 11, 2016
More Decks by akira345
See All by akira345
ビジネス要件から逆算するマイクロサービスアーキテクチャ選定の「思考プロセス」
akira345
0
65
インシデント対応
akira345
0
410
えれくら!〜電気電子工作系制作・交流会〜#29
akira345
0
35
脱・同期処理!マイクロサービスにおける負荷分散の勘所
akira345
0
130
AWSデプロイツール紹介
akira345
0
79
40歳でやったこと
akira345
0
57
回路を読むために必要なこと
akira345
0
43
おれのAWSがこんなに辛い訳がない!!
akira345
0
50
Dockerを触ってみよう
akira345
0
110
Other Decks in Technology
See All in Technology
AIエージェントの権限管理 1: MCPサーバー・ツールの Fine grained access control 編
ren8k
3
490
Azure Lifecycle with Copilot CLI
torumakabe
3
1k
#jawsugyokohama 100 LT11, "My AWS Journey 2011-2026 - kwntravel"
shinichirokawano
0
330
AIを共同作業者にして書籍を執筆する方法 / How to Write a Book with AI as a Co-Creator
ama_ch
2
130
Azure Static Web Apps の自動ビルドがタイムアウトしやすくなった状況に対応した件/global-azure2026
thara0402
0
370
実践ハーネスエンジニアリング:TAKTで実現するAIエージェント制御 / Practical Harness Engineering: AI Agent Control Enabled by TAKT
nrslib
9
4.1k
AI時代 に増える データ活用先
takahal
0
170
AWS認定資格は本当に意味があるのか?
nrinetcom
PRO
1
260
自立を加速させる神器 - EMOasis #11
stanby_inc
0
120
Revisiting [CLS] and Patch Token Interaction in Vision Transformers
yu4u
0
330
EBS暗号化に失敗してEC2が動かなくなった話
hamaguchimmm
2
180
No Types Needed, Just Callable Method Check
dak2
1
110
Featured
See All Featured
A better future with KSS
kneath
240
18k
DevOps and Value Stream Thinking: Enabling flow, efficiency and business value
helenjbeal
1
160
Groundhog Day: Seeking Process in Gaming for Health
codingconduct
0
140
New Earth Scene 8
popppiees
3
2.1k
Fireside Chat
paigeccino
42
3.9k
Conquering PDFs: document understanding beyond plain text
inesmontani
PRO
4
2.6k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
133
19k
First, design no harm
axbom
PRO
2
1.2k
ピンチをチャンスに:未来をつくるプロダクトロードマップ #pmconf2020
aki_iinuma
128
55k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
32
2.9k
Designing for Timeless Needs
cassininazir
0
190
Transcript
メモリと遊んでみた LT駆動開発 26 - EXTENDED 報告会 後朝祭 AKIRA345
概要 • 去年の8月、OSC島根に遠征に行ったついでに、島根にあるパーツ屋さん でSRAMを入手。 • 近所の大学の為に電子部品を店頭にむき出しで展示していました。 • 展示されている部品に直感的にSRAMだと踏んで、交渉の末Getしました。 • 以前実験したDRAMより扱いやすいです。
メモリの種類 今回はこれ。
SRAM? • コンピュータなどに使用される半導体メモリの1種である。 ダイナミックRAM (DRAM) とは異なり、定期的なリフレッシュ(記憶保持動 作)が不要であるため「スタティック」と呼ばれる。
特徴 • DRAMのリフレッシュ動作などが不要で、制御が簡単 • データの格納されているアドレスを指定して読み書き • 書き換え回数の制限がない • バッテリで記憶を保持できる •
DRAMに比べ構成するトランジスタの量が多いので高価 • 高速に動作ができる • 容量が大きくなると、それだけ格納するビット数が増えるので、ピン数が増 える。
用途 • サターンやファミコンのバックアップメモリ • CPUの一時キャッシュ • BIOSの記録保持 • マイコンのメモリや液晶のVRAM •
プリンタやCDドライブのキャッシュメモリ • ゲーム機のRAMとして
まずは使い方を調査 • かなり古いSRAMだが、ネットでググればデータシートが出てくる。
データ出力ON! アドレス指定 8bitでデータ出力 書き込みは禁止にしておく。 チップセレクトON 制御が単純!
ここでARDUINOの登場 • とりあえず、アドレスを指定して、チップをセレクト、書き込み禁止にして 出力有効にするとデータが出る。というのは分かったので、さくっと実装。 • 例によってArduinoの動作が遅い為に動作しないという罠 • アドレス指定に十進数を用いて、SRAMのアドレス(ビット指定)にするのに 真面目に10進->2進変換ロジックを組むも遅いので動作せず(汗 •
いくつか高速化のロジックを参考にするもビット演算分かんねー • 実はArduinoのポートに10進数投げつけても、問題なかった。
少し説明 0 1 2 3 4 5 6 7 PortZ
• PortZ(仮称)という変数(正確にはレジスタ)が、マイコンの物 理的なPINに対応。 • 例では PortZ = “B0110101” のように2進数を代入するように書かれている。 • この変数に値を渡すときは2進数じゃないとダメ? • 実際はPortZ = 10 と渡しても、内部ではB00001010になるので、直接渡して問 題ないのでした。 10年以上C言語なんて触ってなかったから 忘れてたよ!!
なんだかんだと3日ばかし費やす・・・ • SRAMに読み書きすることに成功!! https://github.com/akira345/arduino_sram_test/
分かったこと • 予想通り、制御はDRAMに比べ圧倒的に楽。 • DRAMと違いデータが8bitパラレルで出てくれるのも楽。 • ちゃんとバッテリで保持できた。 • 数十年はむき出しで放置されていたと思われるけど、意外に壊れないもん だ。
• 古いSRAMなので、5Vだし動作も遅く、現代ではあまり使われないけど、 Arduinoなどで遊ぶには、80年代の古いものが扱いやすい。 • 最近のは3Vだったり高速だったり制御が複雑だったり・・ • DRAMに比べアドレスバス、データバスとPIN数が多いので配線が酷い
まとめ • 興味関心を持ったことを調べるのは楽しい。 • 頭で理解した内容が合っているのか?の検証は割と苦労する。 • 苦労した分動くとやっぱり楽しい!! • 圧倒的に基礎知識が不足している。今回ロジックではなく一番苦労したの はC言語の扱い。
• メモリ単品で扱うことは少ないのか、当たり前すぎるのか、具体的にどうや ればいいのか?という突っ込んだ説明は例によって見当たらず・・・
時間が有ればデモ