#1 Re: Програмування Arduino » SoftwareSerial (Nano + Mega2560) » 2020-04-01 13:25:10

Я теж був би радий, але в моніторах плат нічого не видно, окрім "...not initiated!", тобто пересилка не відбувається sad Спробував іншу Мега2560, бо допускав момент. що піни "підпалені" - теж нічого не змінилося.

#2 Re: Програмування Arduino » SoftwareSerial (Nano + Mega2560) » 2020-04-01 09:34:04

Ось перероблений варіант під AltSoftSerial
Master

#include <SPI.h>
#include <Wire.h>
#include <AltSoftSerial.h>
#include "RTClib.h"
#include <string.h>
#include "Time.h"
#include "TimeAlarms.h"

AltSoftSerial altSerial;

char chrValue = ' ';
RTC_DS1307 RTC;
unsigned long time = 0;

uint32_t syncProvider() {
  return RTC.now().unixtime();
}

void setup() {
  Serial.begin(9600);
  SPI.begin();
  Wire.begin();
  altSerial.begin(9600);
  RTC.begin();
  if (! RTC.isrunning()) {
    Serial.println(F("RTC is NOT running!"));
    return;
  }
  if (!altSerial.available()) {
    Serial.print("Alt connection error!");
  }
    RTC.adjust(DateTime(F(__DATE__), F(__TIME__)));
    setSyncProvider(syncProvider);
  }

  void loop() {
    DateTime now = RTC.now();
    checker();
    reads();
  }

  void checker() {
    if (altSerial.available()) {
      Serial.println("Master to Slave initiated!");
      while (altSerial.available()) {
        Serial.println("Starting transmit:");
        char chrValue = 65;
        altSerial.print(chrValue);
        Serial.println("Data was sent:" + chrValue);
        delay(100);
        altSerial.flush();
      }
    }
    delay(100);
  }
  void reads() {
    if (altSerial.available()) {
      while (altSerial.available() > 0) {
        chrValue = altSerial.read();
        Serial.println(chrValue);
        if (chrValue == 66) {
          Serial.println("Slave to Master OK!");
        }
        else if (!chrValue == 66) {
          Serial.println("Slave to Master ERROR!");
          delay(100);
          altSerial.flush();
        }
      }
    }
  }

Slave

#include <SPI.h>
#include <Wire.h>
#include <AltSoftSerial.h>

AltSoftSerial altSerial;

char chrValue = ' ';

void setup() {
  Serial.begin(9600);
  SPI.begin();
  Wire.begin();
  altSerial.begin(9600);
  if (!altSerial.available()) {
    Serial.println("Slave to Master not initiated!");
  }
}

void loop() {
  master();
}

void master() {
  while (altSerial.available() == 0) {
  }
  if (altSerial.available() > 0) {
    while (altSerial.available() > 0) {
      chrValue = altSerial.read();
      if (chrValue == 65) {
        Serial.println("Data received:" + chrValue);
        delay(100);
      }
      else if (!chrValue == 65) {
        Serial.println("Wrong data!");
        delay(100);
      }
      delay(100);
      char chrValue = 66;
      altSerial.print(chrValue);
      Serial.println("Data was sent:" + chrValue);
      delay(100);
      altSerial.flush();
    }
  }
}

Тепер стабільно, з обох сторін "...not initiated!". Розпіновка вірна, GND спільний

#3 Re: Програмування Arduino » SoftwareSerial (Nano + Mega2560) » 2020-04-01 08:15:46

то я помилився при вставці коду. на 9600 результат аналогічний

#4 Re: Програмування Arduino » SoftwareSerial (Nano + Mega2560) » 2020-04-01 04:26:14

Спробував "викинути" відправку по "крону" і просто запхати все в loop, і як результат - нічого не видно на "моніторах" для обох плат...

#5 Програмування Arduino » SoftwareSerial (Nano + Mega2560) » 2020-04-01 03:40:30

Alex.I
відповідей: 7

Всім вітання. Якщо хтось мав справу з комінкацією 2-х Arduino з використанням SoftwareSerial ліби, то прошу підказки. Перечитав багато прикладів та багато чого спробував, але є "проблема". Задумка така:

- Master по "крону" відправляє на Slave Char, потім виконується Flush
- Slave постійно перевіряє чи передається щось по SoftwareSerial
- Якщо Slave прийняв потрібний Char, то зі сторони Slave виконується Flush + відправляється інший Char на Master
- Master постійно перевіряє чи передається щось по SoftwareSerial
і т.д.

Про проблему SoftwareSerial (неможливість одночасно зчитувати та відправляти) знаю. Також пробував AltSoftserial, але трошки "не зайшло", тому вирішив "добити" спочатку з SoftwareSerial, а вже потім пробувати щось краще

Код Master (Nano v3):

#include <Wire.h>
#include <SoftwareSerial.h>
#include "RTClib.h"
#include <string.h>
#include "Time.h"
#include "TimeAlarms.h"

