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

 
 
 
Reply to this topicStart new topic
> stm32f429 Ethernet не запускается
juvf
сообщение Feb 20 2016, 14:59
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



Имеется борда stm32f4 disco на процессоре stm32f429. Прикрутил к ней phy на LAN8710. Качнул с st примеры.
Запускаю.... виснет на ожидании сброса ETH->DMABMR_SR.

сначало инициализирую ноги
CODE
void ETH_GPIO_Config(void)
{
volatile uint32_t i;
GPIO_InitTypeDef GPIO_InitStructure;

/* Enable GPIOs clocks */
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA | RCC_AHB1Periph_GPIOB
| RCC_AHB1Periph_GPIOC, ENABLE);

/* Enable SYSCFG clock */
RCC_APB2PeriphClockCmd(RCC_APB2Periph_SYSCFG, ENABLE);

/* MII/RMII Media interface selection --------------------------------------*/
SYSCFG_ETH_MediaInterfaceConfig(SYSCFG_ETH_MediaInterface_RMII);


/* Ethernet pins configuration ************************************************/
/*
ETH_MDIO --------------> PA2
ETH_MDC ---------------> PC1

ETH_RMII_REF_CLK-------> PA1

ETH_RMII_CRS_DV -------> PA7
ETH_MII_RX_ER -------> PB10
ETH_RMII_RXD0 -------> PC4
ETH_RMII_RXD1 -------> PC5
ETH_RMII_TX_EN -------> PB11
ETH_RMII_TXD0 -------> PB12
ETH_RMII_TXD1 -------> PB13

ETH_RST_PIN -------> PE2
*/

/* Configure PA1,PA2 and PA7 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_2 | GPIO_Pin_7;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOA, &GPIO_InitStructure);
GPIO_PinAFConfig(GPIOA, GPIO_PinSource1, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOA, GPIO_PinSource2, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOA, GPIO_PinSource7, GPIO_AF_ETH);

/* Configure PB10,PB11,PB12 and PB13 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10 | GPIO_Pin_11 | GPIO_Pin_12 | GPIO_Pin_13;
GPIO_Init(GPIOB, &GPIO_InitStructure);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource11, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource12, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOB, GPIO_PinSource13, GPIO_AF_ETH);

/* Configure PC1, PC4 and PC5 */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1 | GPIO_Pin_4 | GPIO_Pin_5;
GPIO_Init(GPIOC, &GPIO_InitStructure);
GPIO_PinAFConfig(GPIOC, GPIO_PinSource1, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOC, GPIO_PinSource4, GPIO_AF_ETH);
GPIO_PinAFConfig(GPIOC, GPIO_PinSource5, GPIO_AF_ETH);

/* Configure the PHY RST pin */
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOE, &GPIO_InitStructure);

GPIO_ResetBits(GPIOE, GPIO_Pin_2);
for (i = 0; i < 20000; i++);
GPIO_SetBits(GPIOE, GPIO_Pin_2);
for (i = 0; i < 20000; i++);
}


потом включаю клок на ehternet
Код
/* Enable ETHERNET clock  */
  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_ETH_MAC | RCC_AHB1Periph_ETH_MAC_Tx |
                        RCC_AHB1Periph_ETH_MAC_Rx, ENABLE);
после этой команды бит ETH->DMABMR_SR встаёт в 1 и стоит вечно. По идее он в 1 только во время сброса контроллера ethernet. далее
Код
  /* Reset ETHERNET on AHB Bus */
  ETH_DeInit();

  /* Software reset */
  ETH_SoftwareReset();

  /* Wait for software reset */
  while (ETH_GetSoftwareResetStatus() == SET);
и зависаю на while (ETH_GetSoftwareResetStatus() == SET);, тут ожидание, когда ETH->DMABMR_SR станет = 0. На физике есть кварц 25 МГц и есть клокирование, т.е. генератор запускается, но до обмена с физикой по MDIO и MDC не доходит. Я думаю формирователь физ. уровней не причем. Где-то во внутрях стм что-то не так. А что - не пойму.

Сообщение отредактировал IgorKossak - Feb 20 2016, 17:00
Причина редактирования: [codeebox] для длинного кода, [code] - для короткого!
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 20 2016, 15:06
Сообщение #2


Гуру
******

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



Цитата(juvf @ Feb 20 2016, 17:59) *
Запускаю.... виснет на ожидании сброса ETH->DMABMR_SR.

