Dies ist eine alte Version des Dokuments!
Inhaltsverzeichnis
Anpassung des Contiki SNMP zur Verwendung auf den Modulen von Adaptive Network Solutions
Contiki SNMP (siehe SNMP auf Contiki 2.5 und Contiki 2.6) wurde so angepasst dass nun folgende Features auf den Modulen zur Verfügung stehen:
- Betriebszustandsanzeige über LED DS3
- Paketempfangssignalisierung über LED DS2
- Port Pin Steuerung über SNMPv3 über LED DS1
- Messung der Versorgungsspannung über ADC0 bei Anschluss eines 1:1 Spannungsteilers über die Versorgungsspannung
→ Pinbelegung und Schaltplan der Module siehe: brick_mcu_pinassignments_ref2.pdf
Betriebszustandsanzeige über LED DS3
Zur Signalisierung der Betriebszustandsanzeige wurde innerhalb des Contiki SNMP Prozesses (snmpd.c) zuerst alle LEDs als Ausgänge geschaltet, anschließend LED DS3 (PIN7) auf LOW geschaltet und somit aktiviert.
/*Switch LED on @ANY Brick On if SNMPD started and set other LEDs as Output*/ DDRB |= (1 << PIN5); DDRB |= (1 << PIN6); DDRB |= (1 << PIN7); PORTB &= ~(1 << PIN7); PORTB |= (1 << PIN6); PORTB |= (1 << PIN5); /*END LED @ANY Brick*/
Paketempfangssignalisierung über LED DS2
Um das Eintreffen eines Pakets über uIPv6 visualisieren zu können, wurde die LED DS2 innerhalb der Funktion tcpip_input(void)
innerhalb der Datei tcpip.c im Verzeichnis /core/net/
angepasst.
/*---------------------------------------------------------------------------*/ void tcpip_input(void) { /*sz*/ /*Blinking LED on packet receiving*/ PORTB &= ~(1 << PIN6); /*sz*/ process_post_synch(&tcpip_process, PACKET_INPUT, NULL); uip_len = 0; #if UIP_CONF_IPV6 uip_ext_len = 0; #endif /*UIP_CONF_IPV6*/ /*sz*/ /*Blinking LED on packet receiving*/ PORTB |= (1 << PIN6); /*sz*/ } /*---------------------------------------------------------------------------*/
Pin Steuerung über SNMPv3 über LED DS1
Zur Steuerung von LED DS2 wurden die GET und SET Funktionen innerhalb der Datei mib-init-beuth-zig.c
des SNMP Daemons angepasst.
/* LED DS1 for @ANY module start */ /** \brief LED DS1 for @ANY module get function*/ s8t getBeuthState(mib_object_t* object, u8t* oid, u8t len) { object->varbind.value.i_value = !((PORTB >> PIN5) & 1); return 0; } /** \brief set LED DS1 for @ANY module*/ s8t setBeuthState(mib_object_t* object, u8t* oid, u8t len, varbind_value_t value) { if (value.i_value == 1) { PORTB &= ~(1 << PIN5); } else { PORTB |= (1 << PIN5); } return 0; } /* LED DS1 for @ANY module end */
Messung der Versorgungsspannung über ADC0 bei Anschluss eines 1:1 Spannungsteilers über die Versorgungsspannung
Zur Messung der Versorgungsspannung wurde der PIN des ADC0 mit einem Spannungsteiler beschaltet.
Als Referenzspannung wurden die stabilen intern verfügbaren 2,54V des Mikrocontrollers verwendet. Zur Initialisierung des ADCs sowie zur Abfrage des aktuellen Wertes sind die folgenden Funktionen innerhalb der Datei mib-init-beuth-zig.c
notwendig.
/* battery power level*/ /************************/ /** \brief function for initialization of the adc*/ void adc_init() { // AREF = AVcc ADMUX = (1<<REFS0)|(1<<REFS1); //intern 2.54V voltage reference // ADC Enable and prescaler of 128 // 16000000/128 = 125000 ADCSRA = (1<<ADEN)|(1<<ADPS2)|(1<<ADPS1)|(1<<ADPS0); } /** \brief adc read function */ u16t adc_read() { ADMUX = (ADMUX & 0xF8)|0; // clears the bottom 3 bits before ORing // start single convertion // write '1' to ADSC ADCSRA |= (1<<ADSC); // wait for conversion to complete // ADSC becomes '0' again // till then, run loop continuously while(ADCSRA & (1<<ADSC)); return (ADC); } /** \brief get function for the battery power level mib object*/ s8t getBattValue(mib_object_t* object, u8t* oid, u8t len) { adc_init(); u16t adc_value; int batt_level; adc_value=adc_read(); batt_level=(((25400)/1024)*adc_value*2); //Reference Voltage 2.54Volts, 10Bit ADC, //multiplied with ADC Read, multiplied with two because of the 1:1 voltage divider object->varbind.value.i_value = batt_level; return 0; } /*Battery Level end*/