U23 2008/Gruppe3

From C4 Wiki
Jump to: navigation, search

Gruppe3

Wir saßen an der linken Ecke des projizierten Bildes ;)


Mitglieder:


-mkr
-PyroGX
-whitenexx
-The Kenny (Macbook, Brille)
-Gordin

Code:

Aufgabe Abend 5: Scheduler

Es gab wohl mehrere Untergruppen, wir sollten alle unseren Code hier reinstellen.

Ich bin irgendwie zu blöd dafür, den Code richtig im Wiki einzufügen. - The-Kenny

Hab meinen Code jetzt auch mal reingestellt. Code ist bisschen größer (426 Byte) aber man kann als Optionen außer an und aus auch toggle und nichtstun benutzen und tolle Konstanten :P - Gordin

Code von mkr: <source lang="c">

#include <avr/io.h>
#include <util/delay.h>
 
void set_leds(uint8_t leds)
	{
	//alle leds ausschalten
	PORTC &= ~_BV(PC4);
	PORTD &= ~_BV(PD3);
	PORTD &= ~_BV(PD6);
	PORTD &= ~_BV(PD7);

 	//gewählte leds einschalten
	PORTC |= ((leds & 1) << PC4 );		//bits aus leds an die richtige stelle schieben
	PORTD |= ((leds & 2) << (PD3 - 1) );	//minus eins, weils in leds an der stelle 1 steht (von rechts)
	PORTD |= ((leds & 4) << (PD6 - 2) );	//...
	PORTD |= ((leds & 8) << (PD7 - 3) );
	}


int main(void)
	{ 	
	uint8_t i = 0;			//index der ledconf, die ausgegeben werden soll
	uint8_t delay_time = 200;	//pause zwischen den ausgaben
	uint8_t ledconf[4] = {		//array mit led zuständen
		0b00001000,
		0b00000100,
		0b00000010,
		0b00000001,
		};

	// LED Output-Pins konfigurieren
	DDRC |= _BV(PC4);
	DDRD |= ( _BV(PD3) | _BV(PD6) | _BV(PD7) );

	while(1)
		{
		if (i >= sizeof(ledconf))		//index darf maximal so graß sein, wie die anzahl der ledconf elemente - 1
			i = 0;
		set_leds(ledconf[i]);
		i++;

		_delay_ms(delay_time);
		}
	}

</source>


Code von Gordin: hauptcode: <source lang="c">

#include "rumpus_ledlib.c" //selbstgeschriebene kleine lib zum steuern der leds
#include <util/delay.h>
					
static void display(uint8_t led_config) {
	//übergibt nur die für die jeweilige Funktion wichtigen bits an die led_X funktionen
	led_1(led_config & led1);
	led_2(led_config & led2);
	led_3(led_config & led3);
	led_4(led_config & led4);
	_delay_ms(100);
}

int main(void) {
	// Binäre Schreibweise: 11 = led an 10 = led aus 01 = toggle 00 = nichtstun
	/*uint8_t kr[6] = {    	0b11101010 ,
	 * 			0b10110000,
	 * 			0b00101100,
	 * 			0b00001011,
	 * 			0b00001110,
	 * 			0b00111000 }; */
	 
	/* Andere möglichkeit: 
	 * (Erzeugt die selbe Sequenz wie oben aber das Programm wird ca. 20 Byte größer)
	 * Reihenfolge der leds ist egal */
	uint8_t kr[6] = {	led1    | led2aus | led3aus | led4aus,
				led1aus | led2,
				led2aus | led3,
				led3aus | led4,
				led4aus | led3,
				led3aus | led2, }; 
	led_init(); // leds initialisieren
	uint8_t i;
	while(1) {
		for (i = 0; i < sizeof(kr) ; i++) { // Größe des Arrays muss im  Array stehen array[X]...
		display(kr[i]);	
		}
		
	}
}

</source>

rumpus_ledlib.c: <source lang="c">

#include <avr/io.h>
// Prototypen
void led_1(uint8_t wastun);
void led_2(uint8_t wastun);
void led_3(uint8_t wastun);
void led_4(uint8_t wastun);
void led_init(void);

const uint8_t led1 		= 	0b11000000;
const uint8_t led1aus 		= 	0b10000000;
const uint8_t led1toggle	= 	0b01000000;
const uint8_t led2 		= 	0b00110000;
const uint8_t led2aus		= 	0b00100000;
const uint8_t led2toggle	= 	0b00010000;
const uint8_t led3 		= 	0b00001100;
const uint8_t led3aus		= 	0b00001000;
const uint8_t led3toggle	= 	0b00000100;
const uint8_t led4 		= 	0b00000011;
const uint8_t led4aus		= 	0b00000010;
const uint8_t led4toggle	= 	0b00000001;


/* toggled alle leds  */ /* auskommentieren zum benutzen 0o
void led_toggleall() {
PORTC ^= _BV(PC4);
PORTD ^= _BV(PD3) | _BV(PD6) | _BV(PD7);
}*/


/* ausführen bevor man was mit den leds macht */

void led_init() {
DDRC = _BV(PC4);
DDRD = _BV(PD3) | _BV(PD6) | _BV(PD7);
PORTC &= ~_BV(PC4);
PORTD &= ~_BV(PD3) | ~_BV(PD3) | ~_BV(PD3);
}


