HB-UNI-Sen-CAP-MOIST

Entwicklung und Bau von Hardware aller Art, die im HM-Umfeld eingesetzt werden kann

Moderator: Co-Administratoren

jp112sdl
Beiträge: 12108
Registriert: 20.11.2016, 20:01
Hat sich bedankt: 848 Mal
Danksagung erhalten: 2148 Mal
Kontaktdaten:

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von jp112sdl » 14.04.2019, 17:09

Wenn das so hält ... schick!

VG,
Jérôme ☕️

---
Support for my Homebrew-Devices: Download JP-HB-Devices Addon

emil70
Beiträge: 288
Registriert: 02.12.2017, 13:47
System: CCU
Hat sich bedankt: 33 Mal
Danksagung erhalten: 8 Mal

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von emil70 » 14.04.2019, 19:13

Will ich hoffen. Ist schon sehr stabil

Wie ist das denn so mit den Senderintervallzuverlässigkeit bei den Selbstbauten?

Bei den HB-UNI-Sensor1 habe ich 10 min eingestellt. Das kommt jetzt auch so ungefähr hin

Bei HB-UNI-Sen-CAP-MOIST-master habe ich 5 min eingestellt. Letzte Änderung war um 18:29 Uhr
gruß emil70

jp112sdl
Beiträge: 12108
Registriert: 20.11.2016, 20:01
Hat sich bedankt: 848 Mal
Danksagung erhalten: 2148 Mal
Kontaktdaten:

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von jp112sdl » 14.04.2019, 19:15

emil70 hat geschrieben:
14.04.2019, 19:13
Letzte Änderung war um 18:29 Uhr
Wenn sich am Wert nichts ändert, ändert sich auch der Zeitstempel nicht.

Steht im WebUI Handbuch. :roll: :lol: :lol: :lol:

VG,
Jérôme ☕️

---
Support for my Homebrew-Devices: Download JP-HB-Devices Addon

Denis
Beiträge: 4
Registriert: 09.04.2019, 19:27

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von Denis » 23.04.2019, 22:50

Hallo zusammen,

auch ich versuche mich diesen Sensor nachzubauen.
Allerdings scheitere ich schon am compilieren.

Ich vermute das mir eine Bibliothek fehlt. Aber ich komme leider nicht drauf.

Code: Alles auswählen


platformio run
Processing pro8MHzatmega328 (platform: atmelavr; board: pro8MHzatmega328; framework: arduino)
 
Verbose mode can be enabled via `-v, --verbose` option
CONFIGURATION: https://docs.platformio.org/page/boards/atmelavr/pro8MHzatmega328.html
PLATFORM: Atmel AVR > Arduino Pro or Pro Mini ATmega328 (3.3V, 8 MHz)
HARDWARE: ATMEGA328P 8MHz 2KB RAM (30KB Flash)
Converting main.ino

