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

 
 
> 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
Ответов (1 - 4)
scifi
сообщение Oct 4 2016, 14:51
Сообщение #2


Гуру
******

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



Почитайте еррату. Там сказано, что если в один и тот же регистр записывать повторно без должной задержки, то получится ерунда. Поскольку у них есть привычка каждый бит записывать отдельно, приходится страховаться от этого случая.
У меня всё содержимое регистра записывается одним махом, поэтому такой проблемы нет.
Go to the top of the page
 
+Quote Post
isz
сообщение Oct 4 2016, 14:56
Сообщение #3


Участник
*

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



Хм, эррату почитаю.

Но здесь же нет побитовой записи. Запись в регистр происходит сразу из переменной tempreg1. Затем читает, ждет и опять пишет.
Go to the top of the page
 
+Quote Post
scifi
сообщение Oct 4 2016, 15:02
Сообщение #4


Гуру
******

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



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

Ненужные пляски с бубном.
Go to the top of the page
 
+Quote Post
isz
сообщение Oct 4 2016, 15:05
Сообщение #5


Участник
*

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



Спасибо за ответ. Инфу в эррате нашел.
Go to the top of the page
 
+Quote Post

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

 


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


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