Ви не увійшли.
Сторінки 1
Я теж був би радий, але в моніторах плат нічого не видно, окрім "...not initiated!", тобто пересилка не відбувається Спробував іншу Мега2560, бо допускав момент. що піни "підпалені" - теж нічого не змінилося.
Ось перероблений варіант під 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 спільний
то я помилився при вставці коду. на 9600 результат аналогічний
Спробував "викинути" відправку по "крону" і просто запхати все в loop, і як результат - нічого не видно на "моніторах" для обох плат...
Всім вітання. Якщо хтось мав справу з комінкацією 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 - не допомогло
OK. Спробую на 2560, можливо запрацює
Всім вітання. Одразу до проблеми. Є ось такий код:
#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б
Всім вітання. Зацікавила ось така тема - підключити OLED дисплей 0.96" I2C 128x64 через I2C модуль на PCF8574T. Цікаво, т.я. дисплей та модуль використовують однакові піни для підключення, А4 та А5. База - nano v3, китайський аналог. Чи хтось стикався з чимось подібним?
Сторінки 1