Перейти к содержанию

I2C CMSIS


Рекомендуемые сообщения

Доброго дня.
Пытаюсь научиться работать с интерфейсом I2C в мк STM32f407, но никак не могу разобраться с порядком команд при отправке / приеме битов(не очень понятно с чего там все начинается, какие регистры надо проверять чтобы можно было что то отправлять / принимать, бит АСK вообще загадка, даташит как то не сильно помогает), если кто сможет скинуть код с отправкой / приемом данных по шине I2C только с помощью CMSIS и прокомментирует последовательность, буду очень благодарен.

Ссылка на комментарий
Поделиться на другие сайты

  • 1 месяц спустя...

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

В 23.06.2020 в 16:05, Валентин Паскаль сказал:

////////////

Не на тот камень но очень похоже.

Изменено пользователем Falconist
Оверквотинг
Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

23.06.2020 в 15:05, Валентин Паскаль сказал:

порядком команд при отправке / приеме битов

Это все описано в reference manual на f4, начиная с раздела I2C master mode. Прям вот по шагам все описано. То, что надо записать в регистр скорости, генерирует куб.

 

23.06.2020 в 15:05, Валентин Паскаль сказал:

бит АСK вообще загадка

А это описано в документации на сам интерфейс, коей полно в инете, даже на русском языке.

 

23.06.2020 в 15:05, Валентин Паскаль сказал:

если кто сможет скинуть код с отправкой / приемом данных по шине I2C только с помощью CMSIS и прокомментирует последовательность

100$.

Ссылка на комментарий
Поделиться на другие сайты

2 часа назад, Ivan Rusev сказал:

Меня интересует вот этот бит где и когда он устанаваливается?

Это находится в следующем разделе, где про чтение данных написано. Неужели так трудно прочесть? Плюс прочти уже наконец что такое ACK и NACK в I2C.

Ссылка на комментарий
Поделиться на другие сайты

  • 1 месяц спустя...
17.08.2020 в 17:03, BARS_ сказал:

Это все описано в reference manual на f4, начиная с раздела I2C master mode. Прям вот по шагам все описано. То, что надо записать в регистр скорости, генерирует куб.

 

А это описано в документации на сам интерфейс, коей полно в инете, даже на русском языке.

 

100$.

200долларов кто больше.

17.08.2020 в 21:19, BARS_ сказал:

Это находится в следующем разделе, где про чтение данных написано. Неужели так трудно прочесть? Плюс прочти уже наконец что такое ACK и NACK в I2C.

Кстати я не увидел при чтении мастера рестарт хотя он должен быть.

Ссылка на комментарий
Поделиться на другие сайты

04.10.2020 в 12:25, Zhuk72 сказал:

Рестарт - это повторный старт.

В референс мануцал в режиме мастера при чтении.Нет рестарта в 7 битном  адресе.А в 10 битном  есть.?

Ссылка на комментарий
Поделиться на другие сайты

03.10.2020 в 17:08, Ivan Rusev сказал:

при чтении мастера рестарт

Его там и не будет. Рестарт предполагается спецификацией I2C конкретного устройства, которую ты до сих пор не прочел. Обычно, сначала производится ЗАПИСЬ адреса регистра, потом рестарт, а потом уже ЧТЕНИЕ данных из регистров. В референсе же тебе нарисовали работу мастера в общих чертах, показав, что после КАЖДОЙ передачи адреса в 7-битном режиме мастер переходит в режим чтения;:image.png.f6299232600d2ccf95cfd8a8e43604a6.png 

А вот в 10-битом режиме для этого надо сделать рестарт:

image.png.76518af055ad4b7218a6e5d132156349.png

Остальное определяет алгоритм работы шины конкретного слейва.

Изменено пользователем BARS_
Ссылка на комментарий
Поделиться на другие сайты

@Ivan Rusev Зачем себя насиловать AVR что больше не продают? Как говорят американцы... играй в своей лиге)) Или читай документацию, и не пиши сюда ерунду. 

Ссылка на комментарий
Поделиться на другие сайты

1 час назад, BARS_ сказал:

Его там и не будет. Рестарт предполагается спецификацией I2C конкретного устройства, которую ты до сих пор не прочел. Обычно, сначала производится ЗАПИСЬ адреса регистра, потом рестарт, а потом уже ЧТЕНИЕ данных из регистров. В референсе же тебе нарисовали работу мастера в общих чертах, показав, что после КАЖДОЙ передачи адреса в 7-битном режиме мастер переходит в режим чтения;:image.png.f6299232600d2ccf95cfd8a8e43604a6.png 