/* Steuerung für led 1: Argumente, die übergeben werden können:
 * 0b11000000 (led1) = anschalten
 * 0b10000000 (led1aus) = ausschalten
 * 0b01000000 (led1toggle) = toggle
 * 0b00000000 (0) = nichts */

void led_1(uint8_t wastun) {
if (wastun == led1aus) {
	PORTC &= ~_BV(PC4); // löscht PC4 in PORTC
	}
else if (wastun == led1) {
	PORTC |= _BV(PC4); // setzt PC4 in PORTC
	}
else if (wastun == led1toggle) {
	PORTC ^= _BV(PC4); // tauscht PC4 in PORTC
	}
}


/* Steuerung für led 2: Argumente, die übergeben werden können:
 * 0b00110000 (led2) = anschalten
 * 0b00100000 (led2aus) = ausschalten
 * 0b00010000 (led2toggle) = toggle
 * 0b00000000 (0) = nichts */

void led_2(uint8_t wastun) {
if (wastun == led2aus) {
	PORTD &= ~_BV(PD3); // löscht PD3 in PORTD
	}
else if (wastun == led2) {
	PORTD |= _BV(PD3); // setzt PD3 in PORTD
	}
else if (wastun == led2toggle) {
	PORTD ^= _BV(PD3); // tauscht PD3 in PORTD
	}
}


/* Steuerung für led 3: Argumente, die übergeben werden können:
 * 0b00001100 (led3) = anschalten
 * 0b00001000 (led3aus) = ausschalten
 * 0b00000100 (led3toggle) = toggle
 * 0b00000000 (0) = nichts */

void led_3(uint8_t wastun) {
if (wastun == led3aus) {
	PORTD &= ~_BV(PD6); // löscht PD6 in PORTD
	}
else if (wastun == led3) {
	PORTD |= _BV(PD6); // setzt PD6 in PORTD
	}
else if (wastun == led3toggle) {
	PORTD ^= _BV(PD6); // tauscht PD6 in PORTD
	}
}


/* Steuerung für led 4: Argumente, die übergeben werden können:
 * 0b00000011 (led4) = anschalten
 * 0b00000010 (led4aus) = ausschalten
 * 0b00000001 (led4toggle) = toggle
 * 0b00000000 (0) = nichts */

void led_4(uint8_t wastun) {
if (wastun == led4aus) {
	PORTD &= ~_BV(PD7); // löscht PD7 in PORTD
	}
else if (wastun == led4) {
	PORTD |= _BV(PD7); // setzt PD7 in PORTD
	}
else if (wastun == led4toggle) {
	PORTD ^= _BV(PD7); // tauscht PD7 in PORTD
	}
}

</source>

Aufgabe Abend3:

<source lang="c"> /*

* abend3test.c
*
*  Created on: 25.08.2008
*      Author: Gordin
*/
  1. include <avr/interrupt.h>

void taster_lesen(void);

volatile uint8_t checktaster; uint8_t gerade_gedrueckt;

ISR(TIMER1_COMPA_vect)

   {
   checktaster = 1;
   }

void taster_lesen()

   {
   static uint8_t laststate = 0, oldstate = 0;
   /* Speichert umgekehrten Wert der Taster (1 = gedrückt) */
   uint8_t newstate = (~PINC) & 0b1111;
   /* Überprüft, ob der Aktuelle state der Taster gleich dem letzten ist. */
   uint8_t state = laststate & newstate;
   /* Überprüft ob der neue state der Taster ungleich dem vorletzten
    * und ob der neue State gedrückt ist => Taster wurde gerade gedrückt */
   gerade_gedrueckt = (state ^ oldstate) & state;
   /* Speichert den letzten state der Taster ab zur Überprüfung beim nächsten Aufruf
    * ob sich der neue state zum vorletzten mal geändert hat */
   oldstate = laststate;
   /* Speichert den neuen state der Taster ab zur Überprüfung beim nächsten Aufruf
    * ob der neue state gleich geblieben ist*/
   laststate = newstate;
   }

int main(void)

   {
   /* Leds initialisieren */
   DDRC = _BV(PC4);
   DDRD = _BV(PD3) | _BV(PD6) | _BV(PD7);
   /* Taster initialisieren */
   PORTC = _BV(PC0) | _BV(PC1) | _BV(PC2) | _BV(PC3);
   /* inittimer1, prescaler 1024 */
   TCCR1B = _BV(CS12) | _BV(CS10);
   /* Set CTC mode */
   TCCR1B |= _BV (WGM12);
   /* compare match after 10ms , 20mhz/1024/100 = ~195 */
   OCR1A = 195;
   /* enable interrupt */
   TIMSK1 = _BV(OCIE1A);
   sei ();
   while (1)

{ if (checktaster) { taster_lesen();

           /* Setzt die Bits für die leds (kleiner als einzelne if-abfragen) */

PORTC ^= (gerade_gedrueckt & 0b1) << 4; PORTD ^= ((gerade_gedrueckt & 0b10) << 2) + ((gerade_gedrueckt & 0b1100) << 4); checktaster = 0; } }

   }

</source>