標準TTLだけ(!)でCPUをつくろう!(組立てキットです!)
(ホントは74HC、CMOSなんだけど…)
[第510回]
●PIC18F14K50をクロック48MHzで動かしてみました
前にも説明しましたように、PIC18F14K50でUSB(Full Speedモード)を使う場合には48MHzをUSBクロックとして供給しなければなりません。
PIC18F14K50には4xPLL回路が内蔵されていますから、それを使えば12MHzのクロックを供給すればよいことになります。
PIC18F14K50の内蔵発振回路では16MHzまでのクロックが得られるのですが、残念なことに12MHzはありません。
また内部回路の制約からでしょうか、内部発振クロックでPLLが利用できるのは8MHzだけに限られます。
いずれにせよ、USBのための48MHzクロックをPIC18F14K50に供給するためには、外部から12MHzクロックを与えるか、12MHzクリスタルを外付けするかのいずれかの方法しかありません(外部から48MHzクロックを直接供給することも可能ですが、それについてはここでは考えないことにします)。
ということで、いよいよPIC18F14K50でUSBのプログラムテストをするための前準備として、まずは48MHzクロックで動かしてみることにしました。
これがそのテストプログラムです。
;;;pic p18f14k50 test program
;f14k50test4
;10/5/21
;
;
#include<p18f14k50.inc>
;cpuclock=48MHz 12MHz crystal
;
CONFIG FOSC = HS,CPUDIV = NOCLKDIV,PLLEN=ON,WDTEN=OFF,LVP=OFF;not WDT
;
org 00
clrf ANSEL;PORTA,PORTC are digital
clrf ANSELH;PORTB,PORTC are digital
clrf SLRCON
clrf TRISA;porta=out
clrf TRISB;portb=out
clrf TRISC;portc=out
;
movlw 1
loop
xorwf PORTC
goto loop
;
いままでのプログラムとほとんど同じです。 CONFIGのクロックのところだけを少し書き換えています。 前回までのテストでは内部発振クロックを使いましたから、PIC18F2550をテストしたジャノ目基板の空いたところを利用しましたが、USBのテストのためには、ちょっとスペースが不足しますので、あらためて別のジャノ目基板に組みました。

LEDがいっぱいついて、ものものしい状態です。
最初はこんなすごい状態ではなかったのですが、USBでの接続でみごとにコケてしまいましたので、その原因を追求するためにこのような状態になってしまいました。
プログラムではクリスタルを外付けにする設定になっていますが、この写真では74HCU04で12MHzクリスタルを発振させたクロックを供給しています。
こちらが裏側の写真です。

●RC0からの出力波形です
プログラムを実行中のRC0からの出力波形です。

CPUクロックは48MHzです。
PORTCのビット0は3マシンクロックごとに1と0が交互に出力されます。
CPUクロックが48MHzということは、1クロックが1/48μsecということです。
PICの1マシンクロックは4CPUクロックですから、1/12μsecです。
そしてその3マシンクロックは、1/4μsecになります。
250nsecです。
今回も計算通りの出力が得られています。
2010.5.27upload
前へ
次へ
ホームページトップへ戻る