А вот в 10-битом режиме для этого надо сделать рестарт:

image.png.76518af055ad4b7218a6e5d132156349.png

Остальное определяет алгоритм работы шины конкретного слейва.

EV6: ADDR = 1, очищается чтением регистра SR1 с последующим чтением SR2. В 10-битном режиме ведущего приемника за этой последовательностью следует записать CR2 с START = 1.Ну и перевод вот он .И что тут написано

34 минуты назад, MasterElectric сказал:

@Ivan Rusev Зачем себя насиловать AVR что больше не продают? Как говорят американцы... играй в своей лиге)) Или читай документацию, и не пиши сюда ерунду. 

Какие же вы злые.Умные и безцеремонные.Нельзя так.Если у вас опыта больше это не даёт вам право меня футболить. AVR-прошлое.

Ссылка на комментарий
Поделиться на другие сайты

Дань моде и не дает возможности работать с AVR. Сейчас не модно с "динозаврами" работать. Считается лучше говнокодить на крутом камне, чем создать толковую прошивку на "старье". Это как с обновлениями. Не важно, что задница отвалится или АКБ сдохнет за сутки. Главное - последняя версия ПО (или "железа").

Ссылка на комментарий
Поделиться на другие сайты

21 час назад, Ivan Rusev сказал:

И что тут написано

Прочти ВНИМАТЕЛЬНО мое предыдущее сообщение. Хватит тупить!

 

13 часов назад, Zhuk72 сказал:

возможностей AVR?

Я бы не сказал, что настроить I2C в STM32 вот прям сильно сложнее, чем в AVR. По сути задать скорость и выбрать режим работы. Автор просто упорно не желает открыть описание самого I2C и вникнуть в его работу. А без понимания работы интерфейса пытаться его настроить и запустить занятие бессмысленное.

 

21 час назад, Ivan Rusev сказал:

Если у вас опыта больше это не даёт вам право меня футболить.

Тебе же наличие меньшего опыта дает право беспробудно тупить.

 

21 час назад, Ivan Rusev сказал:

AVR-прошлое.

Да что ты говоришь. А нахрена тебе ARM ядро? Будешь на дисплее крутой графический интерфейс рисовать? А может обрабатывать потоки данных? Может тебе сразу Intel ставить? Открою тебе страшную тайну, 8-битные МК очень широко используются по сей день. AVR, PIC, Silab, Cypress и т.п. Причем используются в серийно выпускаемой технике. Элементная база выбирается исходя из задачи.

Ссылка на комментарий
Поделиться на другие сайты

1 час назад, BARS_ сказал:

Прочти ВНИМАТЕЛЬНО мое предыдущее сообщение. Хватит тупить!

 

Я бы не сказал, что настроить I2C в STM32 вот прям сильно сложнее, чем в AVR. По сути задать скорость и выбрать режим работы. Автор просто упорно не желает открыть описание самого I2C и вникнуть в его работу. А без понимания работы интерфейса пытаться его настроить и запустить занятие бессмысленное.

 

Тебе же наличие меньшего опыта дает право беспробудно тупить.

 

Да что ты говоришь. А нахрена тебе ARM ядро? Будешь на дисплее крутой графический интерфейс рисовать? А может обрабатывать потоки данных? Может тебе сразу Intel ставить? Открою тебе страшную тайну, 8-битные МК очень широко используются по сей день. AVR, PIC, Silab, Cypress и т.п. Причем используются в серийно выпускаемой технике. Элементная база выбирается исходя из задачи.

я не русский мне простительно.А вы накинулись на меня как коршуны на мясо.

Гагаузы хуже молдован.И круче циган.

Ссылка на комментарий
Поделиться на другие сайты

3 минуты назад, Ivan Rusev сказал:

я не русский мне простительно

Национальность как-то влияет на развитие мозга или сообразительность? Или разрешает тупить?

Ссылка на комментарий
Поделиться на другие сайты

07.10.2020 в 23:34, BARS_ сказал:

Национальность как-то влияет на развитие мозга или сообразительность? Или разрешает тупить?

Есть понятие то что реально есть.А есть понятие симуляция.Не судите .

Ссылка на комментарий
Поделиться на другие сайты

  • 3 года спустя...

Иван Русев, исчез если ишо надо вот чтение регистра из stmpe811  по шине i2c3 ой одна ошибка в коде, не могу выкинуть....


