реклама на сайте
подробности

 
 
> STM32F4, Запись в регисты Ethernet модуля
isz
сообщение Oct 4 2016, 14:24
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 16
Регистрация: 2-10-09
Из: Екатеринбург
Пользователь №: 52 693



Добрый день.
В библиотеке 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;


Для чего это сделано и как работает?
Я догадываюсь что для пересечения клоковых доменов, но не совсем понимаю почему именно так.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
scifi
сообщение Oct 4 2016, 14:51
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Почитайте еррату. Там сказано, что если в один и тот же регистр записывать повторно без должной задержки, то получится ерунда. Поскольку у них есть привычка каждый бит записывать отдельно, приходится страховаться от этого случая.
У меня всё содержимое регистра записывается одним махом, поэтому такой проблемы нет.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 28th July 2025 - 18:33
Рейтинг@Mail.ru


Страница сгенерированна за 0.01364 секунд с 7
ELECTRONIX ©2004-2016