SoftwareSerial ArduinoSlave(8, 9);
char chrValue = ' ';
RTC_DS1307 RTC;
unsigned long time = 0;

uint32_t syncProvider() {
  return RTC.now().unixtime();
}

void setup() {
  Serial.begin(9600);
  SPI.begin();
  Wire.begin();
  ArduinoSlave.begin(9600);
  RTC.begin();
  if (! RTC.isrunning()) {
    Serial.println(F("RTC is NOT running!"));
    return;
  }
  if (!ArduinoSlave.available()) {
    Serial.println("Master to Slave not initiated!");
    return;
  }
  RTC.adjust(DateTime(F(__DATE__), F(__TIME__)));
  setSyncProvider(syncProvider);
  //  Alarm.alarmRepeat(0, 0, 10, checker);
  Alarm.timerRepeat(10, checker);	//повтор пересилки кожні 10 сек
}

void loop() {
  DateTime now = RTC.now();
  Alarm.delay(1000);
  reads();
}

void checker() {
  if (ArduinoSlave.available()) {
    Serial.println("Master to Slave initiated!");
    while (ArduinoSlave.available() > 0) {
      Serial.println("Starting transmit:");
      char chrValue = 65;
      ArduinoSlave.print(chrValue);
      Serial.println("Data was sent:" + chrValue);
      delay(100);
      ArduinoSlave.flush();
    }
  }
  delay(100);
}
void reads() {
    if (!ArduinoSlave.available()) {
      Serial.println("Receive interface not initiated!");
    }
  if (ArduinoSlave.available()) {
    while (ArduinoSlave.available() > 0) {
      chrValue = ArduinoSlave.read();
      Serial.println(chrValue);
      if (chrValue == 66) {
        Serial.println("Slave to Master OK!");
      }
      else if (!chrValue == 66) {
        Serial.println("Slave to Master ERROR!");
        delay(100);
        ArduinoSlave.flush();
      }
    }
  }
}

Код Slave (Mega2560)

#include <SPI.h>
#include <Wire.h>
#include <SoftwareSerial.h>

SoftwareSerial ArduinoMaster(46, 48);
int i;
char chrValue = ' ';
int led1 = 5;
int led2 = 4;
String answer = "";

void setup() {
  Serial.begin(9600);
  SPI.begin();
  Wire.begin();
  ArduinoMaster.begin(115200);
  if (!ArduinoMaster.available()) {
    Serial.println("Slave to Master not initiated!");
  }
}

void loop() {
  master();
}

void master() {
  while (ArduinoMaster.available() == 0) {
  }
  if (ArduinoMaster.available() > 0) {
    while (ArduinoMaster.available() > 0) {
      chrValue = ArduinoMaster.read();
      if (chrValue == 65) {
        Serial.println("Data received:" + chrValue);
        delay(100);
      }
      else if (!chrValue == 65) {
        Serial.println("Wrong data!");
        delay(100);
      }
      delay(100);
      char chrValue = 66;
      ArduinoMaster.print(chrValue);
      Serial.println("Data was sent:" + chrValue);
      delay(100);
      ArduinoMaster.flush();
    }
  }
}

Якщо Master/Slave запустити окремо, то очікувано "....not initiated!" на обох "моніторах", а якщо разом - то просто нічого не виводиться на Master, але "....not initiated!" на Slave. Піни пробував міняти, GND підключав спільно для обох плат. Також пробував використовувати різний baud rate - не допомогло

#7 Програмування Arduino » Nano (v3) + SD + DS1307. Проблема з кроном » 2020-02-04 03:56:22

Alex.I
відповідей: 4

Всім вітання. Одразу до проблеми. Є ось такий код:

#include <SPI.h>
#include <Wire.h>
#include "RTClib.h"
#include <string.h>
#include <TimeLib.h>
#include <WeeklyAlarm.h>
#include <SD.h>

#define DS1307_I2C_ADDRESS 0x68
#define SD_ChipSelectPin 10

RTC_DS1307 RTC;
char FileName[] = "00000000.DAT";
char FolderName[] = "logs/archived/";
char file[50];
char folder[50];
char location[1];
WeeklyAlarm weeklyAlarm;
Alarm alarm1;


void setup(){
  RTC.begin();
     if (! RTC.isrunning()) {
     Serial.println(F("RTC is NOT running!"));
      return;
      }
  Serial.begin(9600);
  RTC.adjust(DateTime(F(__DATE__), F(__TIME__)));
  setTime(8, 26, 0, 3, 2, 2020);

    initial();
    getFileName();
    moveFiles();
    weeklyAlarm.prettyPrintTime(now(), Serial);
    alarm1.setCallback(callbackPlain);
    alarm1.set(AlarmType::ALL_DAYS, ON, 8, 28);
    weeklyAlarm.add(alarm1);
    alarm1.printTo(Serial);
    delay(2000);
}
void loop() {
  weeklyAlarm.handler();
  weeklyAlarm.prettyPrintTime(now(), Serial);
  delay(5000);
}