Library Dependency Finder -> http://bit.ly/configure-pio-ldf
LDF MODES: FINDER(chain) COMPATIBILITY(soft)
Collected 11 compatible libraries
Scanning dependencies...
Dependency Graph
|-- <EnableInterrupt> 1.0.0
|-- <AskSinPP> 3.1.8
|   |-- <Low-Power> 1.6
|-- <Low-Power> 1.6
Compiling .pioenvs\pro8MHzatmega328\src\main.ino.cpp.o
Compiling .pioenvs\pro8MHzatmega328\FrameworkArduino\Print.cpp.o
Compiling .pioenvs\pro8MHzatmega328\FrameworkArduino\Stream.cpp.o
Compiling .pioenvs\pro8MHzatmega328\FrameworkArduino\Tone.cpp.o
In file included from C:/Users/demuelle/Documents/PlatformIO/Projects/HB-UNI-Sen-CAP-MOIST/src/main.ino:27:0:
.piolibdeps\EnableInterrupt_ID311/EnableInterrupt.h:22:125: note: #pragma message: NOTICE: *** EnableInterrupt library version pre-0.9.6. This is not a problem. Keep calm, and carry on. ***
#pragma message("NOTICE: *** EnableInterrupt library version pre-0.9.6. This is not a problem. Keep calm, and carry on. ***")
^
C:/Users/demuelle/Documents/PlatformIO/Projects/HB-UNI-Sen-CAP-MOIST/src/main.ino:99:5: error: expected unqualified-id before 'public'
uint16_t Sendeintervall () const {
^
C:/Users/demuelle/Documents/PlatformIO/Projects/HB-UNI-Sen-CAP-MOIST/src/main.ino:103:3: error: expected declaration before '}' token
void defaults () {
^
*** [.pioenvs\pro8MHzatmega328\src\main.ino.cpp.o] Error 1
 [ERROR] Took 3.53 seconds
Könnt Ihr damit wa anfangen?
Ich verwende Platformio.

Benutzeravatar
Psi
Beiträge: 512
Registriert: 09.08.2018, 19:58
Wohnort: Nürnberg
Hat sich bedankt: 27 Mal
Danksagung erhalten: 90 Mal

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von Psi » 24.04.2019, 10:10

Hi,
die Fehler scheinen ja in deiner src/main.ino:99 und 103 zu sein. Poste doch mal den Sketch.

Die platformio.ini müsste ca so aussehen:

Code: Alles auswählen

[env:pro8MHzatmega328]
platform = atmelavr
framework = arduino
board = pro8MHzatmega328

Denis
Beiträge: 4
Registriert: 09.04.2019, 19:27

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von Denis » 24.04.2019, 22:22

Hallo,
hier der Sketch, (Quelle:https://asksinpp.de/Sketche/
https://github.com/jp112sdl/HB-UNI-Sen- ... -MOIST.ino)

Code: Alles auswählen

//- -----------------------------------------------------------------------------------------------------------------------
// AskSin++
// 2016-10-31 papa Creative Commons - http://creativecommons.org/licenses/by-nc-sa/3.0/de/
// 2018-04-16 jp112sdl Creative Commons - http://creativecommons.org/licenses/by-nc-sa/3.0/de/
//- -----------------------------------------------------------------------------------------------------------------------

//Sensor:
//https://www.dfrobot.com/wiki/index.php/Capacitive_Soil_Moisture_Sensor_SKU:SEN0193

// define this to read the device id, serial and device type from bootloader section
// #define USE_OTA_BOOTLOADER

#define EI_NOTEXTERNAL
#include <EnableInterrupt.h>
#include <AskSinPP.h>
#include <LowPower.h>

#include <Register.h>
#include <MultiChannelDevice.h>

// Arduino Pro mini 8 Mhz
// Arduino pin for the config button
#define CONFIG_BUTTON_PIN 8
#define ISR_PIN           9

// number of available peers per channel
#define PEERS_PER_CHANNEL 6

// all library classes are placed in the namespace 'as'
using namespace as;

//Korrekturfaktor der Clock-Ungenauigkeit, wenn keine RTC verwendet wird
#define SYSCLOCK_FACTOR    0.88

#define LED_PIN            4
#define BATT_EN_PIN        6
#define BATT_SENS_PIN      A3

volatile bool isrDetected = false;

//SENSOR_EN_PIN und SENSOR_PIN sind immer paarweise und kommagetrennt hinzuzufügen:
//Beispiel für 3 Sensoren
//byte SENSOR_EN_PINS[]      {5 , 6, 7}; //VCC Pin des Sensors
//byte SENSOR_PINS[]         {14, 15, 16}; //AOut Pin des Sensors

byte SENSOR_EN_PINS[]      {5 }; //VCC Pin des Sensors
byte SENSOR_PINS[]         {14}; //AOut Pin des Sensors

#define sendISR(pin) class sendISRHandler { \
    public: \
      static void isr () { isrDetected = true; } \
  }; \
  pinMode(pin, INPUT_PULLUP); \
  if( digitalPinToInterrupt(pin) == NOT_AN_INTERRUPT ) \
    enableInterrupt(pin,sendISRHandler::isr,RISING); \
  else \
    attachInterrupt(digitalPinToInterrupt(pin),sendISRHandler::isr,RISING);

// define all device properties
const struct DeviceInfo PROGMEM devinfo = {
  {0xF3, 0x11, 0x03},          // Device ID
  "JPCAPM0003",                // Device Serial
  {0xF3, 0x11},                // Device Model
  0x11,                        // Firmware Version
  as::DeviceType::THSensor,    // Device Type
  {0x01, 0x01}                 // Info Bytes
};

/**
   Configure the used hardware
*/
typedef AvrSPI<10, 11, 12, 13> SPIType;
typedef Radio<SPIType, 2> RadioType;
typedef StatusLed<LED_PIN> LedType;
typedef AskSin<LedType, BatterySensorUni<BATT_SENS_PIN, BATT_EN_PIN, 0>, RadioType> BaseHal;
class Hal : public BaseHal {
  public:
    void init (const HMID& id) {
      BaseHal::init(id);
      battery.init(seconds2ticks(60UL * 60) * SYSCLOCK_FACTOR, sysclock); //battery measure once an hour
      battery.low(22);
      battery.critical(19);
    }

    bool runready () {
      return sysclock.runready() || BaseHal::runready();
    }
} hal;


DEFREGISTER(UReg0, MASTERID_REGS, DREG_BURSTRX, DREG_LOWBATLIMIT, 0x21, 0x22)
class UList0 : public RegList0<UReg0> {
  public:
    UList0 (uint16_t addr) : RegList0<UReg0>(addr) {}

    bool Sendeintervall (uint16_t value) const {
      return this->writeRegister(0x21, (value >> 8) & 0xff) && this->writeRegister(0x22, value & 0xff);
    }
    uint16_t Sendeintervall () const {
      return (this->readRegister(0x21, 0) << 8) + this->readRegister(0x22, 0);
    }

    void defaults () {
      clear();
      burstRx(false);
      lowBatLimit(22);
      Sendeintervall(30);
    }
};

DEFREGISTER(UReg1, 0x23, 0x24, 0x25, 0x26)
class UList1 : public RegList1<UReg1> {
  public:
    UList1 (uint16_t addr) : RegList1<UReg1>(addr) {}
    bool HIGHValue (uint16_t value) const {
      return this->writeRegister(0x23, (value >> 8) & 0xff) && this->writeRegister(0x24, value & 0xff);
    }
    uint16_t HIGHValue () const {
      return (this->readRegister(0x23, 0) << 8) + this->readRegister(0x24, 0);
    }

    bool LOWValue (uint16_t value) const {
      return this->writeRegister(0x25, (value >> 8) & 0xff) && this->writeRegister(0x26, value & 0xff);
    }
    uint16_t LOWValue () const {
      return (this->readRegister(0x25, 0) << 8) + this->readRegister(0x26, 0);
    }

    void defaults () {
      clear();
      HIGHValue(830);
      LOWValue(420);
    }
};

class WeatherEventMsg : public Message {
  public:
    void init(uint8_t msgcnt, uint8_t channel, uint8_t val, bool batlow, uint8_t volt) {

      Message::init(0x0e, msgcnt, 0x70, BCAST , batlow ? 0x80 : 0x00, 0x00);
      pload[0] = val     & 0xff;
      pload[1] = channel & 0xff;
      pload[2] = volt    & 0xff;
    }
};

class WeatherChannel : public Channel<Hal, UList1, EmptyList, List4, PEERS_PER_CHANNEL, UList0>, public Alarm {
    WeatherEventMsg msg;
    uint16_t        millis;
    uint8_t         humidity;

  public:
    WeatherChannel () : Channel(), Alarm(0), millis(0) {}
    virtual ~WeatherChannel () {}

    void measure() {
      digitalWrite(SENSOR_EN_PINS[(number() - 1)], HIGH);
      _delay_ms(500);
      uint16_t sens_val = 0;
      for (uint8_t i = 0; i < 10; i++) {
        sens_val += analogRead(SENSOR_PINS[(number() - 1)]);
        _delay_ms(10);
      }
      sens_val = sens_val / 10;
      digitalWrite(SENSOR_EN_PINS[(number() - 1)], LOW);
      DPRINT(F("+Sensor    (#")); DDEC(number()); DPRINT(F(") V: ")); DDECLN(sens_val);
      uint16_t range = this->getList1().HIGHValue() - this->getList1().LOWValue();
      uint32_t base = sens_val - this->getList1().LOWValue();
      uint8_t pct_inv = (100 * base) / range;
      humidity = (pct_inv > 100) ? 0 : 100 - pct_inv;
      DPRINT(F("+Humidity  (#")); DDEC(number()); DPRINT(F(") %: ")); DDECLN(humidity);
    }

    void irq () {
      sysclock.cancel(*this);
      processMessage();
    }

    virtual void trigger (__attribute__ ((unused)) AlarmClock& clock) {
      processMessage();
    }

    void processMessage() {
      measure();
      tick = delay();
      DPRINT(F("+Battery   (#")); DDEC(number()); DPRINT(F(") V: ")); DDECLN(device().battery().current());
      msg.init(device().nextcount(), number(), humidity, device().battery().low(), device().battery().current());
      device().sendPeerEvent(msg, *this);
      sysclock.add(*this);
    }

    uint32_t delay () {
      uint16_t _txMindelay = 30;
      _txMindelay = device().getList0().Sendeintervall();
      if (_txMindelay == 0) _txMindelay = 30;
      return seconds2ticks(_txMindelay * 60 * SYSCLOCK_FACTOR);
    }

    void configChanged() {
      DPRINTLN(F("Config changed List1"));
      DPRINT(F("*HIGHValue (#")); DDEC(number()); DPRINT(F("): ")); DDECLN(this->getList1().HIGHValue());
      DPRINT(F("*LOWValue  (#")); DDEC(number()); DPRINT(F("): ")); DDECLN(this->getList1().LOWValue());
    }

    void setup(Device<Hal, UList0>* dev, uint8_t number, uint16_t addr) {
      Channel::setup(dev, number, addr);
      pinMode(SENSOR_PINS[ number - 1 ], INPUT);
      pinMode(SENSOR_EN_PINS[ number - 1 ], OUTPUT);
      sysclock.add(*this);
    }

    uint8_t status () const {
      return 0;
    }

    uint8_t flags () const {
      return 0;
    }
};

class UType : public MultiChannelDevice<Hal, WeatherChannel, sizeof(SENSOR_PINS), UList0> {
  public:
    typedef MultiChannelDevice<Hal, WeatherChannel, sizeof(SENSOR_PINS), UList0> TSDevice;
    UType(const DeviceInfo& info, uint16_t addr) : TSDevice(info, addr) {}
    virtual ~UType () {}

    virtual void configChanged () {
      TSDevice::configChanged();
      DPRINT(F("*LOW BAT Limit: "));
      DDECLN(this->getList0().lowBatLimit());
      DPRINT(F("*Wake-On-Radio: "));
      DDECLN(this->getList0().burstRx());
      this->battery().low(this->getList0().lowBatLimit());
      DPRINT(F("*Sendeintervall: ")); DDECLN(this->getList0().Sendeintervall());
    }
};

UType sdev(devinfo, 0x20);
ConfigButton<UType> cfgBtn(sdev);

void setup () {
  DINIT(57600, ASKSIN_PLUS_PLUS_IDENTIFIER);
  if (sizeof(SENSOR_PINS) != sizeof(SENSOR_EN_PINS)) {
    DPRINTLN(F("!!! ERROR: Anzahl SENSOR_PINS entspricht nicht der Anzahl SENSOR_EN_PINS"));
  } else {
    sdev.init(hal);
    DDEVINFO(sdev);
    buttonISR(cfgBtn, CONFIG_BUTTON_PIN);
#ifdef ISR_PIN
    sendISR(ISR_PIN);
#endif
    sdev.initDone();
  }
}

void loop() {
  bool worked = hal.runready();
  bool poll = sdev.pollRadio();

  if ( worked == false && poll == false ) {
    if (isrDetected) {
      DPRINTLN(F("manual button pressed"));
      for (uint8_t i = 1; i <= sizeof(SENSOR_PINS); i++) {
        sdev.channel(i).irq();
      }
      isrDetected = false;
    }

    if ( hal.battery.critical() ) {
      hal.activity.sleepForever(hal);
    }
    hal.activity.savePower<Sleep<>>(hal);
  }
}
Die Zeilen 99-108 sind folgende

Code: Alles auswählen

uint16_t Sendeintervall () const {
      return (this->readRegister(0x21, 0) << 8) + this->readRegister(0x22, 0);
    }

    void defaults () {
      clear();
      burstRx(false);
      lowBatLimit(22);
      Sendeintervall(30);
    }


Meine Platformio.ini sieht auch so aus.

Code: Alles auswählen

[env:pro8MHzatmega328]
platform = atmelavr
board = pro8MHzatmega328
framework = arduino

TomMajor
Beiträge: 1793
Registriert: 30.08.2017, 23:25
Hat sich bedankt: 175 Mal
Danksagung erhalten: 399 Mal
Kontaktdaten:

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von TomMajor » 24.04.2019, 23:23

Füge mal am Anfang des Sketches ein

Code: Alles auswählen

#include <Arduino.h>
ein (für die uint**_t Typen).
Viele Grüße,
Tom

Denis
Beiträge: 4
Registriert: 09.04.2019, 19:27

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von Denis » 25.04.2019, 13:37

Hallo Tom,

leider unverändert.

Grüße Denis

TomMajor
Beiträge: 1793
Registriert: 30.08.2017, 23:25
Hat sich bedankt: 175 Mal
Danksagung erhalten: 399 Mal
Kontaktdaten:

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von TomMajor » 25.04.2019, 14:46

mit dem gleichen Fehler?
Falls ja, dann inkludiere mal

Code: Alles auswählen

stdint.h
Viele Grüße,
Tom

jp112sdl
Beiträge: 12108
Registriert: 20.11.2016, 20:01
Hat sich bedankt: 848 Mal
Danksagung erhalten: 2148 Mal
Kontaktdaten:

Re: HB-UNI-Sen-CAP-MOIST

Beitrag von jp112sdl » 25.04.2019, 15:03

Also ich hab mir grad mal die Platform.IO Extension in VSCode installiert.
Alles komplettes Neuland... hab mich da irgendwie durchgeklickt... Board und Libs installiert und ich konnte anschließend sofort kompilieren, ohne irgendwas extra zu includen:

Code: Alles auswählen

Processing pro8MHzatmega328 (platform: atmelavr; board: pro8MHzatmega328; framework: arduino)
----------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Verbose mode can be enabled via `-v, --verbose` option
CONFIGURATION: https://docs.platformio.org/page/boards/atmelavr/pro8MHzatmega328.html
PLATFORM: Atmel AVR > Arduino Pro or Pro Mini ATmega328 (3.3V, 8 MHz)
HARDWARE: ATMEGA328P 8MHz 2KB RAM (30KB Flash)
Converting HB-UNI-Sen-CAP-MOIST.ino
Library Dependency Finder -> http://bit.ly/configure-pio-ldf
LDF MODES: FINDER(chain) COMPATIBILITY(soft)
Collected 8 compatible libraries
Scanning dependencies...
Dependency Graph
|-- <Low-Power> 1.6
|-- <AskSinPP> 3.1.8
|   |-- <Low-Power> 1.6
|-- <EnableInterrupt> 1.0.0
Compiling .pioenvs/pro8MHzatmega328/src/HB-UNI-Sen-CAP-MOIST.ino.cpp.o
Compiling .pioenvs/pro8MHzatmega328/liba53/Low-Power_ID38/LowPower.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/AlarmClock.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/Globals.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/HMID.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/Led.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/PhaseCut.cpp.o
In file included from ~/Documents/PlatformIO/Projects/190425-145703-pro8MHzatmega328/src/HB-UNI-Sen-CAP-MOIST.ino:14:0:
~/.platformio/lib/EnableInterrupt_ID311/EnableInterrupt.h:22:125: note: #pragma message: NOTICE: *** EnableInterrupt library version pre-0.9.6. This is not a problem. Keep calm, and carry on. ***
#pragma message("NOTICE: *** EnableInterrupt library version pre-0.9.6. This is not a problem. Keep calm, and carry on. ***")
^
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes128_dec.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes128_enc.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes_dec.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes_enc.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes_invsbox.c.o
Archiving .pioenvs/pro8MHzatmega328/liba53/libLow-Power_ID38.a
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes_keyschedule.cpp.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/aes_sbox.c.o
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/gf256mul.S.o
Indexing .pioenvs/pro8MHzatmega328/liba53/libLow-Power_ID38.a
Compiling .pioenvs/pro8MHzatmega328/lib0a8/AskSinPP_ID2900/gf256mul.cpp.o
Archiving .pioenvs/pro8MHzatmega328/libe27/libEnableInterrupt_ID311.a
Archiving .pioenvs/pro8MHzatmega328/libFrameworkArduinoVariant.a
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/CDC.cpp.o
Indexing .pioenvs/pro8MHzatmega328/libe27/libEnableInterrupt_ID311.a
Indexing .pioenvs/pro8MHzatmega328/libFrameworkArduinoVariant.a
Archiving .pioenvs/pro8MHzatmega328/lib0a8/libAskSinPP_ID2900.a
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/HardwareSerial.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/HardwareSerial0.cpp.o
Indexing .pioenvs/pro8MHzatmega328/lib0a8/libAskSinPP_ID2900.a
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/HardwareSerial1.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/HardwareSerial2.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/HardwareSerial3.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/IPAddress.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/PluggableUSB.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/Print.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/Stream.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/Tone.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/USBCore.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/WInterrupts.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/WMath.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/WString.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/abi.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/hooks.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/main.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/new.cpp.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring_analog.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring_digital.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring_pulse.S.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring_pulse.c.o
Compiling .pioenvs/pro8MHzatmega328/FrameworkArduino/wiring_shift.c.o
Archiving .pioenvs/pro8MHzatmega328/libFrameworkArduino.a
Indexing .pioenvs/pro8MHzatmega328/libFrameworkArduino.a
Linking .pioenvs/pro8MHzatmega328/firmware.elf
Building .pioenvs/pro8MHzatmega328/firmware.hex
Checking size .pioenvs/pro8MHzatmega328/firmware.elf
Memory Usage -> http://bit.ly/pio-memory-usage
DATA:    [====      ]  38.7% (used 793 bytes from 2048 bytes)
PROGRAM: [=======   ]  65.1% (used 20002 bytes from 30720 bytes)
======================================================================= [SUCCESS] Took 2.56 seconds =======================================================================

Terminal will be reused by tasks, press any key to close it.

VG,
Jérôme ☕️

---
Support for my Homebrew-Devices: Download JP-HB-Devices Addon

Antworten

Zurück zu „Hardwareentwicklung und Selbstbau von Aktoren und Sensoren“