У меня такое было, когда тактирующий сигнал от PHY не приходил на вход ETH_RMII_REF_CLK.
Go to the top of the page
 
+Quote Post
romas2010
сообщение Feb 20 2016, 20:57
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 63
Регистрация: 25-11-11
Пользователь №: 68 515



Цитата(juvf @ Feb 20 2016, 17:59) *
Имеется борда stm32f4 disco на процессоре stm32f429. Прикрутил к ней phy на LAN8710. Качнул с st примеры.
Запускаю.... виснет на ожидании сброса ETH->DMABMR_SR.


скачайте мой проект, указанный вот по этой ссылке http://electronix.ru/forum/index.php?act=a...st&id=97074 в ветке http://electronix.ru/forum/index.php?showtopic=131337

Там файп drivers/stm32f429/ethmac.c
Попробуйте еще аппаратно сбрость бит EMAC_RST в регистре AHB1RSTR

библиотека самописная,к примерам от st никак вообще не соотносится. Физика-dp8384..... но это не суть важно
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 21 2016, 10:20
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



Цитата(scifi @ Feb 20 2016, 20:06) *
У меня такое было, когда тактирующий сигнал от PHY не приходил на вход ETH_RMII_REF_CLK.

У меня под рукой был LAN8710, на нём и сделал. у LAN8720 есть нога NINT/REFCLKO, которая подключена к процессорной ноге ETH_RMII_REF_CLK.
У LAN8710 нет выхода REFCLKO. Буду думать, как решить проблему.

Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 21 2016, 13:41
Сообщение #5


Гуру
******

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



Цитата(juvf @ Feb 21 2016, 13:20) *
У LAN8710 нет выхода REFCLKO. Буду думать, как решить проблему.

Ну да, нужно сформировать 50 МГц и завести их и на PHY, и на МК. Можно посмотреть на PLL внутри МК и выход MCO.
У меня KSZ8081RNA, он принимает 25 МГц (вывел из МК через MCO) и выдаёт 50 МГц, которые идут в МК.
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 21 2016, 16:48
Сообщение #6


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



Цитата
Ну да, нужно сформировать 50 МГц и завести их и на PHY, и на МК. Можно посмотреть на PLL внутри МК и выход MCO.
У меня KSZ8081RNA, он принимает 25 МГц (вывел из МК через MCO) и выдаёт 50 МГц, которые идут в МК.


У меня так не прокатит..... во первых мой phy принимает только 25МГц. Хочу сделать так: раскачать в МК плл-ем 100МГц и вывести через MCO1 и MCO2. На МСО1 установить делитель 2, на МСО делитель 4. Получу 25 и 50 МГц. 50 - пробросить обратно в МК на на REF_CLK, 25 - пробросить на PHY.

По даташиту на МК для режима RMII нужен внешний генератор 50 МГц который подключается и к МК и к PHY. Но мой PHY не переварит 50, ему нужно ТОЛЬКО 25. Вопрос: должны ли частоты 25 МГц на phy и 50 МГц на МК быть синхронны? Могу я на PHY повесить отдельный кварц 25МГц, а на МК подать 50МГц, независимую (асинхронную) от 25 МГц?
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 21 2016, 17:41
Сообщение #7


Гуру
******

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



Цитата(juvf @ Feb 21 2016, 19:48) *
По даташиту на МК для режима RMII нужен внешний генератор 50 МГц который подключается и к МК и к PHY. Но мой PHY не переварит 50, ему нужно ТОЛЬКО 25.

Чувствуете противоречие между первым и вторым предложением? Я тоже. Точный PHY part number - в студию! Ну и, чтобы два раза не вставать, речь идёт о RMII, верно?
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 21 2016, 19:23
Сообщение #8


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



Парт намбэ phy - LAN8710.
Да, речь идет о rmii
Go to the top of the page
 
+Quote Post
scifi
сообщение Feb 21 2016, 19:49
Сообщение #9


Гуру
******

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



Цитата(juvf @ Feb 21 2016, 22:23) *
Парт намбэ phy - LAN8710.
Да, речь идет о rmii

Я уточнял номер модели, потому что у того же KSZ8081 буковки в конце сильно влияют. Как я погляжу, у LAN8710 такого нет - там зашифрован температурный диапазон и отгрузка катушкой.

Цитата(juvf @ Feb 21 2016, 19:48) *
У меня так не прокатит..... во первых мой phy принимает только 25МГц.

