I2C (Inter IC Bus) — универсальная шина данных, разработанная Philips.
Две линии связи: последовательная линия синхронизации SCL (Serial Clock), последовательная линия передачи данных SDA (Serial Data).
Синхронный, полудуплексный, несимметричный, для нескольких устройств
Ответить с данными
Поддерживает установку нескольких устройств на шине (одно ведущее и несколько ведомых, несколько главных и несколько ведомых)
Один ведущий, несколько ведомых: микроконтроллер выступает в роли хоста и доминирует над работой шины I2C. Все внешние модули, установленные на шине I2C, являются ведомыми. без разрешения шины I2C для предотвращения конфликтов.
Мультиведущий и мультиведомый: любой модуль на шине может активно выступать в роли ведущего. При возникновении конфликта шины протокол I2C проводит арбитраж. Сторона, выигравшая арбитраж, получает контроль над шиной, а проигравшая сторона автоматически становится подчиненной.
1.2 Аппаратная схема
SCL всех устройств I2C соединены вместе, а SDA подключен вместе.
И SCL, и SDA устройства должны быть настроены в режиме выхода с открытым стоком.
Добавьте подтягивающий резистор к каждому из SCL и SDA, значение сопротивления обычно составляет около 4,7 кОм.
Один ведущий и несколько ведомых: ЦП представляет собой однокристальный микрокомпьютер. В качестве ведущего устройства он обеспечивает полный контроль над линией SCL. Ведущий имеет полный контроль над линией SCL в любое время. Кроме того, в состоянии ожидания хост может активно инициировать управление SDA. Только когда ведомое устройство отправляет данные и ведомое устройство отвечает, хост передает управление SDA ведомому устройству.
Управляемая микросхема представляет собой подчиненное устройство, установленное на шине I2C, которым может быть датчик ориентации, OLED, память, модуль часов и т. д. Мощность ведомого устройства относительно невелика. Что касается линии синхронизации SCL, оно может только пассивно читать в любое время. Ведомому устройству не разрешено управлять линией SCL. Что касается линии данных SDA, ведомому устройству не разрешено активно инициировать управление SDA. Только после того, как ведущий отправит команду на чтение ведомого устройства или когда ведомое устройство ответит, ведомое устройство может на короткое время получить контроль над SDA.
Рисунок 2: SCL слева и SDA справа. Все данные могут быть введены через буфер данных или триггер Шмитта.
Поскольку вход не оказывает никакого влияния на схему, любое устройство может иметь вход в любое время.
Выход использует конфигурацию выхода с открытым стоком. Когда выходной сигнал низкий, переключатель включен, а контакт напрямую подключен к земле, что является сильным понижением, когда выходной сигнал высокий, переключатель выключен и контакт; не подключен ни к чему и находится в плавающем состоянии, поэтому все устройства могут выводить только низкий уровень, но не высокий уровень. Чтобы избежать плавания, вызванного высоким уровнем, SCL и SDA должны иметь внешний подтягивающий резистор. шина, через резистор подтянута к высокому уровню, поэтому подтяжка слабая. Таким образом, во-первых, полностью исключается явление короткого замыкания по питанию и обеспечивается безопасность схемы, во-вторых, избегается частое переключение режимов выводов; В режиме с открытым стоком вывод высокого уровня эквивалентен отключению контакта, поэтому вы можете напрямую выводить высокий уровень перед вводом. В-третьих, в этом режиме существует явление «проводного И». Пока какое-либо одно или несколько устройств выводят низкий уровень, шина находится на низком уровне. Только когда все устройства выводят высокий уровень, шина находится на высоком уровне. . Таким образом, I2C может воспользоваться этим явлением для синхронизации часов и арбитража шины в режиме с несколькими ведущими устройствами. Таким образом, хотя здесь SCL может использовать двухтактный выход в режиме одного ведущего и нескольких ведомых, он по-прежнему использует режим выхода с открытым стоком и выдвижным выходом.
1.3 Базовый блок синхронизации I2C
1.3.1 Начальные и конечные условия
начальное состояние: Во время высокого уровня SCL SDA переключается с высокого уровня на низкий уровень.
Условие прекращения: Во время высокого уровня SCL SDA переключается с низкого уровня на высокий уровень.
в начальных условиях : Когда шина I2C находится в состоянии ожидания, и SCL, и SDA находятся в состоянии высокого уровня, то есть ни одно устройство не касается SCL, а SDA и SDA переводятся на высокий уровень с помощью внешних подтягивающих резисторов, и шина находится в режиме ожидания. в спокойном состоянии. Когда хосту необходимо отправить и получить данные, он должен сначала нарушить молчание шины и сгенерировать условие запуска, то есть SCL находится на высоком уровне, не касаясь его, а затем потянуть SDA вниз, чтобы сгенерировать спадающий фронт. Когда ведомое устройство захватывает высокий уровень SCL и сигнал заднего фронта SDA, оно сбрасывается и ждет вызова ведущего устройства. После спадающего фронта SDA хосту необходимо снова отключить SCL. С одной стороны, он занимает шину, а с другой стороны, это также облегчает соединение базового блока. Позже будет обеспечено, что, за исключением условий запуска и остановки, SCL каждого последовательного блока начинается с низкого уровня и заканчивается низким уровнем.
В состоянии завершения : SCL отпускает первым и восстанавливается до высокого уровня, затем SDA отпускает и восстанавливается до высокого уровня, создавая нарастающий фронт, который запускает условие завершения. После условия одновременного завершения SCL и SDA имеют высокий уровень и возвращаются в исходное спокойное состояние. Запуск и остановка генерируются хостом, а ведомому устройству не разрешено генерировать запуск и остановку. Поэтому, когда шина простаивает, ведомый всегда должен освобождать руки и не имеет права выпрыгивать и трогать шину.
1.3.2 Отправка байта
Отправить байт: Во время низкого уровня SCL хост последовательно помещает биты данных в линию SDA (сначала старший бит), а затем освобождает SCL. Ведомое устройство будет читать биты данных во время высокого уровня SCL, поэтому SDA не разрешен. чтобы иметь какие-либо данные на высоком уровне вероятности нежелательной почты. Когда данные изменяются, выполните описанный выше процесс 8 раз, чтобы отправить один байт.
Хост низкого уровня помещает данные, а ведомый узел высокого уровня считывает данные. После условия запуска первый байт также должен быть отправлен хостом. Когда SCL низкий, если хост хочет отправить 0, он переводит SDA на низкий уровень, если он хочет отправить 1, он отпускает, и SDA восстанавливается до высокого уровня; Во время низкого уровня SCL уровень SDA может изменяться. После размещения данных хост освобождает линию синхронизации, и уровень SCL восстанавливается до высокого уровня. На высоком уровне это время, когда ведомое устройство считывает SDA, поэтому на высоком уровне SDA не может изменяться. После того, как SCL достигнет высокого уровня, ведомому устройству необходимо прочитать SDA как можно быстрее. Обычно ведомое устройство завершает чтение по нарастающему фронту SCL. Поскольку тактовый сигнал контролируется ведущим устройством, ведомое устройство не знает, когда наступит спадающий фронт, поэтому ведомое устройство будет считывать данные по нарастающему фронту сигнала SCL. После того, как хост на какое-то время отпускает SCL, он может продолжать устанавливать низкий уровень SCL и передавать следующий бит. Хосту также необходимо поместить данные в SDA как можно скорее после спада SCL. Но хост имеет контроль над тактовой частотой, поэтому ему нужно помещать данные в SDA только в тот момент, когда низкий уровень низкий. После освобождения данных хост снова освобождает SCL, SCL становится высоким, и ведомое устройство считывает этот бит. Зациклите этот процесс: хост понижает уровень SCL, помещает данные в SDA, хост освобождает SCL, а ведомое устройство считывает данные SDA. При синхронизации SCL ведущий передает, а ведомый принимает последовательно. После 8 циклов отправляются 8-битные данные, составляющие один байт. Поскольку сначала идет старший бит, первый бит является старшим битом B7 байта, а младший бит B0 отправляется последним.
1.3.3 Получить байт
получить байт: Во время низкого уровня SCL ведомое устройство последовательно помещает биты данных в линию SDA (сначала старший бит), а затем освобождает SCL. Хост будет читать биты данных во время высокого уровня SCL, поэтому SDA не разрешен. чтобы иметь какие-либо данные на высоком уровне SCL. Когда данные изменяются, выполните описанный выше процесс 8 раз, чтобы получить один байт (хост должен освободить SDA перед получением).
Подчиненное устройство низкого уровня передает данные, хост высокого уровня считывает данные. Линия SDA: ведущему необходимо освободить SDA перед получением. В это время ведомое устройство получает контроль над SDA. Если ведомому устройству необходимо отправить 0, оно устанавливает низкий уровень SDA. Если ведомому устройству необходимо отправить 1, оно отпускает и SDA. восстанавливается до высокого уровня. Низкий уровень преобразует данные, высокий уровень считывает данные. Сплошная линия представляет уровень, контролируемый ведущим устройством, а пунктирная линия представляет уровень, контролируемый ведомым устройством. SCL контролируется хостом на протяжении всего процесса, а хост SDA должен быть освобожден перед приемом и передан на управление подчиненному устройству. Поскольку тактовый сигнал SCL контролируется хостом, преобразование данных ведомого устройства в основном выполняется по заднему фронту SCL, и хост может читать в любое время, когда уровень SCL высокий.
1.3.4 Отправка и получение ответа
Отправить ответ: После получения одного байта хост отправляет один бит данных в следующий такт. Данные 0 указывают на ответ, а данные 1 указывают на отсутствие ответа.
получить ответ: После того, как хост отправит байт, он получает бит данных в следующий такт, чтобы определить, отвечает ли подчиненное устройство. Данные 0 указывают на ответ, данные 1 указывают на отсутствие ответа (хост должен выпустить SDA перед получением).
То есть после вызова времени отправки байта должно следовать время вызова ответа на прием, который используется для определения того, получил ли ведомый только что переданные ему данные. Если ведомое устройство получает его, то в бите ответа, когда ведущее устройство отпускает SDA, ведомое устройство должно немедленно опустить SDA, а затем во время высокого уровня SCL хост считывает бит ответа. Если бит ответа равен 0, это означает, что ведомое устройство действительно его получило. При получении байта необходимо вызвать ответ на отправку. Цель отправки ответа — сообщить ведомому устройству, хотите ли вы продолжить отправку. Если ведомая машина получит ответ от ведущего после отправки части данных, ведомая машина продолжит отправку. Если ведомая машина не получит ответ от главной машины, ведомая машина будет думать, что часть данных получена. было отправлено, но главная машина меня игнорирует. Возможно, хост этого не хочет. В это время подчиненное устройство послушно освободит SDA и передаст управление SDA, чтобы предотвратить вмешательство в последующие операции хоста.
1.4 Синхронизация I2C
1.4.1 Укажите адрес для записи
Укажите адрес для записи
Для указанного устройства (Slave Address) запишите указанные данные (Data) по указанному адресу (Reg Address) (то есть адресу регистра указанного устройства)
процесс: (1) Начальные условия (2) Время отправки байта — 0xD0 (ведомый адрес (7 бит) + запись (1 бит)-0) (1101 0000) (3) Получение ответа: RA = 0 (получение ответа от ведомого устройства) (4) Указанный адрес: 0x19 (0001 1001). (5) Получение ответа: RA = 0 (получение ответа от ведомого устройства) (6) Запись указанных данных: 0xAA (1010 1010) (7) Получение ответа: RA = 0 (8) Стоповый бит P (условие завершения)
После условия запуска должно быть время отправки байта. Содержимое байта должно быть адресом ведомого устройства + биты чтения и записи. Адрес ведомого устройства составляет 7 бит, а биты чтения и записи — 1 бит, что ровно. 8 бит. Отправка подчиненного адреса предназначена для определения объекта связи, а отправка битов чтения и записи — для подтверждения, следует ли записывать или читать дальше. Теперь хост отправляет часть данных. Содержимое байта преобразуется в шестнадцатеричное. Первым идет старший бит, который равен 0xD0. Следующий бит — это бит ответа (RA) принимающего ведомого устройства. Бит записи заканчивается, и уровень SCL устанавливается на низкий уровень. После этого хост должен выпустить SDA, а затем бит подтверждения RA.
Высокий уровень после окончания ответного бита RA генерируется ведомым устройством, отпускающим SDA. спадающий фронт SCL произошел почти одновременно.
Если после завершения ответа вы продолжите отправлять один байт, второй байт может быть отправлен внутрь назначенного устройства. Подчиненное устройство может определить использование второго собственного и последующих байтов. Как правило, второй байт может быть адресом регистра или словом управления командой и т. д., а третий байт — это содержимое, которое хост хочет записать по адресу регистра (второй байт).
P — стоповый бит.
Цель этого кадра данных: для устройства, которое указывает адрес подчиненного устройства 1101000, записать данные 0xAA в его внутренний регистр по адресу 0x19. 0 означает: хост выполнит операцию записи в последующее время; 1 означает: хост выполнит операцию считывания в последующей временной последовательности;
1.4.2 Чтение текущего адреса
Текущий адрес прочитан
Для указанного устройства (Адрес ведомого) прочтите данные ведомого устройства (Данные) по адресу, указанному указателем текущего адреса.
процесс: (1) Начальные условия (2) Время отправки байта — 0xD1 (ведомый адрес (7 бит) + чтение (1 бит)-1) (1101 0001) (3) Получение ответа: RA = 0 (получение ответа от ведомого устройства) (4) Чтение данных подчиненного устройства: 0x0F (0000 1111) (7) Отправить ответ: SA = 0 (8) Стоповый бит P (условие завершения)
Бит чтения и записи равен 1, что указывает на то, что должна быть выполнена следующая операция чтения. После того как ведомое устройство ответит (RA=0), направление передачи данных изменится на противоположное. Ведущий хочет передать управление SDA ведомому, и ведущий вызывает время приема байта для выполнения операции приема.
Во втором байте ведомое устройство получает разрешение от ведущего устройства и может осуществлять запись в SCL на низком уровне SCL. Ведущее устройство считывает SDA на высоком уровне SCL. Наконец, ведущее устройство последовательно читает на высоком уровне SCL. 8 бит, принимается один байт данных, отправленных ведомым устройством, который равен 0x0F. А какой регистр слейва 0x0F? Что касается времени чтения, протокол I2C предусматривает, что при адресации хоста флаг чтения и записи устанавливается в 1. Следующий байт немедленно переключится на время чтения. Следовательно, хост начнет получать до того, как успеет указать, какой регистр он хочет прочитать, поэтому ссылки для указания адреса здесь нет. В ведомой машине все регистры выделены в линейную область, и будет отдельная переменная-указатель, указывающая один из регистров. Этот указатель по умолчанию указывает на включение питания, обычно указывает на адрес 0 и каждый раз, когда записывается байт. После прочтения байта указатель автоматически увеличится один раз и перейдет на следующую позицию. Затем при вызове тайминга чтения текущего адреса, если хост не укажет, какой адрес читать, слейв вернется в регистр, на который указывает байт. текущее значение.
1.4.3 Чтение по указанному адресу
Укажите адрес для чтения
Для указанного устройства (Slave Address) по указанному адресу (Reg Address) прочитайте данные подчиненного устройства (Data).
Сначала начните, затем повторите запуск, затем остановитесь процесс: (1) Начальные условия (2) Время отправки байта — 0xD0 (ведомый адрес (7 бит) + запись (1 бит)-0) (1101 0000) (3) Получение ответа: RA = 0 (получение ответа от ведомого устройства) (4) Указанный адрес: 0x19 (0001 1001). (5) Получение ответа: RA = 0 (получение ответа от ведомого устройства) (6) Повторите начальное условие. (7) Время отправки байта — 0xD1 (ведомый адрес (7 бит) + чтение (1 бит)-1) (1101 0001) (8) Получение ответа: RA = 0 (9) Чтение данных подчиненного устройства: 0xAA (1010 1010) (10) Отправить ответ: SA = 0 (11) Стоповый бит P (условие завершения)
Первая часть — запись по указанному адресу, но указан только адрес, а времени на запись нет. Вторая часть — чтение текущего адреса, поскольку адрес только что был указан, поэтому читается текущий адрес; позвонил еще раз.
Указанный адрес подчиненного устройства равен 1101000, флаг чтения-записи равен 0, и после ответа подчиненного устройства записывается еще один байт (второй байт), указывающий адрес 0x19. указатель адреса, то есть после того, как ведомое устройство получит данные, указатель его регистра указывает на позицию 0x19.
Sr — это повторяющееся условие запуска, что эквивалентно запуску нового времени, поскольку указанный флаг чтения и записи может следовать только за первым байтом условия запуска, поэтому, если вы хотите переключить направление чтения и записи, вы можете только это сделать. другое стартовое условие.
Затем после условия запуска переадресуйте и укажите бит флага чтения-записи. В это время бит флага чтения-записи равен 1, что указывает на то, что он должен быть прочитан. Затем хост получает байт, который является данными. 0xAA по адресу 0x19.
2. МПУ6050
2.1 Знакомство с MPU6050
MPU6050 — это 6-осевой датчик положения, который может измерять параметры ускорения и угловой скорости собственных осей X, Y и Z. Благодаря объединению данных можно дополнительно получить угол положения (угол Эйлера). Он часто используется в . балансировка транспортных средств, самолетов и т. д., которым необходимо обнаружить сцену жеста.
3-осевой акселерометр (Акселерометр): измеряет ускорение по осям X, Y и Z.
3-осевой гироскоп (гироскоп): измеряет угловую скорость по осям X, Y и Z.
Если взять в качестве примера фюзеляж самолета, то угол Эйлера — это угол между фюзеляжем самолета и первоначальными тремя осями.
самолетНос самолета наклоняется вниз или вверх, угол между этой осью называетсяПодача;
самолетФюзеляж кренится влево или вправо, угол между этой осью называетсяРулон;
самолетДержите фюзеляж на уровне,Поверните нос самолета влево или вправо, угол между этой осью называетсярыскание。
Угол Эйлера отражает положение самолета в данный момент, независимо от того, наклонен ли он вверх или вниз, влево или вправо.
Общие алгоритмы объединения данных обычно включают дополнительную фильтрацию, фильтрацию Калмана и т. д., а также расчет ориентации в инерциальной навигации.
Акселерометр : Пунктирная линия посередине — это ось индукции. В середине находится небольшой ползунок определенной массы, который может скользить влево и вправо. Слева и справа от него находится пружина. Когда ползунок перемещается, он приводит в движение потенциометр, расположенный на нем. Этот потенциометр представляет собой резистор, делящий напряжение. Измеряя выходное напряжение потенциометром, вы можете получить значение ускорения небольшого ползунка. Этот акселерометр на самом деле представляет собой пружинный динамометр. Согласно второму закону Ньютона F = ma. Если вы хотите измерить ускорение a, вы можете найти объект с единичной массой и измерить силу F. Вот и все. На каждой из осей X, Y и Z имеется акселерометр. Акселерометры обладают статической стабильностью, но не динамической стабильностью.
Гироскопический датчик : В середине находится вращающееся колесо с определенной массой. Когда вращающееся колесо вращается с высокой скоростью, в соответствии с принципом сохранения углового момента вращающееся колесо имеет тенденцию сохранять свой первоначальный угловой момент. Эта тенденция может сохраняться. направление оси вращения не изменилось. Когда направление внешнего объекта вращается, направление внутренней оси вращения не будет вращаться, что приведет к угловому отклонению при соединении балансировочного кольца. Если присоединить к соединению вращающийся потенциометр и измерить напряжение потенциометра, можно получить угол поворота. Гироскоп должен иметь возможность напрямую определять угол, но гироскоп этого MPU6050 не может напрямую измерять угол. Он измеряет угловую скорость, то есть угловую скорость вращения чипа вокруг осей X, Y и Z. -ось. Интеграл угловой скорости — это угол. Однако, когда объект неподвижен, значение угловой скорости не может быть полностью возвращено к нулю из-за шума. Тогда после непрерывного накопления интегралов этот небольшой шум приведет к медленному дрейфу рассчитанного угла. который представляет собой угол, полученный путем интегрирования угловой скорости. Он не выдерживает испытания временем, но этот угол не представляет проблемы, независимо от того, является ли он неподвижным или движущимся, и на него не влияет движение объекта. Гироскопы обладают динамической, а не статической стабильностью.
Согласно акселерометру, который имеет статическую стабильность, но не имеет динамической стабильности; гироскоп имеет динамическую стабильность, но не имеет статической стабильности. Эти две характеристики позволяют нам учиться на сильных сторонах друг друга и дополнять слабые стороны друг друга, выполняя дополнительную фильтрацию. , мы можем объединить как статическую, так и динамическую устойчивость. Поза неудобная.
Выбор полной шкалы акселерометра: ±2, ±4, ±8, ±16 (g) (1g = 9,8 м/с2)
Полномасштабный выбор гироскопа: ±250, ±500, ±1000, ±2000 (°/сек, градус/секунда, единица угловой скорости, сколько градусов вращения в секунду) (чем больше полномасштабный выбор, тем шире диапазон диапазон измерения: чем меньше полномасштабный диапазон, тем выше будет разрешение измерения.
Настраиваемый цифровой фильтр нижних частот: регистр можно настроить для выбора фильтрации нижних частот выходных данных.
Настраиваемый источник синхронизации
Настраиваемое разделение частоты дискретизации: источник тактового сигнала можно разделить с помощью делителя частоты, чтобы обеспечить тактовый сигнал для преобразования АЦП и других внутренних схем. Управляя коэффициентом деления частоты, вы можете контролировать скорость AD-преобразования.
Адрес подчиненного устройства I2C: 1101000 (AD0=0) или 1101001 (AD0=1)
110 1000 преобразуется в шестнадцатеричное число, то есть 0x68, поэтому некоторые говорят, что подчиненный адрес MPU6050 равен 0x68. Но при связи I2C старшие 7 бит первого байта — это адрес подчиненного устройства, а младший бит — бит чтения и записи. Поэтому, если вы считаете, что 0x68 — это адрес подчиненного устройства, при отправке первого байта вы должны сначала изменить его. 0x68 Сдвиг влево на 1 бит (0x68 << 1), затем чтение и запись побитно или вверх, чтение 1 и запись 0.
Другой метод заключается в сдвиге данных 0x68 влево на 1 бит (0x68 << 1) в качестве подчиненного адреса, который равен 0xD0. В этом случае подчиненный адрес MPU6050 равен 0xD0. В настоящее время при фактической отправке первого байта, если вы хотите записать, просто используйте 0xD0 в качестве первого байта, если вы хотите прочитать, используйте 0xD0 или 0x01 (0xD0 | 0x01), то есть 0xD1 в качестве первого байта. . Это представление не требует операции сдвига влево, или, другими словами, это представление объединяет биты чтения и записи в адрес подчиненного устройства. 0xD0 — адрес записи, а 0xD1 — адрес чтения.
2.3 Аппаратная схема
приколоть
Функция
VCC, земля
источник питания
SCL, SDA
Контакт связи I2C
XCL, XDA
Контакты связи хоста I2C
АД0
Младший бит адреса подчиненного устройства
ИНТ
Выход сигнала прерывания
LDO: линейный стабилизатор напряжения с низким падением напряжения, стабилизатор напряжения 3,3 В.
SCL и SDA: это контакты связи I2C. Модуль имеет встроенные два подтягивающих резистора 4,7 кОм, поэтому при подключении просто подключите SDA и SCL непосредственно к порту GPIO. Нет необходимости подключать внешние подтягивающие резисторы. .
XCL, XDA: контакты связи хоста I2C. Эти два контакта предназначены для расширения функций чипа. Обычно используется для внешних магнитометров или барометров. Когда эти микросхемы расширения подключены, главный интерфейс MPU6050 может напрямую обращаться к данным этих микросхем расширения и считывать данные этих микросхем расширения в MPU6050, оснащенный блоком DMP. расчет отношения. Вывод AD0: это младший бит адреса ведомого устройства. Если он подключен к низкому уровню, 7-битный адрес ведомого устройства равен 1101000; если он подключен к высокому уровню, 7-битный адрес ведомого устройства равен 1101001. На принципиальной схеме есть резистор, который по умолчанию слабо притянут к низкому уровню, поэтому, если вывод остается плавающим, это низкий уровень. Если вы хотите подключить его к высокому уровню, вы можете напрямую подключить AD0 к VCC. и сильно потяните его вверх до высокого уровня.
INT: вывод прерывания. Вы можете настроить некоторые события внутри чипа для запуска вывода вывода прерывания, например, готовность данных, ошибка хоста I2C и т. д.
Чип также имеет встроенные функции: обнаружение свободного падения, обнаружение движения, обнаружение нулевого движения и т. д. Эти сигналы могут запускать вывод INT для генерации перехода уровня, а сигналы прерывания можно настроить при необходимости.
Питание микросхемы MPU6050 составляет 2,375-3,46 В, что является устройством питания 3,3 В и не может быть напрямую подключено к 5 В. Поэтому добавляется стабилизатор напряжения 3,3 В, а напряжение на входной клемме VCC_5 В может находиться в диапазоне от 3,3 В до 5 В. Затем регулятор напряжения 3,3 В выдает стабильное напряжение 3,3 В для питания чипа, пока на клемму 3,3 В подается питание. , Загорится индикатор питания.
2.4 Блок-схема MPU6050
CLKIN и CLKOUT — это входные и выходные контакты тактового сигнала, но обычно мы используем внутренние тактовые сигналы.
Серая часть: датчик внутри чипа, акселерометр по оси XYZ и гироскоп по оси XYZ.
Также имеется встроенный датчик температуры, который можно использовать для измерения температуры.
Эти датчики по сути эквивалентны переменным резисторам. После деления напряжения они выдают аналоговое напряжение, а затем выполняют аналого-цифровое преобразование через АЦП. После завершения преобразования данные с этих датчиков равномерно помещаются в данные. регистр, который можно получить, прочитав регистр данных. Значение, измеренное датчиком. Все преобразования внутри этого чипа полностью автоматизированы.
Каждый датчик имеет блок самотестирования, который используется для проверки качества чипа. При запуске самотестирования чип имитирует внешнюю силу, действующую на датчик. Эта внешняя сила приводит к искажению данных датчика. больше, чем обычно. Процесс самотестирования: сначала вы можете включить самотестирование, прочитать данные, затем включить самотестирование, прочитать данные, вычесть два данных, и полученные данные называются ответом самотестирования. Для этого ответа самотестирования в руководстве указан диапазон. Если он находится в этом диапазоне, это означает, что с чипом проблем нет.
Насос заряда: это насос заряда или насос заряда.
Для вывода CPOUT требуется внешний конденсатор.
Регистр состояния прерывания: может контролировать, какие внутренние события выводятся на вывод прерывания.
FIFO: регистр «первым пришел — первым обслужен», который может кэшировать поток данных.
Регистр конфигурации: вы можете настроить различные внутренние схемы.
Регистр датчиков: регистр данных, в котором хранятся данные каждого датчика.
Заводская калибровка: это означает, что внутренние датчики откалиброваны.
Цифровой процессор движения: для краткости DMP — это аппаратный алгоритм расчета положения, встроенный в чип. Его можно использовать для расчета положения с помощью официальной библиотеки DMP.
FSYNC: Синхронизация кадров.
3. 10-1 Чтение и запись программного обеспечения I2C MPU6050
3.1 Подключение оборудования
Через программную связь I2C читайте и записывайте регистры внутри чипа MPU6050. Записывая в регистр конфигурации, вы можете настроить подключаемый модуль. Прочитав регистр данных, вы можете получить данные подключаемого модуля. На OLED-экране будут отображаться считанные данные. Идентификационный номер этого MPU6050 имеет фиксированное значение 0x68. Ниже три слева — это выходные данные датчика ускорения, которые представляют собой ускорение по осям X, Y и Z соответственно. Три справа — это выходные данные датчика гироскопа. которые представляют собой угловую скорость осей X, Y и Z. SCL подключен к выводу PB10 STM32, а SDA подключен к выводу PB11. Поскольку здесь реализовано переключение программного уровня, два порта GPIO можно подключить по своему желанию.
3.2 Результаты работы
3.3 Поток кода
STM32 является хостом, а MPU6050 — ведомым, что соответствует режиму «главный-подчиненный».
Установите модули .c и .h уровня связи I2C.
Напишите базовую инициализацию GPIO I2C.
6 основных единиц синхронизации: начало, завершение, отправка байта, получение байта, отправка ответа, получение ответа.
Создайте модули .c и .h MPU6050.
На основе модуля связи I2C он реализует чтение по указанному адресу, запись по указанному адресу, запись регистров для настройки чипа и чтение регистров для получения данных датчика.
основной.c
Вызовите модуль MPU6050, инициализируйте, получите данные и отобразите данные.
STM32 включает в себя аппаратную схему приемопередатчика I2C, которая может автоматически выполнять такие функции, как генерация тактовых импульсов, генерация начальных и конечных условий, передача и прием ответных битов, а также передача и прием данных аппаратным обеспечением, снижая нагрузку на ЦП.
Поддержка модели с несколькими хостами
Поддержка 7-битного/10-битного режима адреса.
Поддерживает различные скорости связи: стандартную скорость (до 100 кГц), быструю (до 400 кГц)
Поддержка прямого доступа к памяти
Совместимость с протоколом SMBus.
Аппаратные ресурсы I2C STM32F103C8T6: I2C1, I2C2
4.2 Блок-схема I2C
Слева расположены контакты связи: SDA и SCL используются SMBus; Выводы, полученные от обычных периферийных устройств, обычно подключаются к внешнему миру через режим мультиплексирования порта GPIO (см. таблицу).
Вышеупомянутая часть управления данными: SDA Основная часть передачи и приема данных — это регистр данных DR (РЕГИСТР ДАННЫХ) и регистр сдвига данных. Когда данные необходимо отправить, один байт данных может быть записан в регистр данных DR. Когда в сдвиговом регистре нет данных для сдвига, значение регистра данных будет далее передано в сдвиговый регистр. Во время процесса смещения следующие данные могут быть непосредственно помещены в регистр данных и подвергнуты ожиданию. Как только предыдущий сдвиг данных будет завершен, следующие данные могут быть легко подключены и продолжены. Когда данные передаются из регистра данных в сдвиговый регистр, бит TXE регистра состояния устанавливается в 1, что указывает на то, что регистр передачи пуст.
Прием: входные данные побитно перемещаются из вывода в сдвиговый регистр. При сборе одного байта данных данные передаются из сдвигового регистра в регистр данных целиком, при этом устанавливается флаг RXNE. одновременно, что указывает на прием. Регистр не пуст, тогда данные можно считать из регистра данных. Что касается того, когда получать и когда отправлять, вам необходимо записать соответствующие биты в регистр управления для работы. Условия запуска, условия завершения, биты ответа и т. д. завершаются посредством управления данными.
Компаратор и адресный регистр используются в подчиненном режиме.
SCL: Управление тактовым сигналом используется для управления линией SCL. Запишите соответствующий бит в регистр управления часами, и схема выполнит соответствующую функцию. Логическая схема управления, запись в регистр управления может управлять всей схемой. Рабочее состояние схемы можно узнать, прочитав регистр состояния.
При отправке и получении большого количества байтов DMA можно использовать для повышения эффективности.
4.3 Базовая структура I2C
SDA: поскольку I2C имеет старший порядок, этот регистр сдвига сдвигается влево. При отправке сначала удаляется старший бит, затем второй старший бит. Тактовый сигнал SCL сдвигается один раз и сдвигается 8 раз, а в линии SDA можно разместить 8 байтов от старшего бита к младшему. При приеме данные перемещаются справа через порт GPIO и, наконец, 8 раз принимается один байт. Выходные данные выводятся в порт через порт GPIO. Входные данные вводятся в сдвиговый регистр через порт GPIO.
Порт GPIO необходимо настроить на мультиплексный режим вывода с открытым стоком; мультиплексирование означает, что состояние порта GPIO контролируется встроенными периферийными устройствами, а выход с открытым стоком — это конфигурация порта, требуемая протоколом I2C. Даже в режиме вывода с открытым стоком порт GPIO может быть входным.
SCL: Контроллер часов управляет линией синхронизации через GPIO.
4.4 Хост отправляет
Когда STM32 хочет записать по указанному адресу, ему необходимо следовать диаграмме последовательности передачи передатчика.
7-битный адрес: адресуется один байт после условия запуска.
10-битный адрес: два байта после условия запуска являются адресацией. Первый байт — это заголовок кадра, а содержимое — 5-битный бит флага 11110 + 2-битный адрес + 1 бит чтения-записи; Чистый 8-битный адрес.
После инициализации шина по умолчанию переходит в состояние ожидания, а STM по умолчанию переходит в подчиненный режим. Чтобы сгенерировать условие запуска, STM32 необходимо выполнить запись в регистр управления (CR1), записать 1, а затем STM32 перейдет из подчиненного режима в ведущий режим. .
Событие EV5 можно рассматривать как бит флага SB — это бит регистра состояния, указывающий состояние оборудования. SB=1 означает, что условие запуска было отправлено.
Затем вы можете отправить байт адреса подчиненного устройства. Адрес подчиненного устройства необходимо записать в регистр данных DR. После записи в DR аппаратная схема автоматически передаст байт адреса в сдвиговый регистр, а затем передаст слово Узел. отправляется на шину I2C, а затем оборудование автоматически получит ответ и вынесет решение. Если ответа нет, оборудование установит флаг сбоя ответа, а затем этот флаг может примениться для прерывания, чтобы напомнить нам.
Когда адресация будет завершена, произойдет событие EV6, и бит флага ADDR будет равен 1. Этот бит флага указывает на окончание передачи адреса в ведущем режиме.
Событие EV8_1 означает, что флаг TxE равен 1, сдвиговый регистр пуст и регистр данных пуст. Нам нужно выполнить запись в регистр данных DR для отправки данных. После записи в DR, поскольку сдвиговый регистр пуст, DR. немедленно переключится на сдвиговый регистр для отправки. Произойдет событие EV8. Сдвиговый регистр не пуст, а регистр данных пуст, что означает, что сдвиговый регистр отправляет данные. Следовательно, здесь в процессе генерируется время данных 1. В этот момент данные 2 будут записаны в регистр данных и ожидают. После получения бита ответа биты данных передаются в сдвиговый регистр для передачи. Состояние в этот момент такое, что сдвиговый регистр не пуст и Регистр данных пуст, поэтому в это время инцидент с EV8 произошел снова.
Затем отправляются данные 2, но на этот раз следующие данные записаны в регистр данных и ждут. Как только событие EV8 обнаружено, можно записать следующие данные.
После того, как данные, которые вы хотите отправить, записаны, новые данные не записываются в регистр данных. Когда текущий сдвиг данных в сдвиговом регистре завершен, сдвиговый регистр пуст, и регистр данных также пуст. Событие EV8_2, TxE=1 означает, что сдвиговый регистр пуст, регистр данных пуст, BTF: флаг окончания передачи байта, при передаче, когда будут отправлены новые данные, а в регистр данных не записаны новые данные. При обнаружении EV8_2 может быть сгенерировано условие завершения Stop. Очевидно, что для генерации условия завершения в регистре управления должны быть соответствующие биты, которыми можно управлять. На этом последовательность отправки завершена.
4.5 Прием принимающей стороны
7-битный главный прием: начало, подчиненный адрес + чтение, прием ответа, прием данных, отправка ответа... прием данных, отсутствие ответа, завершение
Сначала запишите стартовый бит регистра управления, чтобы сгенерировать условие запуска, а затем дождитесь события EV5 (указывающего, что условие запуска было отправлено).
После адресации принимается ответ, а после окончания генерируется событие EV6 (указывающее, что адресация завершена).
Данные 1 означают, что данные вводятся через сдвиговый регистр.
EV6_1 указывает, что данные все еще смещаются. После получения ответа это означает, что сдвиговый регистр успешно переместил один байт данных 1. В это время сдвинутый байт передается в регистр данных целиком, и одновременно устанавливается флаг RxNE, указывающий, что регистр данных не пуст, то есть получен один байт данных. Статус — событие EV7, RxNE=1. Чтение регистра DR очищает событие, что означает. что данные получены. После того, как мы прочитали данные, события больше нет.
Конечно, когда данные 1 не были прочитаны, данные 2 могут быть непосредственно перемещены в сдвиговый регистр. После этого сдвиг данных 2 завершен, данные 2 получены, генерируется событие EV7, данные 2 считываются и. событие EV7 исчезло.
Когда прием больше не требуется, регистр управления битом ответа ACK должен быть установлен в 0 заранее, когда происходит последний блок синхронизации, и устанавливается запрос условия завершения, то есть событие EV7_1. После этого происходит отсутствие ответа NA. Будет задан бит STOP, поэтому генерируется условие завершения.
4.6 Сравнение сигналов программного и аппаратного обеспечения
5.2 Аппаратная реализация чтения и записи I2C MPU6050
5.2.1 Подключение оборудования
SCL подключен к выводу PB10 STM32, а SDA подключен к выводу PB11. Поскольку здесь реализовано переключение программного уровня, два порта GPIO можно подключить по своему желанию. Верхние данные OLED — это идентификационный номер устройства. Идентификационный номер этого MPU6050 имеет фиксированное значение 0x68. Ниже три слева — это выходные данные датчика ускорения, которые представляют собой ускорение по осям X, Y и Z соответственно. Три справа — это выходные данные датчика гироскопа. которые представляют собой угловую скорость осей X, Y и Z.
5.2.2 Результаты работы
5.2.3 Процесс реализации кода
Настройте периферийные устройства I2C, инициализируйте периферийные устройства I2C, замените MyI2C_Init (1) Включите часы периферийного устройства I2C и соответствующего порта GPIO, (2) Инициализируйте порт GPIO, соответствующий периферийному устройству I2C, в мультиплексированном режиме с открытым стоком. (3) Используйте структуру для настройки всего I2C. (4) I2C_Cmd, включить I2C
Управляйте периферийными схемами, реализуйте синхронизацию записи по указанным адресам и заменяйте WriteReg.
Управляйте периферийной схемой, чтобы реализовать синхронизацию чтения указанного адреса и заменить ReadReg.