ユーザ用ツール

サイト用ツール


softdev:pic18

差分

このページの2つのバージョン間の差分を表示します。

この比較画面へのリンク

両方とも前のリビジョン前のリビジョン
次のリビジョン
前のリビジョン
softdev:pic18 [2012/02/19 22:55] – [コンフィグbit] kingsoftdev:pic18 [2013/07/15 20:25] (現在) – 外部編集 127.0.0.1
行 31: 行 31:
 #pragma config EBTRB = OFF //Boot Block Table Read Protection #pragma config EBTRB = OFF //Boot Block Table Read Protection
 </code> </code>
 +INTIO2のような定数は、どこにも定義が無いのだが、IDEの中のヘルプに書かれており認識するようである。それぞれの持つ意味は、PICのデータシートから紐解くしか無い。いまいちよくわかっとらん。
 +
 ===== Delay ===== ===== Delay =====
 サンプルで用意されていたDelay関数が無くなっちゃった。あるのか知れんけど。よくわからんから重宝してたのですが、で、includeフォルダをみたら、delays.hと言うのがあった。わたしも、あんまりよくわかってないので、行き当たりばったりでよくないんですが。 サンプルで用意されていたDelay関数が無くなっちゃった。あるのか知れんけど。よくわからんから重宝してたのですが、で、includeフォルダをみたら、delays.hと言うのがあった。わたしも、あんまりよくわかってないので、行き当たりばったりでよくないんですが。
行 51: 行 53:
  
 で、なんがしか時間待ちするようであるので、オシロの波形で確認したところ、PIC18F1320で8MHz内蔵タイマで下表の結果だった。 で、なんがしか時間待ちするようであるので、オシロの波形で確認したところ、PIC18F1320で8MHz内蔵タイマで下表の結果だった。
-^  Function  ^  Results +^  Function  ^  Results   期待値  ^ 
-|Delay1KTCYx(1)  |  510us  | +|Delay1KTCYx(1)  |  510us   500us  | 
-|Delay10KTCYx(1)  |  5.1ms  | +|Delay10KTCYx(1)  |  5.1ms   5ms  | 
-|Delay100TCYx(1)  |  66us  | +|Delay100TCYx(1)  |  66us   50us  | 
-|Delay100TCYx(10)  |  550us  | +|Delay100TCYx(10)  |  550us   500us  | 
-|Delay100TCYx(100)  |  5.2ms  | +|Delay100TCYx(100)  |  5.2ms   5ms  | 
-|Delay10TCYx(1)  |  19.2us +|Delay10TCYx(1)  |  19.2us   5us  | 
-|Delay10TCYx(10)  |  79us  | +|Delay10TCYx(10)  |  79us   50us  | 
-|Delay10TCYx(20)  |  146us  | +|Delay10TCYx(20)  |  146us   100us  | 
-|Delay10TCYx(100)  |  670us  |+|Delay10TCYx(100)  |  670us   500us  |
  
  計測にPort出力のH/Lと、反転するのにif文を使っているので、その処理分追加されているので、よくわからない(条件分岐せずにポートの出力をすると670nsぐらい)けど、小さい時間は誤差が大きいようだ。内蔵タイマを4MHz設定にすると、時間は半分だった。\\  計測にPort出力のH/Lと、反転するのにif文を使っているので、その処理分追加されているので、よくわからない(条件分岐せずにポートの出力をすると670nsぐらい)けど、小さい時間は誤差が大きいようだ。内蔵タイマを4MHz設定にすると、時間は半分だった。\\
行 80: 行 82:
  
  
 +===== 定義済定数 =====
 +参考書とかでは、ポートの出力、例えばポートAのビット0は、RA0=1 などの記述で1出力できたのだが、PIC18Fでは大量のWarningが出る。そのままでも動作に問題は無いのだが、気持ち悪い。RA0の記述が非推奨のようである。
 +
 +ヘッダファイルを見ると、PORTAbits.RA0と記載するのかな。でも長いなぁ
 +
 +<code c>
 +extern volatile union {
 +    struct {
 +        unsigned RB0                    :1;
 +        unsigned RB1                    :1;
 +        unsigned RB2                    :1;
 +        unsigned RB3                    :1;
 +        unsigned RB4                    :1;
 +        unsigned RB5                    :1;
 +        unsigned RB6                    :1;
 +        unsigned RB7                    :1;
 +    };
 +    struct {
 +        unsigned RB                     :8;
 +} PORTBbits @ 0xF81;
 +</code>
 + よくわからないんだけど、共用体の中に、構造体があるから、PORTBbits.RB0とPORTBbits.RBは同じメモリになるけど、PORTBbits.RB0とPORTBbits.RB1は異なるメモリにあり独立しているという意味だと思うんだけど、<del>bitが他のbitに影響を与えるようだ。</del>
 +
 +ADCONの設定をしていないせいでした。とほほ。一部のポートはADCONがデフォルトになっていると言う事もある。
  
softdev/pic18.1329659721.txt.gz · 最終更新: 2013/07/15 20:28 (外部編集)