打印
[PIC®/AVR®/dsPIC®产品]

PIC16F18326时程序不能正常运行

[复制链接]
353|14
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
llljh|  楼主 | 2022-11-5 14:49 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
PIC16F18326时程序不能正常运行

使用特权

评论回复
沙发
llljh|  楼主 | 2022-11-5 14:53 | 只看该作者
想在PIC16F18326中写一个简单的IO控制测试程序,编译和烧写都正常,但是用万能表检测IO电平时无论怎么写代码都不能出正常的效果

使用特权

评论回复
板凳
llljh|  楼主 | 2022-11-5 18:21 | 只看该作者
同样的代码在PIC16f1829中正常运行

使用特权

评论回复
地板
huangchui| | 2022-11-5 18:25 | 只看该作者
一模一样?

使用特权

评论回复
5
llljh|  楼主 | 2022-11-5 18:27 | 只看该作者
除了一些配置位不同

使用特权

评论回复
6
午夜粪车| | 2022-11-5 18:30 | 只看该作者
楼主程序可以公开吗?贴程序看下吧,这么说看不出什么原因

使用特权

评论回复
7
llljh|  楼主 | 2022-11-5 18:33 | 只看该作者

#include <stdio.h>
#include <stdlib.h>

// PIC16F18326 Configuration Bit Settings

// 'C' source line config statements

// CONFIG1
#pragma config FEXTOSC = XT     // FEXTOSC External Oscillator mode Selection bits (XT (crystal oscillator) from 100 kHz to 4 MHz)
#pragma config RSTOSC = HFINT1  // Power-up default value for COSC bits (HFINTOSC (1MHz))
#pragma config CLKOUTEN = OFF   // Clock Out Enable bit (CLKOUT function is disabled; I/O or oscillator function on OSC2)
#pragma config CSWEN = ON       // Clock Switch Enable bit (Writing to NOSC and NDIV is allowed)
#pragma config FCMEN = ON       // Fail-Safe Clock Monitor Enable (Fail-Safe Clock Monitor is enabled)

// CONFIG2
#pragma config MCLRE = ON       // Master Clear Enable bit (MCLR/VPP pin function is MCLR; Weak pull-up enabled)
#pragma config PWRTE = OFF      // Power-up Timer Enable bit (PWRT disabled)
#pragma config WDTE = ON        // Watchdog Timer Enable bits (WDT enabled, SWDTEN is ignored)
#pragma config LPBOREN = OFF    // Low-power BOR enable bit (ULPBOR disabled)
#pragma config BOREN = ON       // Brown-out Reset Enable bits (Brown-out Reset enabled, SBOREN bit ignored)
#pragma config BORV = LOW       // Brown-out Reset Voltage selection bit (Brown-out voltage (Vbor) set to 2.45V)
#pragma config PPS1WAY = ON     // PPSLOCK bit One-Way Set Enable bit (The PPSLOCK bit can be cleared and set only once; PPS registers remain locked after one clear/set cycle)
#pragma config STVREN = ON      // Stack Overflow/Underflow Reset Enable bit (Stack Overflow or Underflow will cause a Reset)
#pragma config DEBUG = OFF      // Debugger enable bit (Background debugger disabled)

// CONFIG3
#pragma config WRT = OFF        // User NVM self-write protection bits (Write protection off)
#pragma config LVP = ON         // Low Voltage Programming Enable bit (Low Voltage programming enabled. MCLR/VPP pin function is MCLR. MCLRE configuration bit is ignored.)

// CONFIG4
#pragma config CP = OFF         // User NVM Program Memory Code Protection bit (User NVM code protection disabled)
#pragma config CPD = OFF        // Data NVM Memory Code Protection bit (Data NVM code protection disabled)

// #pragma config statements should precede project file includes.
// Use project enums instead of #define for ON and OFF.

#include <xc.h>
/*
*
*/
int main(int argc, char** argv) {

    TRISCbits.TRISC2 = 0;
    LATC2 = 1;

    while(1){
    }

    return (EXIT_SUCCESS);
}


PS:其他配置位也尝试过了
// CONFIG1
#pragma config FEXTOSC = HS     // FEXTOSC External Oscillator mode Selection bits (HS (crystal oscillator) above 4 MHz)
#pragma config RSTOSC = HFINT32 // Power-up default value for COSC bits (HFINTOSC with 2x PLL (32MHz))
#pragma config CLKOUTEN = OFF   // Clock Out Enable bit (CLKOUT function is disabled; I/O or oscillator function on OSC2)
#pragma config CSWEN = ON       // Clock Switch Enable bit (Writing to NOSC and NDIV is allowed)
#pragma config FCMEN = ON       // Fail-Safe Clock Monitor Enable (Fail-Safe Clock Monitor is enabled)

// CONFIG2
#pragma config MCLRE = OFF      // Master Clear Enable bit (MCLR/VPP pin function is digital input; MCLR internally disabled; Weak pull-up under control of port pin's WPU control bit.)
#pragma config PWRTE = ON       // Power-up Timer Enable bit (PWRT enabled)
#pragma config WDTE = OFF       // Watchdog Timer Enable bits (WDT disabled; SWDTEN is ignored)
#pragma config LPBOREN = OFF    // Low-power BOR enable bit (ULPBOR disabled)
#pragma config BOREN = ON       // Brown-out Reset Enable bits (Brown-out Reset enabled, SBOREN bit ignored)
#pragma config BORV = LOW       // Brown-out Reset Voltage selection bit (Brown-out voltage (Vbor) set to 2.45V)
#pragma config PPS1WAY = ON     // PPSLOCK bit One-Way Set Enable bit (The PPSLOCK bit can be cleared and set only once; PPS registers remain locked after one clear/set cycle)
#pragma config STVREN = ON      // Stack Overflow/Underflow Reset Enable bit (Stack Overflow or Underflow will cause a Reset)
#pragma config DEBUG = ON      // Debugger enable bit (Background debugger disabled)

// CONFIG3
#pragma config WRT = OFF        // User NVM self-write protection bits (Write protection off)
#pragma config LVP = OFF        // Low Voltage Programming Enable bit (High Voltage on MCLR/VPP must be used for programming.)

// CONFIG4
#pragma config CP = OFF          // User NVM Program Memory Code Protection bit (User NVM code protection enabled)
#pragma config CPD = OFF         // Data NVM Memory Code Protection bit (Data NVM code protection enabled)

使用特权

评论回复
8
chenjunt| | 2022-11-5 18:35 | 只看该作者
这个跟你的外围电路应该也有关系吧,用的内部时钟还是外部的?

使用特权

评论回复
9
zhaoxqi| | 2022-11-5 18:37 | 只看该作者
这个跟你的电路应该也有关系吧,用的内部时钟还是外部的?

使用特权

评论回复
10
llljh|  楼主 | 2022-11-5 18:39 | 只看该作者
这种问题,如果用MCC配置初始化函数基本不会存在。

使用特权

评论回复
11
xxrs| | 2022-11-5 18:41 | 只看该作者
何必浪费时间做不必要的事情

使用特权

评论回复
12
happy_10| | 2022-11-5 18:43 | 只看该作者
看你的定义位配置,你把时钟定义成了外部晶振,实际上你的板子上是没有晶振的吧,呵呵。

使用特权

评论回复
13
llljh|  楼主 | 2022-11-5 18:48 | 只看该作者
搞定了,呵呵,犯了低级错误……

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

855

主题

11301

帖子

6

粉丝