Compare commits

..

No commits in common. '7c9500f690a12144d71882b506430c1e8ffeaaab' and '9c6079bdeef0b1d6b1219f9a2d7837aa95b4391d' have entirely different histories.

@ -12,18 +12,17 @@ auf einem Atmel AVR (ATmega328p) ist der Modbus-Slave implementiert.
| Parameter | Wert |
|----------------|--------|
| Baudrate | 115200 |
| Datenbits | 8 |
| Parität | none |
| Stopbits | 1 |
| Modbus Adresse | 1 |
Das Gerät stellt den 24-bit ADC Wert in 2er-Komplement Darstellung über zwei
Das Gerät stellt den 24-bit ADC Wert in 2er-Komplement Darstelling über zwei
Holding-Register bereit. Somit ergibt sich ein 32-bit signed Integer Datentyp.
| Register Adresse | Wert |
|------------------|-----------|
| 0 | ADC[0:15] |
| 1 | 8xADC[23],ADC[22:16]|
| 1 | ADC[23:16]|
#### Beispiel:
Abfragen des Wertes mit dem Tool modpoll (https://www.modbusdriver.com/modpoll.html)

@ -1,6 +1,5 @@
#include <avr/io.h>
#include <avr/interrupt.h>
#include <stdint.h>
#include <util/delay.h>
#include "modbus.h"
@ -8,8 +7,6 @@
uint16_t holdingRegisters[4];
volatile uint32_t led_on_timer[3];
// return raw ADC data
uint32_t HX711_get_data(uint8_t clk_PIN, uint8_t data_PIN, uint8_t gain_for_next_conv){
uint32_t data = 0;
@ -65,20 +62,16 @@ void modbusGet(void) {
{
switch(rxbuffer[1]) {
case fcReadHoldingRegisters:
PORTC |= 1 << 0;
led_on_timer[0]=1000;
PORTC ^= 1 << 1; // toggle led
while(PINB & (1<<4)); // wait for data ready
uint32_t tmp = HX711_get_data(3, 4, 128);
holdingRegisters[0] = tmp & 0xFFFF;
holdingRegisters[1] = (tmp>>16) & 0xFFFF;
holdingRegisters[2] = led_on_timer[1];
modbusExchangeRegisters(holdingRegisters,0,4);
break;
default:
PORTC |= 1 << 1;
led_on_timer[1]=1000;
modbusSendException(ecIllegalFunction);
break;
}
@ -104,11 +97,4 @@ int main(void){
ISR(TIMER0_OVF_vect) { //this ISR is called 9765.625 times per second
modbusTickTimer();
for(uint8_t i=0; i<2; i++){
if(led_on_timer[i]>0)
led_on_timer[i]--;
else
PORTC &= ~(1<<i);
}
}