Ну вот смотрю я в этот даташит и не могу понять. Тактируется он от 25 МГц, в то же время 50 МГц не выдаёт. Так жить нельзя - работать не будет. Может быть, это только про MII? Пишут про вариант, когда тактируется от внешних 50 МГц - вот это я понимаю.
Go to the top of the page
 
+Quote Post
Corvus
сообщение Feb 21 2016, 20:22
Сообщение #10


Знающий
****

Группа: Свой
Сообщений: 771
Регистрация: 24-04-08
Из: Зеленоград
Пользователь №: 37 056



Да, даташит чудной немного. Для RMII PHY должен тактироваться от 50 МГц. Вот в этом документе подробнее расписано:
http://ww1.microchip.com/downloads/en/Devi...20Checklist.pdf (стр. 9)
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 24 2016, 04:04
Сообщение #11


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



квест продолжается. Нога у процессора с функцией ETH_RMII_REF_CLK на PA1. Но в ките stm32f429i-dicko на PA1 заведено прерывание INT1 от акселерометра L3GD20. Акселерометр постоянно держит PA1 в нуле. Я подал 50 МГц на РА1 и клоки оказались засаженны. см картинку. МАС на процессоре не запустился. ETH->DMABMR_SR постоянно в 1. Хоть выпаивай акселерометр. Не понятно как на этой борде запустить ethernet? Может как-то программно акселерометр можно отключить?
Эскизы прикрепленных изображений
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
SasaVitebsk
сообщение Feb 24 2016, 06:12
Сообщение #12


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



Цитата(juvf @ Feb 24 2016, 07:04) *
квест продолжается. Нога у процессора с функцией ETH_RMII_REF_CLK на PA1. Но в ките stm32f429i-dicko на PA1 заведено прерывание INT1 от акселерометра L3GD20. Акселерометр постоянно держит PA1 в нуле. Я подал 50 МГц на РА1 и клоки оказались засаженны. см картинку. МАС на процессоре не запустился. ETH->DMABMR_SR постоянно в 1. Хоть выпаивай акселерометр. Не понятно как на этой борде запустить ethernet? Может как-то программно акселерометр можно отключить?

Удобная борда от производителя, исходя из Вашего описания.
У меня что-то сомнения, что они так накосячили. А что примеров к ней не поставляется? Я что то не пойму. Ну не могли же они от балды развести плату, поставить на неё phy и никак не проверить! Но это же нонсенс для производителя чипов, к тому же.
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 24 2016, 07:53
Сообщение #13


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



разобрался.... есть борда stm32f4 disco на 429-ом, а есть на 407. в борде с 429 все ноги от ETH заняты переферией (акселерометр, усб). А на 407 все ноги от eth выведены на колодку IDC и больше ни чем не задействованы. И примеры на ст именно для 407 (stm32f4x7_eth_bsp.c). Так то этот код для 429 тоже подходит, но вот аппаратно дискавери 429 не подходит. буду перебираться на другую борду или соберу макетку на проце с модулем eth.
Go to the top of the page
 
+Quote Post
SasaVitebsk
сообщение Feb 24 2016, 08:27
Сообщение #14


Гуру
******

Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521



Я брал вот такой вот вариант http://starterkit.ru/html/index.php?name=s...view&id=128.
Правда примеры там написаны на "отвали", но мне это и не надо. У меня своих наработок уже более чем достаточно. Аппаратно, пока, у меня к ним претензий не было.
Есть ещё одна проблема, что они часто перерабатывают, например детали меняют без ведома. (Это если их модули закладывать в изделия серийные) Были случаи, когда что-то не устанавливается мелкое.
Короче единичное производство. Но меня устраивает. Или самому плату разводить, штучно комплектуху заказывать и ждать 2 месяца. Или платку взять готовую. Ценник гуманный.
Go to the top of the page
 
+Quote Post
juvf
сообщение Feb 24 2016, 08:31
Сообщение #15


Профессионал
*****

Группа: Свой
Сообщений: 1 261
Регистрация: 14-05-09
Из: Челябинск
Пользователь №: 49 045



Цитата(SasaVitebsk @ Feb 24 2016, 13:27) *
Я брал вот такой вот вариант http://starterkit.ru/html/index.php?name=s...view&id=128.
Спс, хорошая борда, лучше чем дискавери + плата расширения, и дешевле. На будущее учту. Сейчас же леплю из того, что под рукой есть.
Go to the top of the page
 
+Quote Post

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

 


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


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