3

我是编程 ATtiny 芯片的新手。我在 Arduino 上运行了与此等效的程序并且它可以工作,但是在 ATtiny2313 上运行它时,虽然没有出现错误消息,但程序似乎冻结了。所有 PORTB 都连接到 LED,当程序运行时,备用 LED 亮起,但随后它们保持亮着而不是交换。

我正在使用 makeFile、AVRdude 和 USBtinyISP 程序员对 ATtiny 进行编程。

我认为程序一定有一些问题,我将非常感谢任何帮助。

谢谢

斯蒂芬

#include <avr/io.h>
#include <util/delay.h>

void myFunction(int status){
  if(status==1){
    PORTB = 0b10101010;
  }else{
    PORTB = 0b1010101;
  }
  int i;
  for(i=0; i<100; i++){
    _delay_ms(10);
  }
  return;
}

int main(void){
    DDRB = 0xFF;
    while(1){
        myFunction(1);
        myFunction(0);
    }
    return 0;
}

我的 Makefile 是:

DEVICE     = atmega8
CLOCK      = 8000000
PROGRAMMER = #-c stk500v2 -P avrdoper
OBJECTS    = main.o
FUSES      = -U lfuse:w:0xe4:m -U hfuse:w:0xdf:m -U efuse:w:0xff:m

# ATMega8 fuse bits used above (fuse bits for other devices are different!):
# Example for 8 MHz internal oscillator
# Fuse high byte:
# 0xd9 = 1 1 0 1   1 0 0 1 <-- BOOTRST (boot reset vector at 0x0000)
#        ^ ^ ^ ^   ^ ^ ^------ BOOTSZ0
#        | | | |   | +-------- BOOTSZ1
#        | | | |   +---------- EESAVE (set to 0 to preserve EEPROM over chip erase)
#        | | | +-------------- CKOPT (clock option, depends on oscillator type)
#        | | +---------------- SPIEN (if set to 1, serial programming is disabled)
#        | +------------------ WDTON (if set to 0, watchdog is always on)
#        +-------------------- RSTDISBL (if set to 0, RESET pin is disabled)
# Fuse low byte:
# 0x24 = 0 0 1 0   0 1 0 0
#        ^ ^ \ /   \--+--/
#        | |  |       +------- CKSEL 3..0 (8M internal RC)
#        | |  +--------------- SUT 1..0 (slowly rising power)
#        | +------------------ BODEN (if 0, brown-out detector is enabled)
#        +-------------------- BODLEVEL (if 0: 4V, if 1: 2.7V)
#
# For computing fuse byte values for other devices and options see
# the fuse bit calculator at http://www.engbedded.com/fusecalc/


# Tune the lines below only if you know what you are doing:

AVRDUDE = avrdude $(PROGRAMMER) -p $(DEVICE)
COMPILE = avr-gcc -Wall -Os -DF_CPU=$(CLOCK) -mmcu=$(DEVICE)

# symbolic targets:
all:    main.hex

.c.o:
    $(COMPILE) -c $< -o $@

.S.o:
    $(COMPILE) -x assembler-with-cpp -c $< -o $@
# "-x assembler-with-cpp" should not be necessary since this is the default
# file type for the .S (with capital S) extension. However, upper case
# characters are not always preserved on Windows. To ensure WinAVR
# compatibility define the file type manually.

.c.s:
    $(COMPILE) -S $< -o $@

flash:  all
    $(AVRDUDE) -U flash:w:main.hex:i

fuse:
    $(AVRDUDE) $(FUSES)

# Xcode uses the Makefile targets "", "clean" and "install"
install: flash fuse

# if you use a bootloader, change the command below appropriately:
load: all
    bootloadHID main.hex

clean:
    rm -f main.hex main.elf $(OBJECTS)

# file targets:
main.elf: $(OBJECTS)
    $(COMPILE) -o main.elf $(OBJECTS)

main.hex: main.elf
    rm -f main.hex
    avr-objcopy -j .text -j .data -O ihex main.elf main.hex
    avr-size --format=avr --mcu=$(DEVICE) main.elf
# If you have an EEPROM section, you must also create a hex file for the
# EEPROM and add it to the "flash" target.

# Targets for code debugging and analysis:
disasm: main.elf
    avr-objdump -d main.elf

cpp:
    $(COMPILE) -E main.c

这是默认文件,我没有更改任何原始设置。

4

2 回答 2

2

您的代码看起来正确。最可能的问题是它的构建不正确,但要解决这个问题,我们需要查看您的 Makefile。

在下面的链接(不允许我发布链接,因此您必须自己复制/粘贴)是与您的问题非常相似的人的帖子。事实证明,他没有通过链接器运行他编译的目标文件,结果是缺少一些基本库,导致 PIC 无休止地循环,试图执行无效的操作码(指令)。

efreedom dot com/Question/E-27081/Using-Avr-Gcc-Delay-Ms-Causes-Chip-Freeze

如果这不能解决问题,请尝试发布您的 Makefile。

此外,没有理由调用 _delay_ms(10) 100 次,您可以直接调用 _delay_ms(1000)。它将使用较低的分辨率。

编辑:在看到您的 Makefile 之后,您的时钟速度可能设置不正确。CLOCK 设置指定了您运行 AVR 的速度,如果它设置为偏离的速度(例如 8MHz 并且您的 PIC 以 1MHz 运行),延迟循环将需要 8 秒,而您预计它需要一个 - 如果那是问题你的 LED 会出现冻结,但如果你等待的时间足够长,它们实际上会改变。尝试删除 -DF_CPU=$(CLOCK) 语句,看看它是否有所作为。

除此之外,您的 Makefile 有很多未使用/不必要的东西,并且由于我目前没有可用的 avr-gcc 设置,因此很难遵循,因此如果您尝试像以下那样简化 Makefile 会有所帮助,看看它是否有效 - 它将关闭,如果您遇到任何问题,请在下方评论!

DEVICE     = attiny2313
CLOCK      = 8000000
OBJECTS    = main.o

# Tune the lines below only if you know what you are doing:

AVRDUDE = avrdude $(PROGRAMMER) -p $(DEVICE)
COMPILE = avr-gcc -Wall -Os -DF_CPU=$(CLOCK) -mmcu=$(DEVICE)

# symbolic targets:
all:    main.hex

flash:  all
    $(AVRDUDE) -U flash:w:main.hex:i

clean:
    rm -f main.hex main.elf $(OBJECTS)

main.elf: $(OBJECTS)
    $(COMPILE) -o main.elf $(OBJECTS)

main.hex: main.elf
    rm -f main.hex
    avr-objcopy -j .text -j .data -O ihex main.elf main.hex
    avr-size --format=avr --mcu=$(DEVICE) main.elf
于 2013-01-27T13:19:19.667 回答
0

Makefile 的第一行指定了错误的芯片。

于 2013-01-27T16:14:27.610 回答