gorlanovmax Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 Доброго времени суток, работаю с AtMega128. Пишу на CodeVisionAVR. Пишется бортовой компьютер со стрелочной индикацией, соответственно надо хранить большое количество картинок для отображения положения стрелки. Необходимо использовать внешнюю память, остановился на 24LC512. Но никак не могу ее запустить. Шина i2c точно работает, т.к. на ней еще установлены часы на базе DS3231. Часы отлично программируются и выдают данные. При этом память постоянно выдает FF во всех ячейках. Последовательность чтения и записи полностью соответствует даташиту. Не могу понять в чем моя ошибка. Код библиотеки для памяти: #include <delay.h> #define Ext_EEPROM_Adr 0b10100000 // Адрес 24LC512 на I2C шине /* read a byte from the EEPROM */ unsigned char eeprom_read(unsigned char address2, unsigned char address1) //Функция чтения из внешней EEPROM { unsigned char data; i2c_start(); //Кидаем команду "Cтарт" на шину I2C i2c_write(Ext_EEPROM_Adr); //Кидаем на шину адрес 24LC512 i2c_write(address2); //Старший байт адресного пространства 24LC512 i2c_write(address1); //Младший байт i2c_stop(); //Посылаем команду "Cтоп" i2c_start(); //Снова посылаем "старт" в шину i2c_write(Ext_EEPROM_Adr | 1); //Обращаемся к 24LC512 в режиме чтения, т.е. по адресу 101000001 data=i2c_read(0); //Принимаем данные с шины и сохраняем в переменную i2c_stop(); //Посылаем команду "Cтоп" return data; //Возвращаем значение прочитанного } /* write a byte to the EEPROM */ void eeprom_write(unsigned char address2, unsigned char address1, unsigned char data) //Функция записи во внешнюю EEPROM { i2c_start(); //Кидаем команду "Cтарт" на шину I2C i2c_write(Ext_EEPROM_Adr); //Кидаем на шину адрес 24LC512 i2c_write(address2); //Старший байт адресного пространства 24LC512 i2c_write(address1); //Младший байт i2c_write(data); //Посылаем байт для записи i2c_stop(); //Посылаем команду "Стоп" delay_ms(5); //Даем микросхеме время записать данные, EEPROM довольно медлительна } тестовый код записи: //объявление переменных unsigned char low_byte, message[23]={'H','E','L','L','O',',',' ','e','x','t','e','r','n','a','l',' ','E','E','P','R','O','M','!'}; for(low_byte=0; low_byte<23; low_byte++) { eeprom_write(0x00, low_byte, message[low_byte]); } код чтения из памяти: for(low_byte=0; low_byte<23; low_byte++) { i=eeprom_read(0x00,low_byte); TFT9341_Draw_Char(10+(low_byte*11),100,RED,WHITE,i,3 ); delay_ms(100); } 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 При чтении: i2c_stop(); в середине не нужен. Нога WP соединена с общим проводом? 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
20% скидка на весь каталог электронных компонентов в ТМ Электроникс!Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!Перейти на страницу акции Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849
gorlanovmax Опубликовано 19 июня, 2017 Автор Поделиться Опубликовано 19 июня, 2017 WP на земле. остановку шины при чтении убрал - изменений не последовало. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>> Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161
Alex Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 23 минуты назад, Yurkin2015 сказал: При чтении: i2c_stop(); в середине не нужен. Наоборот, при записи не нужен. При чтении, идёт сначала запись адреса, затем рестарт, потом команда с установленным битом чтения, затем чтение данных. Вот, из рабочего проекта : /********************************************************************************************/ static char read_block(unsigned char* pBuf, unsigned int address, unsigned int size){ char ret=0; unsigned short adr=address; unsigned char b16 = *((unsigned char*)&address+2); unsigned char cmd[2]={0xA0 | ((b16&0x01)<<1), 0xA1 | ((b16&0x01)<<1)}; I2C_ENTER_ATOMIC(); I2C_Start(); if(I2C_Send(&cmd[0], 1)){ ret=1; if(!I2C_Send((unsigned char*)&adr+1, 1)) ret=0; if(!I2C_Send((unsigned char*)&adr, 1)) ret=0; I2C_Restart(); if(!I2C_Send(&cmd[1], 1)) ret=0; if(!I2C_Recive(pBuf, size)) ret=0; } I2C_Stop(); I2C_EXIT_ATOMIC(); return ret; } /********************************************************************************************/ static char write_block(const unsigned char* pBuf, unsigned int address, unsigned int size){ char ret=0; unsigned short adr=address; unsigned char b16 = *((unsigned char*)&address+2); unsigned char cmd[2]={0xA0 | ((b16&0x01)<<1), 0xA1 | ((b16&0x01)<<1)}; I2C_ENTER_ATOMIC(); I2C_Start(); if(I2C_Send(&cmd[0], 1)){ ret=1; if(!I2C_Send((unsigned char*)&adr+1, 1)) ret=0; if(!I2C_Send((unsigned char*)&adr, 1)) ret=0; if(!I2C_Send(pBuf, size)) ret=0; } I2C_Stop(); I2C_EXIT_ATOMIC(); return ret; } /********************************************************************************************/ Может быть чем-нибудь поможет. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 Ну, осталось про ноги А0 А1 А2 спросить, на земле сидят? 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
gorlanovmax Опубликовано 19 июня, 2017 Автор Поделиться Опубликовано 19 июня, 2017 у lc512 есть только А0 и А1, обе сидят на земле. у меня в чтении рестарт есть изначально. при записи нет. поэтому и чешу репу, что вроде все верно, а не работает 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Alex Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 И ещё. Между записями должна быть выдержана пауза, порядка 5 мс. (если не ошибаюсь). А у Вас, на сколько я вижу, идёт запись 23 байт без всяких задержек. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 18 минут назад, gorlanovmax сказал: у lc512 есть только А0 и А1 Ну, не знаю, у меня в даташитах все три ноги есть. Может, всё же одна нога потерялась? 7 минут назад, Alex сказал: на сколько я вижу, Если приглядеться, то задержку видно ... 1 Ссылка на комментарий Поделиться на другие сайты Поделиться
Alex Опубликовано 19 июня, 2017 Поделиться Опубликовано 19 июня, 2017 3 минуты назад, Yurkin2015 сказал: Если приглядеться, то задержку видно ... Блин, точно, не заметил 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
gorlanovmax Опубликовано 20 июня, 2017 Автор Поделиться Опубликовано 20 июня, 2017 Да, задержка есть. Микруха стоит на плате с часами. Все три ноги повешены на землю. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
artos5 Опубликовано 20 июня, 2017 Поделиться Опубликовано 20 июня, 2017 У меня была проблема что до 8 байт писалось , а больше нет. Проблема в задержке была. А тут , если код нормальный то может и микруха не рабочая .. 0 Что может быть лучше в радиоэлектронике, чем программирование микроконтроллеров ? Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 20 июня, 2017 Поделиться Опубликовано 20 июня, 2017 3 часа назад, gorlanovmax сказал: Все три ноги повешены на землю. Ну, тогда пошагово проверять - отвечает ли микросхема на команды? Послать старт и одну единственную команду: если все ноги и адреса правильные - должен быть ответ. i2c_start(); //Кидаем команду "Cтарт" на шину I2C // Проверяем ответ Acknowledge if(i2c_write(Ext_EEPROM_Adr)) TFT9341_String(10, 10, GREEN, WHITE,"OK", 2); // получили ответ ! else TFT9341_String(10, 10, RED, WHITE, "BAD", 3); // ответа нет :( 1 Ссылка на комментарий Поделиться на другие сайты Поделиться
gorlanovmax Опубликовано 23 июня, 2017 Автор Поделиться Опубликовано 23 июня, 2017 В 20.06.2017 в 08:40, artos5 сказал: микруха не рабочая .. пробовал сначала на этой плате 32-ю. с тем же результатом. потом купил 512-ю В 20.06.2017 в 12:04, Yurkin2015 сказал: Ну, тогда пошагово проверять Спасибо, сегодня вечером проверю 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
gorlanovmax Опубликовано 23 июня, 2017 Автор Поделиться Опубликовано 23 июня, 2017 В 20.06.2017 в 12:04, Yurkin2015 сказал: Ну, тогда пошагово проверять - отвечает ли микросхема на команды? Послать старт и одну единственную команду: если все ноги и адреса правильные - должен быть ответ. i2c_start(); //Кидаем команду "Cтарт" на шину I2C // Проверяем ответ Acknowledge if(i2c_write(Ext_EEPROM_Adr)) TFT9341_String(10, 10, GREEN, WHITE,"OK", 2); // получили ответ ! else TFT9341_String(10, 10, RED, WHITE, "BAD", 3); // ответа нет :( Выдает ошибку. При этом вот такой код: i2c_start(); ack=i2c_write(Ext_EEPROM_Adr); sprintf(lcd_buff,"%03u",ack); TFT9341_String(10, 10, GREEN, WHITE,lcd_buff, 3); i2c_stop(); Выдает 0 на экране. Если я правильно понимаю, то 0 значит отсутствие ошибки. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 23 июня, 2017 Поделиться Опубликовано 23 июня, 2017 У меня для Вас плохие новости. Ноль - значит ответ-подтверждение от микросхемы не получили. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
snn_krs Опубликовано 24 июня, 2017 Поделиться Опубликовано 24 июня, 2017 В 19.06.2017 в 21:51, gorlanovmax сказал: #define Ext_EEPROM_Adr 0b10100000 // Адрес 24LC512 на I2C шине Похоже у вас ошибка в адресе. Советую сделать цикл запись - чтение для всех адресов с 0b10100000 по 0b10101110 и посмотреть на какой адрес будет ответ. По умолчанию на плате перемычки не запаяны и адрес 0b10101110 1 Ссылка на комментарий Поделиться на другие сайты Поделиться
Alex Опубликовано 24 июня, 2017 Поделиться Опубликовано 24 июня, 2017 Нормально всё у него с адресом. И о каких перемычках речь идёт ? Цитата Ноль - значит ответ-подтверждение от микросхемы не получили Ещё не факт. Ноль может означать и присутствие ACK-бита, т.к. он нулевой. Нужно смотреть функцию i2c_write. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Yurkin2015 Опубликовано 24 июня, 2017 Поделиться Опубликовано 24 июня, 2017 Будьте споки, я посмотрел эту функцию прежде чем ответить 1 Ссылка на комментарий Поделиться на другие сайты Поделиться
Alex Опубликовано 24 июня, 2017 Поделиться Опубликовано 24 июня, 2017 А, ну тады ой, звиняйте 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
gorlanovmax Опубликовано 24 июня, 2017 Автор Поделиться Опубликовано 24 июня, 2017 4 часа назад, snn_krs сказал: Похоже у вас ошибка в адресе. Советую сделать цикл запись - чтение для всех адресов с 0b10100000 по 0b10101110 и посмотреть на какой адрес будет ответ. По умолчанию на плате перемычки не запаяны и адрес 0b10101110 Спасибо. Действительно проблема была в этом. Хотя ноги и звонятся на землю. Все пишет и читает 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Рекомендуемые сообщения
Присоединяйтесь к обсуждению
Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.