asc2000 Опубликовано 22 января, 2016 Поделиться Опубликовано 22 января, 2016 Уважаемые форумчане, помогите разобраться. Как известно, в ATtiny регистр CLKPR задает коэф-т деления и определяет системную тактовую частоту. Если фьюз CKDIV8 запрограммирован, то четыре младших разряда регистра CLKPR равны 0011, а если не запрограммирован, то они равны 0000. Т.к. регистр CLKPR относится к энергозависимой памяти (SRAM), то при отключении питания его содержимое должно сбрасываться в начальное состояние, которое определяется значением фьюза CKDIV8 и которое не зависит от той программы, которая записана в Flash-память м-контроллера. Проблема собственно в следующем: есть ATtiny13A, работающая от внутреннего генератора 9,6 МГц. Фьюз CKDIV8 запрограммирован и его состояние я не менял. Сначала (со старой программой) ATtiny13A прекрасно программировалась и читалась программатором. Затем я записал новую программу, в которой применил коэф-т деления генератора на 256 (младшие разряды регистра CLKPR равны 1000). Программа записалась и правильно работала, но контроллер перестал читаться и я не мог его перепрограммировать. Когда же я уменьшил частоту SCK программатора, то м-сх опять стала читаться и программироваться. После этого я снова записал старую программу, в которой не было деления частоты генератора на 256, и снова м-сх стала читаться программатором с высокой частотой SCK. Вопрос: почему ? 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Геннадий Опубликовано 22 января, 2016 Поделиться Опубликовано 22 января, 2016 Потому, что Вы не читали даташит на МК. Можете почитать Евстифеева, если с англицким у Вас напряг. Там на русском описаны условия отношений тактовых частот SPI и самого МК. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
20% скидка на весь каталог электронных компонентов в ТМ Электроникс!Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!Перейти на страницу акции Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849
asc2000 Опубликовано 22 января, 2016 Автор Поделиться Опубликовано 22 января, 2016 Я прочитал (в оригинале) даташиты на многие ATtiny и ATmega, но не нашел ответ на свой вопрос. Буду очень признателен, если Вы приведете конкретные цитаты из даташита. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Выбираем схему BMS для заряда литий-железофосфатных (LiFePO4) аккумуляторовОбязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ очень важен контроль процесса заряда и разряда для избегания воздействия внешнего зарядного напряжения после достижения 100% заряда. Инженеры КОМПЭЛ подготовили список таких решений от разных производителей. Подробнее>>Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161
Геннадий Опубликовано 22 января, 2016 Поделиться Опубликовано 22 января, 2016 Ловите. Это из даташита Attiny2313 (стр. 172): 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
asc2000 Опубликовано 22 января, 2016 Автор Поделиться Опубликовано 22 января, 2016 Да это я знаю. Вы просто не поняли моего вопроса. Я не менял CKSEL-фьюзов, а программатор все равно сначала перестал программировать при данной частоте SCK, а потом снова начал программировать. Такое впечатление, что при программировании как-то влияет регистр CLKPR, но в даташите об этом ни слова. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Геннадий Опубликовано 22 января, 2016 Поделиться Опубликовано 22 января, 2016 CLKPR является регистром предделителя тактовой частоты. Фьюз CKDIV8 меняет именно его конфигурацию. Поэтому не важно каким способом Вы изменили "такты", результат один. Последствия - тоже. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
asc2000 Опубликовано 23 января, 2016 Автор Поделиться Опубликовано 23 января, 2016 В начале я писал, что не менял состояние фьюза CKDIV8. А что Вы имели ввиду здесь? : Поэтому не важно каким способом Вы изменили "такты", результат один. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Геннадий Опубликовано 24 января, 2016 Поделиться Опубликовано 24 января, 2016 Фьюз CKDIV8 вносит изменения в регистр CLKPR. Если Вы его не изменяли, но внесли изменения в CLKPR программно, то и значение, вносимое CKDIV8, будет заменено. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
asc2000 Опубликовано 24 января, 2016 Автор Поделиться Опубликовано 24 января, 2016 Если Вы его не изменяли, но внесли изменения в CLKPR программно, то и значение, вносимое CKDIV8, будет заменено. Но ведь мы сейчас говорим про режим программирования, когда подается низкий уровень RESET. А в даташите ATtiny13 сказано: During reset, all I/O Registers are set to their initial values... А начальное (initial) значение CLKPR определяется состоянием фьюза CKDIV8 и не зависит от того, изменял я или не изменял CLKPR программно. 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Геннадий Опубликовано 24 января, 2016 Поделиться Опубликовано 24 января, 2016 (изменено) Да. Следующим будет вопрос: " Тогда почему после сигнала Reset, используемого в программировании, CLKPR не принимает начального значения и МК не становится видимым программатором"? ХЗ. Не отвечу. Много разных факторов, которые надо анализировать. Скорость SPI, на которой перестает видится МК. Тайминги, применяемые Вашим программатором, для ввода МК в режим программирования. И тд., и тп. Зависимость просматривается, а почему - ответа нет. Изменено 24 января, 2016 пользователем Геннадий 0 Ссылка на комментарий Поделиться на другие сайты Поделиться
Рекомендуемые сообщения
Присоединяйтесь к обсуждению
Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.