Merge branch 'master' into radio

This commit is contained in:
Rihards Skuja 2017-11-24 23:03:13 +02:00
commit 9f7ae5420d
No known key found for this signature in database
GPG Key ID: 53FA13A3F7F8571B
4 changed files with 51 additions and 3 deletions

View File

@ -42,9 +42,11 @@ CTUNING = -funsigned-char -funsigned-bitfields -fpack-struct -fshort-enums
#CEXTRA = -Wa,-adhlns=$(<:.c=.lst)
CFLAGS = $(CDEBUG) $(CDEFS) $(CINCS) -O$(OPT) $(CWARN) $(CSTANDARD) $(CEXTRA)
#ASFLAGS = -Wa,-adhlns=$(<:.S=.lst),-gstabs
ifeq ($(BUILD),debug)
CFLAGS += -DDEBUG
endif
#Additional libraries.
@ -140,6 +142,8 @@ program: $(BUILD_DIR)/$(TARGET).hex $(BUILD_DIR)/$(TARGET).eep
$(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH) $(AVRDUDE_WRITE_EEPROM)
debug:
make "BUILD=debug"
# Convert ELF to COFF for use in debugging / simulating in AVR Studio or VMLAB.

16
include/debug.h Normal file
View File

@ -0,0 +1,16 @@
#ifndef DEBUG_H
#define DEBUG_H
#include <avr/io.h>
#include "/usr/include/simavr/avr/avr_mcu_section.h"
AVR_MCU(F_CPU, "atmega328p");
const struct avr_mmcu_vcd_trace_t _mytrace[] _MMCU_ = {
{ AVR_MCU_VCD_SYMBOL("DDRB"), .what = (void *) &DDRB, },
{ AVR_MCU_VCD_SYMBOL("TCCR1A"), .what = (void *) &TCCR1A, },
{ AVR_MCU_VCD_SYMBOL("TCCR1B"), .what = (void *) &TCCR1B, },
{ AVR_MCU_VCD_SYMBOL("OCR1A"), .what = (void *) &OCR1A, },
{ AVR_MCU_VCD_SYMBOL("OCR1B"), .what = (void *) &OCR1B, },
};
#endif /* DEBUG_H */

View File

@ -1,8 +1,6 @@
#ifndef MAIN_H
#define MAIN_H
typedef unsigned char byte;
void initIO(void);
void blinkLed(void);
void readTemp(void);

View File

@ -6,8 +6,21 @@
#include "main.h"
#include "io.h"
#ifdef DEBUG
#include "debug.h"
#endif /* DEBUG */
void initIO()
{
/* Servos */
DDRB |= (1 << SERVO_L);
/* Phase Correct PWM, 9-bit; Inverting mode */
TCCR1A |= 1 << WGM11 | 1 << COM1A1 | 1 << COM1A0;
/* "Clear Timer on Compare match" mode; Prescaler = 1 */
TCCR1B |= 1 << WGM13 | 1 << WGM12 | 1 << CS10;
ICR1 = 19999; // F_CPU / 50Hz - 1
/* LED */
DDRD |= (1 << LED_1);
}
@ -27,10 +40,27 @@ void readTemp()
}
}
void runServos()
{
/* Stop */
OCR1A = ICR1 - 1500;
_delay_ms(1500);
/* Reverse */
OCR1A = ICR1 - 2000;
_delay_ms(1500);
/* Forwards */
OCR1A = ICR1 - 1000;
_delay_ms(1500);
}
int main(void)
{
initIO();
runServos();
readTemp();
return 0;
}