Factored to support configurable amount of pwm's, fixes
This commit is contained in:
parent
85d29b6473
commit
630bd8e9e4
|
@ -3,7 +3,7 @@ all: er-example-server
|
|||
|
||||
# variable for this Makefile
|
||||
# configure CoAP implementation (3|7|12|13) (er-coap-07 also supports CoAP draft 08)
|
||||
WITH_COAP=13
|
||||
WITH_COAP=7
|
||||
|
||||
# for some platforms
|
||||
UIP_CONF_IPV6=1
|
||||
|
|
|
@ -1,2 +1,2 @@
|
|||
#!/bin/bash
|
||||
avrdude -V -pm128rfa1 -c arduino -P/dev/ttyUSB0 -b57600 -e -U flash:w:er-example-server.osd-merkur.hex:a -U eeprom:w:er-example-server.osd-merkur.eep:a
|
||||
avrdude -pm128rfa1 -c arduino -P/dev/ttyUSB0 -b57600 -e -U flash:w:er-example-server.osd-merkur.hex:a -U eeprom:w:er-example-server.osd-merkur.eep:a
|
||||
|
|
|
@ -35,14 +35,14 @@
|
|||
|
||||
static servo_channel_type servo_channels [] =
|
||||
{ /* PORTx, DDRx, PINxn, PWM */
|
||||
{0x05, 0x04, PINB7, 0} // r
|
||||
, {0x0E, 0x0D, PINE2, 0} // g
|
||||
, {0x05, 0x04, PINB6, 0} // b
|
||||
, {0x05, 0x04, PINB5, 0} // w
|
||||
, {0x05, 0x04, PINB1, 0} // r
|
||||
, {0x05, 0x04, PINB0, 0} // g
|
||||
, {0x05, 0x04, PINB2, 0} // b
|
||||
, {0x05, 0x04, PINB3, 0} // w
|
||||
{0x05, 0x04, 1 << PINB7, 0} // r1
|
||||
, {0x0E, 0x0D, 1 << PINE2, 0} // g1
|
||||
, {0x05, 0x04, 1 << PINB6, 0} // b1
|
||||
, {0x05, 0x04, 1 << PINB5, 0} // w1
|
||||
, {0x05, 0x04, 1 << PINB1, 0} // r2
|
||||
, {0x05, 0x04, 1 << PINB0, 0} // g2
|
||||
, {0x05, 0x04, 1 << PINB2, 0} // b2
|
||||
, {0x05, 0x04, 1 << PINB3, 0} // w2
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
@ -1,78 +0,0 @@
|
|||
//os_fname_map// t4-servo-config:h:h
|
||||
// Copyright (C) 2014 Marcus Priesch, All rights reserved
|
||||
// In Prandnern 31, A--2122 Riedenthal, Austria. office@priesch.co.at
|
||||
// ****************************************************************************
|
||||
// This program is free software; you can redistribute it and/or modify
|
||||
// it under the terms of the GNU General Public License as published by
|
||||
// the Free Software Foundation; either version 2 of the License, or
|
||||
// (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU General Public License
|
||||
// along with this program; if not, write to the Free Software
|
||||
// Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||
// ****************************************************************************
|
||||
//
|
||||
//++
|
||||
// Name
|
||||
// t4-servo-config
|
||||
//
|
||||
// Purpose
|
||||
// configuration for t4-servo
|
||||
//
|
||||
// Revision Dates
|
||||
// 10-Mar-2014 (MPR) Creation
|
||||
// ««revision-date»»···
|
||||
//--
|
||||
|
||||
#include <avr/io.h>
|
||||
|
||||
#ifndef __T4_SERVO_CONFIG_H__
|
||||
#define __T4_SERVO_CONFIG_H__ 1
|
||||
|
||||
// timing: (X:pwm, _:zero)
|
||||
//
|
||||
// X_______________XXXXXXXXXXXXX_______________XXXXXXXXXXXXX
|
||||
//
|
||||
// |<------------->|<--------->|<------------->|<--------->| ...
|
||||
// SERVO_OFFSET SERVO_MAX SERVO_OFFSET SERVO_MAX
|
||||
//
|
||||
// within SERVO_MAX you get the PWM set with servo_set (id, pwm)
|
||||
// if you set SERVO_OFFSET to zero, you get a pwm from 0 to 100% duty cycle
|
||||
//
|
||||
// the period of the smallest tick is derived from the timer4 prescaler
|
||||
// plus the ISR overhead. however, the latter one should be constant
|
||||
// regardless of the pwm signal generated
|
||||
|
||||
#define SERVO_OFFSET 0
|
||||
#define SERVO_MIN 0
|
||||
#define SERVO_MAX 255
|
||||
|
||||
// Counter value for timer 4 without any prescaler for a single tick
|
||||
#define PWMFREQ 500
|
||||
#define T4_VALUE F_CPU/SERVO_MAX/PWMFREQ
|
||||
|
||||
#define SERVO_COUNT 8
|
||||
|
||||
#define T4_SENSOR_NAME "Dual RGBW Led"
|
||||
|
||||
#ifndef servo_channels_defined
|
||||
#define servo_channels_defined
|
||||
static servo_channel_type servo_channels [SERVO_COUNT] =
|
||||
{ {0x0E, 0x0D, PINE2, 0}
|
||||
, {0x0B, 0x0D, PINB7, 0}
|
||||
, {0x0B, 0x0D, PINB6, 0}
|
||||
, {0x0B, 0x0D, PINB5, 0}
|
||||
, {0x0B, 0x0D, PINB0, 0}
|
||||
, {0x0B, 0x0D, PINB1, 0}
|
||||
, {0x0B, 0x0D, PINB2, 0}
|
||||
, {0x0B, 0x0D, PINB3, 0}
|
||||
};
|
||||
#endif
|
||||
#endif
|
||||
|
||||
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
** Copyright (C) 2013 Marcus Priesch, All rights reserved
|
||||
** Copyright (C) 2013-2014 Marcus Priesch, All rights reserved
|
||||
** In Prandnern 31, A--2122 Riedenthal, Austria. office@priesch.co.at
|
||||
**
|
||||
** Redistribution and use in source and binary forms, with or without
|
||||
|
@ -36,6 +36,7 @@
|
|||
**
|
||||
** Revision Dates
|
||||
** 31-Mar-2013 (MPR) Creation
|
||||
** 12-Mar-2014 (MPR) Factored to support configurable amount of pwm's
|
||||
** ««revision-date»»···
|
||||
**--
|
||||
*/
|
||||
|
@ -45,6 +46,7 @@
|
|||
#include "dev/t4-servo-sensor.h"
|
||||
|
||||
const struct sensors_sensor t4_servo_sensor;
|
||||
|
||||
static int status(int type);
|
||||
static int enabled = 0;
|
||||
|
||||
|
@ -71,30 +73,16 @@ static int configure (int type, int c) // type, c: SENSORS_ACTIVE, 1 -> act.
|
|||
else if (c == 1)
|
||||
{
|
||||
t4_servo_init ();
|
||||
t4_servo_set_io (0, T4_SENSOR_1_PORT, T4_SENSOR_1_DDR, T4_SENSOR_1_PIN);
|
||||
t4_servo_set_io (1, T4_SENSOR_2_PORT, T4_SENSOR_2_DDR, T4_SENSOR_2_PIN);
|
||||
t4_servo_set_io (2, T4_SENSOR_3_PORT, T4_SENSOR_3_DDR, T4_SENSOR_3_PIN);
|
||||
t4_servo_set_io (3, T4_SENSOR_4_PORT, T4_SENSOR_4_DDR, T4_SENSOR_4_PIN);
|
||||
}
|
||||
break;
|
||||
|
||||
case 0 :
|
||||
t4_servo_set (0, c);
|
||||
default :
|
||||
if (type >= SERVO_COUNT)
|
||||
return -1;
|
||||
else
|
||||
t4_servo_set (type, c);
|
||||
break;
|
||||
|
||||
case 1 :
|
||||
t4_servo_set (1, c);
|
||||
break;
|
||||
|
||||
case 2 :
|
||||
t4_servo_set (2, c);
|
||||
break;
|
||||
|
||||
case 3 :
|
||||
t4_servo_set (3, c);
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
** Copyright (C) 2013 Marcus Priesch, All rights reserved
|
||||
** Copyright (C) 2013-2014 Marcus Priesch, All rights reserved
|
||||
** In Prandnern 31, A--2122 Riedenthal, Austria. office@priesch.co.at
|
||||
**
|
||||
** Redistribution and use in source and binary forms, with or without
|
||||
|
@ -36,7 +36,8 @@
|
|||
**
|
||||
** Revision Dates
|
||||
** 31-Mar-2013 (MPR) Creation
|
||||
** ««revision-date»»···
|
||||
** 12-Mar-2014 (MPR) Factored to support configurable amount of pwm's
|
||||
««revision-date»»···
|
||||
**--
|
||||
*/
|
||||
|
||||
|
@ -44,28 +45,8 @@
|
|||
#define __T4_SERVO_SENSOR_H__
|
||||
|
||||
#include "lib/sensors.h"
|
||||
#include "t4-servo-config.h"
|
||||
|
||||
extern const struct sensors_sensor t4_servo_sensor;
|
||||
|
||||
#define T4_SENSOR_NAME "T4-Sensor"
|
||||
|
||||
#define T4_SENSOR_1_PORT 0x0E
|
||||
#define T4_SENSOR_1_DDR 0x0D
|
||||
#define T4_SENSOR_1_PIN PINE4
|
||||
|
||||
#define T4_SENSOR_2_PORT 0x0E
|
||||
#define T4_SENSOR_2_DDR 0x0D
|
||||
#define T4_SENSOR_2_PIN PINE3
|
||||
|
||||
#define T4_SENSOR_3_PORT 0x0E
|
||||
#define T4_SENSOR_3_DDR 0x0D
|
||||
#define T4_SENSOR_3_PIN PINE5
|
||||
|
||||
#define T4_SENSOR_4_PORT 0x0E
|
||||
#define T4_SENSOR_4_DDR 0x0D
|
||||
#define T4_SENSOR_4_PIN PINE6
|
||||
|
||||
#endif /* __T4_SERVO_SENSOR_H__ */
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
** Copyright (C) 2013 Marcus Priesch, All rights reserved
|
||||
** Copyright (C) 2013-2014 Marcus Priesch, All rights reserved
|
||||
** In Prandnern 31, A--2122 Riedenthal, Austria. office@priesch.co.at
|
||||
**
|
||||
** Redistribution and use in source and binary forms, with or without
|
||||
|
@ -36,16 +36,18 @@
|
|||
**
|
||||
** Revision Dates
|
||||
** 31-Mar-2013 (MPR) Creation
|
||||
** <EFBFBD><EFBFBD>revision-date<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
** 12-Mar-2014 (MPR) Factored to support configurable amount of pwm's
|
||||
** ««revision-date»»···
|
||||
**--
|
||||
*/
|
||||
|
||||
#include "t4-servo.h"
|
||||
#include "t4-servo-config.h"
|
||||
#include "t4-servo-hardware.h"
|
||||
#include <avr/io.h>
|
||||
#include <avr/interrupt.h>
|
||||
#include "led.h"
|
||||
|
||||
static servo_channel_type servo_channels [SERVO_COUNT];
|
||||
// static servo_channel_type servo_channels [SERVO_COUNT];
|
||||
|
||||
// timer 4: CTC OCR4A
|
||||
#define WGM4 0x4
|
||||
|
@ -56,8 +58,8 @@ void t4_servo_init (void)
|
|||
|
||||
for (channel = 0; channel < SERVO_COUNT; channel ++)
|
||||
{
|
||||
servo_channels [channel].duty = SERVO_MAX/2;
|
||||
t4_servo_set_io (channel, DEFAULT_PORT, DEFAULT_DDR, DEFAULT_PIN);
|
||||
_SFR_IO8 (servo_channels [channel].ddr ) |= servo_channels [channel].pin;
|
||||
_SFR_IO8 (servo_channels [channel].port) &= ~(servo_channels [channel].pin);
|
||||
}
|
||||
|
||||
cli ();
|
||||
|
@ -66,45 +68,30 @@ void t4_servo_init (void)
|
|||
TCCR4B_struct.wgm4 = (WGM4 & 0xc) >> 2;
|
||||
TCCR4B_struct.cs4 = 0x1; // No prescaler
|
||||
TCCR4C = 0x00;
|
||||
OCR4A = T4_VALUE;
|
||||
OCR4A = (T4_VALUE);
|
||||
TIMSK4_struct.ocie4a = 1;
|
||||
TIMSK4_struct.toie4 = 1;
|
||||
sei();
|
||||
}
|
||||
|
||||
void t4_servo_off (void)
|
||||
{
|
||||
TIMSK4_struct.toie4 = 0;
|
||||
TIMSK4_struct.ocie4a = 0;
|
||||
}
|
||||
|
||||
int t4_servo_set_io
|
||||
( unsigned char channel
|
||||
, unsigned char port
|
||||
, unsigned char ddr
|
||||
, unsigned char pin
|
||||
)
|
||||
{
|
||||
if (channel >= SERVO_COUNT)
|
||||
return -1;
|
||||
|
||||
servo_channels [channel].port = port;
|
||||
servo_channels [channel].ddr = ddr;
|
||||
servo_channels [channel].pin = 1 << pin;
|
||||
|
||||
_SFR_IO8 (ddr) |= pin;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
int t4_servo_get (unsigned int channel)
|
||||
{
|
||||
if (channel >= SERVO_COUNT)
|
||||
return -1;
|
||||
|
||||
//printf ("t4_servo_get: %d, %d\n", channel, servo_channels [channel].duty);
|
||||
return servo_channels [channel].duty;
|
||||
}
|
||||
|
||||
int t4_servo_set (unsigned int channel, unsigned int duty)
|
||||
int t4_servo_set (unsigned int channel, unsigned char duty)
|
||||
{
|
||||
//printf ("t4_servo_set: %d, %d\n", channel, duty);
|
||||
|
||||
if (channel >= SERVO_COUNT)
|
||||
return -1;
|
||||
|
||||
|
@ -129,14 +116,14 @@ ISR (TIMER4_COMPA_vect, ISR_NOBLOCK)
|
|||
if (tick_count < servo_channels [channel].duty)
|
||||
{
|
||||
// turn on
|
||||
_SFR_IO8 (servo_channels [channel].ddr ) |= servo_channels [channel].pin;
|
||||
// _SFR_IO8 (servo_channels [channel].ddr ) |= servo_channels [channel].pin;
|
||||
_SFR_IO8 (servo_channels [channel].port) |= servo_channels [channel].pin;
|
||||
}
|
||||
else
|
||||
{
|
||||
// turn off
|
||||
_SFR_IO8 (servo_channels [channel].port) &= ~(servo_channels [channel].pin);
|
||||
_SFR_IO8 (servo_channels [channel].ddr ) |= servo_channels [channel].pin;
|
||||
// _SFR_IO8 (servo_channels [channel].ddr ) |= servo_channels [channel].pin;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -147,4 +134,6 @@ ISR (TIMER4_COMPA_vect, ISR_NOBLOCK)
|
|||
tick_count = 0;
|
||||
}
|
||||
sei();
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
** Copyright (C) 2013 Marcus Priesch, All rights reserved
|
||||
** Copyright (C) 2013-2014 Marcus Priesch, All rights reserved
|
||||
** In Prandnern 31, A--2122 Riedenthal, Austria. office@priesch.co.at
|
||||
**
|
||||
** Redistribution and use in source and binary forms, with or without
|
||||
|
@ -36,47 +36,19 @@
|
|||
**
|
||||
** Revision Dates
|
||||
** 31-Mar-2013 (MPR) Creation
|
||||
** <EFBFBD><EFBFBD>revision-date<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||||
** 12-Mar-2014 (MPR) Factored to support configurable amount of pwm's
|
||||
««revision-date»»···
|
||||
**--
|
||||
*/
|
||||
|
||||
#ifndef __T4_SERVO_H__
|
||||
#define __T4_SERVO_H__
|
||||
|
||||
// timing: (X:pwm, _:zero)
|
||||
//
|
||||
// X_______________XXXXXXXXXXXXX_______________XXXXXXXXXXXXX
|
||||
//
|
||||
// |<------------->|<--------->|<------------->|<--------->| ...
|
||||
// SERVO_OFFSET SERVO_MAX SERVO_OFFSET SERVO_MAX
|
||||
//
|
||||
// within SERVO_MAX you get the PWM set with servo_set (id, pwm)
|
||||
// if you set SERVO_OFFSET to zero, you get a pwm from 0 to 100% duty cycle
|
||||
//
|
||||
// the period of the smallest tick is derived from the timer4 prescaler
|
||||
// plus the ISR overhead. however, the latter one should be constant
|
||||
// regardless of the pwm signal generated
|
||||
|
||||
|
||||
#define SERVO_OFFSET 256
|
||||
#define SERVO_MIN 16
|
||||
#define SERVO_MAX 32
|
||||
|
||||
// Counter value for timer 4 without any prescaler for a single tick
|
||||
#define PWMFREQ 500
|
||||
#define T4_VALUE F_CPU/SERVO_MAX/PWMFREQ
|
||||
|
||||
#define SERVO_COUNT 4
|
||||
|
||||
#define DEFAULT_PORT 0x0E
|
||||
#define DEFAULT_PIN 1
|
||||
#define DEFAULT_DDR 0x0D
|
||||
|
||||
typedef struct struct_servo_channel
|
||||
{
|
||||
unsigned char port;
|
||||
unsigned char pin;
|
||||
unsigned char ddr;
|
||||
unsigned char pin;
|
||||
unsigned char duty;
|
||||
} servo_channel_type;
|
||||
|
||||
|
@ -84,13 +56,6 @@ void t4_servo_init(void);
|
|||
void t4_servo_off(void);
|
||||
|
||||
int t4_servo_get(unsigned int channel);
|
||||
int t4_servo_set(unsigned int channel, unsigned int duty);
|
||||
|
||||
int t4_servo_set_io
|
||||
( unsigned char channel
|
||||
, unsigned char port
|
||||
, unsigned char ddr
|
||||
, unsigned char pin
|
||||
);
|
||||
int t4_servo_set(unsigned int channel, unsigned char duty);
|
||||
|
||||
#endif /* __T4_SERVO_H__ */
|
||||
|
|
Loading…
Reference in a new issue