Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: STM32F4
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
isz
Добрый день.
В библиотеке HAL запись в регистры Ethernet происходит следующим образом
Код
  /* Write to ETHERNET MACCR */
    (heth->Instance)->MACCR = (uint32_t)tmpreg1;
    
    /* Wait until the write operation will be taken into account :
    at least four TX_CLK/RX_CLK clock cycles */
    tmpreg1 = (heth->Instance)->MACCR;
    HAL_Delay(ETH_REG_WRITE_DELAY);
    (heth->Instance)->MACCR = tmpreg1;


Для чего это сделано и как работает?
Я догадываюсь что для пересечения клоковых доменов, но не совсем понимаю почему именно так.
scifi
Почитайте еррату. Там сказано, что если в один и тот же регистр записывать повторно без должной задержки, то получится ерунда. Поскольку у них есть привычка каждый бит записывать отдельно, приходится страховаться от этого случая.
У меня всё содержимое регистра записывается одним махом, поэтому такой проблемы нет.
isz
Хм, эррату почитаю.

Но здесь же нет побитовой записи. Запись в регистр происходит сразу из переменной tempreg1. Затем читает, ждет и опять пишет.
scifi
Цитата(isz @ Oct 4 2016, 17:56) *
Но здесь же нет побитовой записи. Запись в регистр происходит сразу из переменной tempreg1. Затем читает, ждет и опять пишет.

Ненужные пляски с бубном.
isz
Спасибо за ответ. Инфу в эррате нашел.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.