|
|
  |
stm32f429 Ethernet не запускается |
|
|
|
Feb 20 2016, 14:59
|

Профессионал
    
Группа: Свой
Сообщений: 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] - для короткого!
|
|
|
|
|
Feb 20 2016, 20:57
|
Участник

Группа: Участник
Сообщений: 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..... но это не суть важно
|
|
|
|
|
Feb 21 2016, 16:48
|

Профессионал
    
Группа: Свой
Сообщений: 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 МГц?
|
|
|
|
|
Feb 21 2016, 19:49
|
Гуру
     
Группа: Свой
Сообщений: 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 МГц - вот это я понимаю.
|
|
|
|
|
Feb 24 2016, 08:27
|
Гуру
     
Группа: Свой
Сообщений: 2 712
Регистрация: 28-11-05
Из: Беларусь, Витебск, Строителей 18-4-220
Пользователь №: 11 521

|
Я брал вот такой вот вариант http://starterkit.ru/html/index.php?name=s...view&id=128. Правда примеры там написаны на "отвали", но мне это и не надо. У меня своих наработок уже более чем достаточно. Аппаратно, пока, у меня к ним претензий не было. Есть ещё одна проблема, что они часто перерабатывают, например детали меняют без ведома. (Это если их модули закладывать в изделия серийные) Были случаи, когда что-то не устанавливается мелкое. Короче единичное производство. Но меня устраивает. Или самому плату разводить, штучно комплектуху заказывать и ждать 2 месяца. Или платку взять готовую. Ценник гуманный.
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|