void I2C3_ReadByte(uint8_t saddr,uint8_t maddr, uint8_t data)
{
	while (I2C3->SR2 & I2C_SR2_BUSY){;}
	I2C3->CR1|=I2C_CR1_START;
	while(!(I2C3->SR1 & I2C_SR1_SB)){;}
	I2C3->DR=saddr<<1;
	while(!(I2C3->SR1 & I2C_SR1_ADDR)){;}
	I2C3->SR2;
	while(!(I2C3->SR1&I2C_SR1_TXE)){;}
	I2C3->DR = maddr;
	while(!(I2C3->SR1&I2C_SR1_TXE)){;}
	I2C3->CR1|=I2C_CR1_START;
	while(!(I2C3->SR1 & I2C_SR1_SB)){;}
	I2C3->DR=saddr<<1|1;
	while(!(I2C3->SR1 & I2C_SR1_ADDR)){;}
	I2C3->SR2;
	I2C3->CR1|=I2C_CR1_ACK;
	I2C3->CR1&=~I2C_CR1_ACK;
	I2C3->CR1|=I2C_CR1_STOP;
	while(!(I2C3->SR1&I2C_SR1_RXNE)){;}
	data=I2C3->DR;

	}

 

Изменено пользователем Shalfey
р
Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • Он довольно бесполезен в нашу современность. Всё, что нужно добавить к 7104 вместо второго чипа, находится на скрине, который вы скинули. Основная проблема с дискретной реализацией, имхо, в ключах и в таймингах. И если вторые ещё кое-как можно обеспечить чисто ардуиновскими костылями при таких разрядностях, то побороть утечку ключей трудно. Можно искать ADG411 конечно, и делать полностью дискретную реализацию самому, но эту проблему как раз и призвана решить 7104. Проектировщику остаётся взять два хороших ОУ, компарь, опору, и сделать схему похожую 8052 со скрина, а 7104 сама разберется с управлением Два 74hc165 регистра, и данные можно выгружать в МК. Что интересно, эта топология автонуля ещё ближе к схеме АЦП В7-38. Такая система автонуля мне больше нравится, чем автонуль в 7135, в которой ключ автонуля включен между очень чувствительным к утечкам инвертирующим входом интегратора и выходом, а тут между выходом и неинвертом, что не даёт утечке ключа автонуля "подсаживать" конденсатор интегратора. Я могу ошибаться в том, насколько хорошо это реально влияет на характеристики, мне просто больше нравится такая раздельная система, когда конденсатор автонуля не включен в цепь интегратора. Так или иначе, эти АЦП, по сути, есть пик двухтактной топологии, и что-то более крутое придумать будет сложно, остаётся лишь повторять, будь то в дискрете или используя микросхемы. Выжать больше 16 бит я думаю не выйдет, сложно объяснить, но это упирается в размахи напряжения, и слишком большое увеличение резистора интегратора/его емкости (что увеличивает влияние утечек, ухудшающих линейность). Не зря в 7104 питание аналоговой части +/-15В, а на интеграторе аж 9В. На эту тему там написано, что это компромисс между всеми ошибками:   И на всякий случай, нет, MAX132 не считается, потому что у неё многотактное интегрирование
    • Всем здравствуйте! Пока на улице идут ливни, я занялся написаем скетча для приемника. Написал, подключил, проверил, все работает! Но вылезла очень большая проблема. Когда подаю питание, севера становится в среднее положение, но потом ее начинает не по детски колбасить. То в одну сторону, то в другую, то она не двигается, то очень сильно гудит и "вибрирует" качалкой. При этом L7805CV дико греется. Уже спустя 3 секунды палец обжигает. В чем может быть дело? Я так полагаю, это нехватка тока для сервы? Кушает она немало...
    • а можете ткнуть именно в ваши разработки ?
    • Ничего особенного. Перерисованная мною вот эта схема.
    • По схеме из журнала , я  33  для С8, С9  не нашёл ...  Впихнул  на 22  , но пока не подцепил подстроечник . тоисть пока что просто увидеть работу  , а потом  буду вгонять в точность  Пока планирую буду баловатся входной частью как в журнале . потом  буду думаать дальше   
    • Кстати, можете померить ёмкость БЭ, у оригиналов в районе 6000 пФ.
    • Общая ёмкость С8 и С9 должна быть 33 пФ, а судя из номиналов получается минимум 39, максимум 58 пФ. А должно быть 24-42 пФ, для этого С9 = 18 пФ. Ну это если с подстрочником. Если его нет (как у большинства) то все норм.
×
×
  • Создать...