void initial (){
  File myFile;
  if(!SD.begin(SD_ChipSelectPin))
{
  Serial.println(F("Memory FAIL"));
  return;
}
  else{   
    Serial.println(F("Memory OK"));   
  }
  delay(200);
//check directories
if (!SD.exists("logs/")) {
    SD.mkdir("logs/");
  }
  if (!SD.exists("logs/archived/")) {
    SD.mkdir("logs/archived/");
  }
  if (!SD.exists("logs/start")) {
    myFile = SD.open("logs/start", FILE_WRITE);
    myFile.close();
  }
  Serial.println(F("Dirs and files OK"));
  }  
void getFileName(){
    DateTime now = RTC.now();
    FileName[0] = (now.year()/1000)%10 + '0'; //To get 1st digit from year()
    FileName[1] = (now.year()/100)%10 + '0'; //To get 2nd digit from year()
    FileName[2] = (now.year()/10)%10 + '0'; //To get 3rd digit from year()
    FileName[3] = now.year()%10 + '0'; //To get 4th digit from year()
    FileName[4] = now.month()/10 + '0'; //To get 1st digit from month()
    FileName[5] = now.month()%10 + '0'; //To get 2nd digit from month()
    FileName[6] = now.day()/10 + '0'; //To get 1st digit from day()
    FileName[7] = now.day()%10 + '0'; //To get 2nd digit from day()
    //Serial.println(filename);
}
void moveFiles(){
    File myFile;
    File myFileIn;
    File myFileOut;
    strcpy(file,FileName);
    strcpy(folder,FolderName);
    strcat(location, folder);
    strcat(location, file);
    myFileIn = SD.open("logs/start", FILE_READ);
    Serial.println(myFile.size());
        if(myFileIn.size() > 2048){
            Serial.println(F("File will be archived!!"));
            myFileOut = SD.open(location, FILE_WRITE);
              while (myFileIn.available()) {
                myFileOut.write(myFileIn.read());
              }
        myFileIn.close();
        myFileOut.close();
        Serial.println(F("File archived!!"));
        SD.remove("logs/start");
        myFileIn = SD.open("logs/start", FILE_WRITE);
        myFileIn.close();
        }
        else if(myFileIn.size() < 2048){
              Serial.println(F("Log files OK"));
              }
        }

void callbackPlain() {
      DateTime now = RTC.now();
    FileName[0] = (now.year()/1000)%10 + '0';
    FileName[1] = (now.year()/100)%10 + '0';
    FileName[2] = (now.year()/10)%10 + '0';
    FileName[3] = now.year()%10 + '0';
    FileName[4] = now.month()/10 + '0';
    FileName[5] = now.month()%10 + '0';
    FileName[6] = now.day()/10 + '0';
    FileName[7] = now.day()%10 + '0';
    File myFile;
    File myFileIn;
    File myFileOut;
    strcpy(file,FileName);
    strcpy(folder,FolderName);
    strcat(location, folder);
    strcat(location, file);
    myFileIn = SD.open("logs/start", FILE_READ);
    Serial.println(myFile.size());
        if(myFileIn.size() > 2048){
            Serial.println(F("File will be archived!!"));
            myFileOut = SD.open(location, FILE_WRITE);
              while (myFileIn.available()) {
                myFileOut.write(myFileIn.read());
              }
        myFileIn.close();
        myFileOut.close();
        Serial.println(F("File archived!!"));
        SD.remove("logs/start");
        myFileIn = SD.open("logs/start", FILE_WRITE);
        myFileIn.close();
        }
        else if(myFileIn.size() < 2048){
              Serial.println(F("Log files OK"));
              }
}

Це мій експеримент роботи "по крону". Суть проблеми
- при старті перевіряється чи наявні папки та файли, якщо ні - то вони створюються + якщо файл перевищує заданий розмір, то він копіюється до іншої папки...

...
    initial();
    getFileName();
    moveFiles();
...

перевіряв з різними розмірами файлів - працює, sd робоча.
Але, якщо я код перевірки та копіювання файлу "кидаю у крон", то система намертво підвисає, коли доходить до моменту виконная і це видно по монітору порта - результуючий напис не виводиться, а от якщо лишити просто вивід напису

Serial.println(F("Log files OK"));

чи подібне - то все проходить. Чи хтось зтикався з подібним? Пробував використовувати різни ліби - результат однаковий. Грішу на ОЗУ, т.я. після компіляції лишається, приблизно 670б

#8 Апаратні питання » Підключення OLED (128*64) через PCF8574AT » 2019-11-29 12:19:47

Alex.I
відповідей: 2

Всім вітання. Зацікавила ось така тема - підключити OLED дисплей 0.96" I2C 128x64 через I2C модуль на PCF8574T. Цікаво, т.я. дисплей та модуль використовують однакові піни для підключення, А4 та А5. База - nano v3, китайський аналог. Чи хтось стикався з чимось подібним?

Підвал форуму