ZiB
Продолжаем описание программного USB на базе микроконтроллеров STM8 (первая часть читать).
Сегодня расскажу о коде приемника и о первом включении устройства:
Передача данных
В процессе “подключения” устройства к ПК пришлось поправить код передатчика, теперь в подпрограмму передается адрес (указатель) на массив данных.
Прием данных
К сожалению на текущий момент не удалось на лету и вырезать незначащие биты, реализовано только декодирование NRZI.
При приеме так же используются обе линии, это позволяет декодировать NRZI буквально двумя командами.
Вот краткий алгоритм работы приемника (декодера):
Использование тестового сигнала избыточно, да и проверку можно делать по другому, например декодирование и проверка конца пакета, может быть выполнено вот так:
srl a
xor a,(y)
tnz (y)
jreq L_End_Rx
С данным кодом я работал последний раз когда пытался, все таки реализовать вырезку незначащих бит.
Важная часть в декодировании захват сигналов всегда в одно и тоже время.
К сожалению у STM8 команды могут выполнятся длительное время от 1 до 6 тактов, для устранения этого недостатка пришлось использовать один таймер.
По первому фронту сигнала запускается таймер 1, после вхождения в обработчик прерывания считывается счетный регистр и выполняется переход в перед на кол-во циклов (комманд nop).
Таким образом получается, что чем больше задержка на вход в прерывания тем дальше переход по коду.
Данный подход позволяет “удерживать” точку захвата в пределах одного такта микроконтроллера.
Это пожалуй ключевой момент, без него не возможно обеспечить начала захвата сигнала в одно и тоже время.
Вот как это выглядит на ассемблере:
_usb_rx: ldw x, #L_Delay_Begin ; адрес начала таблицы задержек addw x, 21086 ; + смещение (значение таймера) cpw x, #L_Delay_End ; проверка выхода за границу таблицы (защита!) jruge L_Error jp (x) ; переход по таблице задержек L_Error: iret ; аврийный выход L_Delay_Begin: nop nop nop nop nop nop
Прошу извинить за столь сумбурное описание реализации.
Из протокола я реализовал чтение дескриптора и то, не полностью.
Описывать его не буду, так как сам плохо понимаю, что там происходит
Записал небольшой видеоролик с подключением тестового устройства к ПК:
Исходный код
Скачать [2014-02-STM8S-USB.zip]
Внимание!!! Код СЫРОЙ, без оформления и тщательной проверки.
Код собран компилятором Cosmic версии 4.3.7, к сожалению IAR-ом не пользуюсь.
Код можете использовать без ограничений, одна только просьба ссылаться на данный сайт, ну и указывать автора, т.е. меня
Будут вопросы пишите, форма обратной связи в меню сайта (см. выше).
Источник: http://ziblog.ru/2014/02/22/programmnyiy-usb-na-stm8-chast-2.html
STM8S + SDCC: Программирование БЕЗ SPL, система тактирования
разделы: STM8 , дата: 11 апреля 2018г
Систему тактирования я уже бегло рассматривал в случае использования SPL.
Стандартная периферийная библиотека, на мой взгляд, предлагается фирмой STM в качестве инструмента для быстрого освоения семейства микроконтроллеров STM8, программистами ранее не работавшими с ними.
Сейчас я считаю, что она совершенно лишняя. Хотя, в примерах я использую именованные константы взятые из заголовочных файлов SPL.
Документация которая понадобится для прочтения статьи: Reference Manual STM8S – RM0016, глава 9. В качестве целевого микроконтроллера я буду использовать 20-пиновый STM8S103F3P6.
Скачать полные исходники со сборочными файлам и скомпилированными прошивками, можно по ссылке в конце статьи.
1. Система тактирования STM8S, ключевые особенности
Система тактирования микроконтроллеров STM8S представлена на следующей картинке:
-
Особенности системы тактирования микроконтроллеров STM8S:
- В системе имеется два тактовых генератора, высокочастотный и низкочастотный.
- Внутренний низкочастотный генератор – LSI, работает на частоте 128 кГц, и имеет погрешность ±12%. Сторожевой таймер и система автопробуждения тактируется только от него.
- В случае AWU – системы автопробуждения, через параметр Option Bytes – CKAWUSEL, возможно назначить внешний источник тактового сигнала HSE с предделителем в качестве источника тактирования AWU.
- В роли высокочастотного генератора могут выступать: а) внутренний генератор – HSI работающий на частоте 16 МГц и имеющий предделитель на 1, 2, 4, 8; б) внешний генератор с частотой до 24 МГц для stm8s2xx серии и до 16 МГц для чипов stm8s1xx серии; в) внутренний генератор работающий от внешнего кварца на частотах 1-24(16 для stm8s1xx) МГц.
- Система тактирования имеет модуль безопасности CSS которая может отслеживать работу внешнего генератора или кварца и в случае неисправности оных, переключить микроконтроллер на работу от внутреннего генератора с предделителем равным 8, т.е. на частоту 2 МГц.
- Все тактовые генераторы могут включаться и отключаться.
- Все периферия при старте микроконтроллера, по умолчанию находится в включенном состоянии. Она может быть отключена через регистры CLK_PCKENR1 и CLK_PCKENR2.
- Микроконтроллер может подать тактовый сигнал на выход CCO.
Регистры отвечающие из систему тактирования и их значения по умолчанию представлены на следующей таблице:
Дефолтные настройки системы тактирования можно изменять через Options Bytes. Они разные для различных серий STM8S. В случае STM8S103 они выглядят так:
2. Подключение и отключение периферии к шинам тактирования. Регистры CLK_ICKR, CLK_PCKENR1 и CLK_PCKENR2
Начнем с простого. В качестве шаблонного проекта возьмем Blink на таймере TIM4 из предыдущей статьи.
В главной функции main() заменим строки:
CLK_CKDIVR=0;
на вызов функции следующего содержания:
static inline void clk_setup() { CLK_CKDIVR=0;
}
С этой функцией и будем в дальнейшем работать.
За подключение периферии к шине тактирования отвечают два регистра: CLK_PCKENR1 и CLK_PCKENR2
Т.к. в программе из периферии используется лишь таймер TIM4, в функцию clk_setup() следует добавить строки:
CLK_PCKENR1=CLK_PCKENR1_TIM4; CLK_PCKENR2=0;
Внутренними генераторам HSI и LSI управляет регистр CLK_ICKR:
В установках по умолчанию для этого регистра, низкочастотный LSI – генератор выключен, а высокочастотный HSI генератор включен. Это установки полностью соответствуют нашим запросам и регистр CLK_ICKR пока можно не трогать.
3. Внутренний высокочастотный генератор HSI. Регистр CLK_CKDIVR
Чип STM8S после включения питания стартует с внутренним 16 МГц генератором тактового сигнала HSI. Выход частоты с него можно менять установкой предделителя fHSI равному 1, 2, 4, или 8. По умолчанию применяется предделитель равный 8.
Частотой процессора можно управлять с помощью предделителя fCPU. По умолчанию он равен 1.
Предделители fHSI и fCPU устанавливаются через регистр CLK_CKDIVR:
Если записать в регистр значение CLK_PRESCALER_HSIDIV1, т.е. ноль, т.о. микроконтроллер будет работать на частоте 16 МГц. Светодиод при этом будет мигать с полупериодом в 1 секунду. Однако если понизить частоту процессора до 1 МГц командой:
CLK_CKDIVR=CLK_PRESCALER_HSIDIV1|CLK_PRESCALER_CPUDIV16;
то светодиод все-равно будет мигать с полупериодом в 1 секунду. Почему? Т.к. задержка формируется через таймер, и если посмотреть на схему тактирования:
то видно, что предделитель fCPU никак на периферию не влияет. Он влияет только на частоту процессора. Если вместо задержки на таймере и использовать задержку на счетчике, например из примера предыдущей статьи: Передача параметров из Си в ассемблерную функцию, то она уже будет работать должным образом.
4. Подключение внешнего кварца к HSE генератору тактовой частоты. Регистры CLK_ECKR, CLK_CMSR, CLK_SWR и CLK_SWCR
При подключении внешнего кварца, генератору HSE требуется некоторое время для стабилизации частоты. По умолчанию, это время равно 2048 тактам. Это значение можно менять через параметр Option Bytes – HSECNT.
В связи с этим, существует два варианта переключения на HSE: автоматический и ручной.
Автоматический вариант предполагает минимум действий со стороны программиста. Требуется всего пара команд, чтобы указать новый источник тактового сигнала и дать команду коммутатору на переключение на него.
Далее микроконтроллер все сделает сам. Он включит генератор HSE, дождется его стабилизации, и после автоматически переключится на него.
Пользовательская программа при этом не ждет переключения, она занимается своими делами.
Блок-схема алгоритма представлена на картинке ниже:
Пример программы с реализацией такого алгоритма у меня получился таким:
#include
#include “stm8s103f.h”
#include “stm8s_tim4.h”
#include “stm8s_clk.h” #define CFG_GCR_AL ((uint8_t)0x02)
#define LED 5 extern void delay(void) __interrupt(23);
volatile uint16_t count;
static inline void clk_setup();
static void switch_to_hse_auto(); void delay_ms(uint16_t ms)
{ count = ms; CFG_GCR = CFG_GCR_AL; 2 TIM4_SR = 0x0; TIM4_PSCR = TIM4_PRESCALER_128; 7128
124 TIM4_ARR = 16; TIM4_IER = (uint8_t)TIM4_IT_UPDATE; 1 TIM4_CR1 = TIM4_CR1_CEN; 1 wfi(); TIM4_CR1 = 0x0; } int main(void) { clk_setup(); PB_DDR=(1
Источник: http://www.count-zero.ru/2018/stm8_clock/
Stm8 182
STM8/128-SK/RAIS5 днейПр-во: ST Microelectronics | 5 дней | 7 560 руб. × |
STM8/128-EVAL5 днейПр-во: ST Microelectronics | 5 дней | 11 400 руб. × |
Со склада | 1 190 руб. ×от 3 шт. — 1 090 руб.от 30 шт. — 1 050 руб. | |
Со склада | 930 руб. ×от 3 шт. — 919 руб.от 30 шт. — 893 руб. | |
Со склада | 860 руб. ×от 3 шт. — 782 руб.от 30 шт. — 760 руб. | |
1 день | 160 руб. ×от 10 шт. — 148 руб.от 100 шт. — 147 руб. | |
Со склада | 75 руб. ×от 15 шт. — 65 руб.от 150 шт. — 62 руб. | |
Со склада | 74 руб. ×от 15 шт. — 67 руб.от 150 шт. — 66 руб. | |
Со склада | 75 руб. ×от 15 шт. — 65 руб.от 150 шт. — 62 руб. | |
2-3 недели | 87 руб. ×от 25 шт. — 83 руб.от 50 шт. — 79 руб. | |
Со склада | 3 000 руб. ×от 3 шт. — 2 800 руб.от 30 шт. — 2 750 руб. | |
Со склада | 2 300 руб. ×от 3 шт. — 2 100 руб.от 30 шт. — 2 050 руб. | |
Со склада | 8 000 руб. ×от 3 шт. — 7 950 руб.от 30 шт. — 7 900 руб. | |
Со склада | 10 750 руб. ×от 2 шт. — 10 210 руб.от 8 шт. — 9 904 руб. | |
Со склада | 620 руб. ×от 5 шт. — 570 руб.от 50 шт. — 548 руб. | |
5 дней | 57 руб. ×от 23 шт. — 35 руб.от 46 шт. — 31 руб. | |
STM8405 | 5 дней | 80 руб. ×от 18 шт. — 50 руб.от 36 шт. — 44 руб. |
STM8306 | 5 дней | 46 руб. ×от 30 шт. — 29 руб.от 59 шт. — 25 руб. |
Страницы Ctrl ← предыдущая Ctrl → следующая
Источник: https://www.chipdip.ru/catalog/popular/stm8
Страничка эмбеддера » Обзор stm8
Когда я выбирал контроллер для очередной поделки, я наткнулся на резкий дефицит разного рода AVR’ок. Я начал искать, чем их заменить, и нашел stm8.
stm8 – это относительно новое семейство микроконтроллеров от компании STMicroelectronics. В нем воплощено чуть ли не все, чего можно ожидать от 8 битных чипов. Конечно-же, у каждого контроллера есть свои плюсы и свои минусы.
Плюсы и минусы
Естественно, плюсы и минусы я оцениваю по применимости в моих проектах, для вас они могут отличаться в ту или иную сторону. Я буду сравнивать с AVR, потому, как на них многие уже скушали небольшую собачку.
Плюсы:
-
Цена. Не смотря на мало распространенность, stm8 стоит по три копейки за ведро.
-
Еще одна цена. Отладочные платы и отладчики стоят копейки. Можно забыть про всю ту ораву самопальных программаторов, что расплодились для AVR’ов. Также, можно забыть про программаторы без отладчиков – за минимальные деньги все включено.
-
У stm8 в отличии от AVR нет фьюзов. И это меня очень радует. Теперь вся программа действительно содержится в одном hex файле. Ну согласитесь, фьюзы в AVR– чистейшее зло!
-
Есть очень дешевые контроллеры с 12-битными АЦП и ЦАПами, и это – очень хорошо!
-
Классный отладочный интерфейс. Задумка об отладке по одному проводу у AVR была хороша, но чтобы ее включить, приходилось подключать еще три. В итоге, JTAG был не намного хуже пресловутого debugWire. ST довела идею до логического завершения. Отладка по двум проводам. Супер!
-
Работает от пяти вольт. Не знаю, можно ли это назвать достоинством в нынешнем мире, но олдфагам это точно понравится.
-
Встроенный bootloader. Умеет загружать программы по uart, spi, can, i2c.
-
На халяву дается библиотека драйверов периферии.
Недостатки:
-
Нет контроллеров в маловыводных корпусах (типа so8).
-
Нет контроллеров с USB. ST предлагает пересаживаться на ее кортексы, если нужен USB.
-
Не слишком пока распространены. Соответственно, и доставать сложно, и цены выше, чем могли бы быть.
Семейства
Существует 3 семейства stm8.
-
stm8s – “стандартные” контроллеры общего применения, обычно 10 битная аналоговая периферия, среднее по современным стандартам энергопотребление. Диапазон питания – 2.95 – 5.5в
-
stm8l – “low-power” контроллеры с низким потреблением, 12 битный аналог, улученная электромагнитная совместимость. Диапазон питания – 1.8-3.6в. По сравнению со стандартными контроллерами, тут добавляется небольшая кучка периферии, в частности, DMA.
-
stm8a – “автомобильные” – все сосредоточено на безопасности и CAN’е. Котроллеры выдерживают больше издевательств над ножками, чем обычные, работают при 145 градусах, Диапазон питания – 2.95 – 5.5в
Названия
Без лишних слов:
Структура документации
В принципе, всего кроме этого раздела можно было и не писать. Документация у ST довольно неплохая. Главное знать, что и где искать. (Примеры будут для контроллера, который валяется у меня прямо сейчас на столе — stm8l152c4)
Заходим на страничку интересующего вас контроллера. (вот тут http://www.st.com/mcu/ выбираем нужное семейство и контроллер, к примеру, stm8l152c4).
В отличии от Atmel’a, дядьки из ST поступили умнее, и разбили документацию на несколько частей. В даташите они приводят только отличие конкретного контроллера от всей остальной линейки. В даташите нужно искать электрические параметры, размер памяти, список периферии.
Немного ниже есть reference manual – это документация на всю линейку. Тут описывается переферия и регистры. Вообщем то, что нужно нормальному сишнику для программирования.
Если полистать ниже, то можно наткнуться на Errata sheet. Ошибок много, но серьезных практически нет.
Если ты – сумасшедший ассемблерщик (С), и этого тебе не хватило, то, в разделе Programming Manual, можно найти документ STM8 CPU programming manual. Это — описание самого ядра, набора инструкций, их таймингов, итп.
Библиотека
ST сделала такую штуку, которая называется STM8x Firmware library. Это – суть фрэймворк для микроконтроллеров.
Давайте, к примеру, запустим АЦП
1#include «stm8a_lib.h»
2
3void main(void)
4{
5 ADC_DeInit();
6 enableInterrupts();
7
8 /* Init ADC peripheral */
9 ADC_Init(ADC_CONVERSIONMODE_CONTINUOUS, ADC_CHANNEL_9,
10 ADC_PRESSEL_FCPU_D2, ADC_EXTTRIG_TIM, DISABLE,
11 ADC_ALIGN_RIGHT, ADC_SCHMITTTRIG_CHANNEL9, DISABLE);
12
13 /* Enable EOC interrupt */
14 ADC_ITConfig(ENABLE);
15
16 /*Start Conversion */
17 ADC_StartConversion();
18
19 while(1) { /* wait for interrupts */ }
20}
Красиво, не правда ли? Конечно, скорость работы с использованием такого “фрэймворка” будет ниже, чем без, но, как завещал Кнут – “premature optimization is the root of all evil”. Если будет совсем медленно, функции библиотеки всегда можно подменить своими.
Такая библиотека позволяет не только поднять скорость разработки, но и облегчает миграцию между процессорами.
Документация на библиотеку, хоть и doxygen’овская, но довольно хороша!
Средства отладки
Как я и обещал, тут все очень хорошо. Есть два основных средства
- stm8s-discovery. Стоит 10$ + жадность продавца. Включает в себя полноценный программатор и небольшую отладочную плату. Стоимость деталей программатора в Киеве намного больше 10$, поэтому разнообразные самопальные программаторы сразу отпадают. Я купил себе такую и не жалею. Намного более стоящее приобретение, чем тот-же avr dragon. Кстати! Отладчик построен на контроллере STM32F103C8T6. На отладочной плате разведен JTAG, и, поэтому, ее можно использовать как отладочную для stm32. Прошивка потеряется, но, учитывая, что весь discovery стоит как один STM32F103C8T6, можно на это забить. Зато есть USB, внешние проводки, светодиоды. Вообщем, discovery — мегавещь.
- st-link стоит побольше, чем stm8-discovery, зато программирует все, что выпускает stm, включая stm32. St-link может стать очень хорошей покупкой, если у вас нет arm-программатора.
Компиляторы
- Первое, и главное для меня, IAR выпускает компилятор для stm8. Бесплатный умеет до 8 кбайт или до 30 дней. Ходят слухи, что плохие люди его взламывают. Наверняка, это только слухи
Источник: http://bsvi.ru/obzor-stm8/
Вибрационные(язычковые)частотомеры
Источник: https://infopedia.su/5x9bb3.html
Adblock
detector