|
88E1111 + Cyclone 4, не отправляет |
|
|
|
May 16 2016, 17:49
|

фанат Linux'а
    
Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008

|
Есть самодельная плата с Cyclone IV + 88E1111, соединены через GMII/RGMII (разведены все 8 линий, т.е. можно выбрать GMII или RGMII). Что работает: Работает приём (вижу в Signal Tap правильные посылки и байты). Работает copper line loopback - на сетевой карте ПК вижу отправленные пакеты продублированы - это работает платка и 88E1111 возвращает пакеты в целости. Стало быть линия ПК-PHY работает, до ПЛИС данные долетают. А вот какая проблема: не отправляет! Вообще! MAC interface loopback если включить - отправка есть а обратно не прилетает, собственно как и из линии... Кварц стоит на 25 МГц от материнской платы выдернул - чтобы уж точно кварц подходил - ведь в материнке же он работал! Да и у меня вроде работает. Говорят может не отправлять если кварц неподходящей стабильности. Пошел я дальше: сделал Nios 2 процессор в этой ПЛИСине, сделал программно "serial management interface" и выкачал через MDC/MDIO регистры. Они у меня получились такие: Код 00: 0x0000 = 0000_0000_0000_0000 01: 0x796D = 0111_1001_0110_1101 02: 0x0141 = 0000_0001_0100_0001 03: 0x0CC2 = 0000_1100_1100_0010 04: 0x0DE1 = 0000_1101_1110_0001 05: 0xCDE1 = 1100_1101_1110_0001 06: 0x000D = 0000_0000_0000_1101 07: 0x2001 = 0010_0000_0000_0001 08: 0x43D7 = 0100_0011_1101_0111 09: 0x0F00 = 0000_1111_0000_0000 10: 0x7C00 = 0111_1100_0000_0000 11: 0x0000 = 0000_0000_0000_0000 12: 0x0000 = 0000_0000_0000_0000 13: 0x0000 = 0000_0000_0000_0000 14: 0x0000 = 0000_0000_0000_0000 15: 0x3000 = 0011_0000_0000_0000 16: 0x0068 = 0000_0000_0110_1000 17: 0xAC40 = 1010_1100_0100_0000 18: 0x0000 = 0000_0000_0000_0000 19: 0x0000 = 0000_0000_0000_0000 20: 0x0C71 = 0000_1100_0111_0001 <- младшая единичка говорит что передатчик включен (1 = Transmitter Enable) 21: 0x0000 = 0000_0000_0000_0000 22: 0x0000 = 0000_0000_0000_0000 23: 0x0000 = 0000_0000_0000_0000 24: 0x4100 = 0100_0001_0000_0000 25: 0x0000 = 0000_0000_0000_0000 26: 0x000A = 0000_0000_0000_1010 27: 0x808F = 1000_0000_1000_1111 28: 0x0000 = 0000_0000_0000_0000 29: 0x0000 = 0000_0000_0000_0000 30: 0x0000 = 0000_0000_0000_0000 31: 0x0000 = 0000_0000_0000_0000 Код int main() { int stage = 0; while(true) { if(stage == 0) { printf("!!!\n\r", stage); smi_write(0, 0, 0x0040); smi_write(0, 20, 0x0C71); unsigned char r0 = smi_read(0, 0); smi_write(0, 0, r0 & (1<<15)); }
for(int reg = 0; reg < 32; reg++) { unsigned short data = smi_read(0, reg); printf("%02d: 0x%04X = ", reg, data); print_bin2(data, 16); printf("\n\r"); } printf("----- %d\n\r", stage); for(int i = 0; i < (ALT_CPU_CPU_FREQ / 5); i++);
stage++; if(stage > 10) stage = 0; } return 0; } Тут много кто с этим PHY работает (88E1111), какие вы регистры настраиваете и какими значениями? Меня интересует режим только 1 гигабит, без возможности 10/100, по меди 4 пары.
Сообщение отредактировал AVR - May 16 2016, 18:22
--------------------
|
|
|
|
|
 |
Ответов
|
May 30 2016, 15:42
|
Группа: Участник
Сообщений: 6
Регистрация: 2-11-05
Пользователь №: 10 411

|
Несколько лет назад подробно разбирался со связкой 88E1111+CycloneIV, на этом форуме всё уже было с детальными пояснениями. Большое спасибо форумчанам, особенно vadimuzzz! Если есть уверенность, что разводка+подключение ПЛИС и марвела сделаны правильно, то дело в программировании регистров. У меня функция инициализации выглядела так (там кое-что лишнее, применительно к моей конкретной реализации + отладочная информация, но разобраться можно ): alt_u32 t2=0; int status=0;
IPADDR2[0]=192; IPADDR2[1]=168; IPADDR2[2]=1; IPADDR2[3]=247;
GATE2[0]=192; GATE2[1]=168; GATE2[2]=1; GATE2[3]=254;
MASK2[0]=255; MASK2[1]=255; MASK2[2]=255; MASK2[3]=0;
MACADDR2[0]=0x00; MACADDR2[1]=0x07; MACADDR2[2]=0xab; MACADDR2[3]=0xf0; MACADDR2[4]=0x0d; MACADDR2[5]=0xb2;
//Чтение регистра конфигурации TSE - регистр 0 - номер версии IP TSE (32 бита) t2 = IORD_ALTERA_TSEMAC_CMD_CONFIG(TSE2_BASE); #ifdef DEBUG alt_printf("TSE Command Reg : %x\n",t2); #endif
alt_u32 t, r; for (t=0;t<33;t++) { IOWR_ALTERA_TSEMAC_MDIO_ADDR0(TSE2_BASE, t); Delay(0xFFFF); //alt_printf("Probing PHY at address %x ...\n", t); r = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE, 0, ALTERA_TSEMAC_PHY_ADDR_PHY_ID1); if( r== 0x141 ) { #ifdef DEBUG alt_printf("Found Marvell 88E1111, PHY=%x\n", t); #endif break; } }
t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x1B);//Extended PHY Specific Status Register #ifdef DEBUG alt_printf("Reg 27 : %x\n",t2); #endif t2 &= 0xFFF0;
IOWR_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x1B,t2|0xf); //f - GMII to Copper; 7 - GMII to fiber; e - GMII to SGMII(=fiber);
t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x14);//Extended PHY Specific Control Register #ifdef DEBUG alt_printf("Reg 20 : %x\n",t2); #endif
IOWR_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x14,t2|0x83);//Add Delay to RX_CLK for RXD Outputs; Add Delay to GTX_CLK for TXD Inputs
t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,26);// #ifdef DEBUG alt_printf("Reg 26 : %x\n",t2); #endif
t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0); #ifdef DEBUG alt_printf("Reg 0 : %x\n",t2); #endif
IOWR_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,ALTERA_TSEMAC_PHY_ADDR_CONTROL,t2|PCS_CTL_sw _reset);//Previous Operations Require SW Reset
do { Delay(0xFFFF); t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,ALTERA_TSEMAC_PHY_ADDR_STATUS); //alt_printf("Reg 1 : %x\n",t2);
Delay(0xFFFF); Delay(0xFFFF); Delay(0xFFFF); } while((t2&(alt_u32)0x0004)==0);//wait for link-up
// Get the Rx and Tx SGDMA addresses sgdma_tx_dev = alt_avalon_sgdma_open(SGDMA2_TX_NAME); if(!sgdma_tx_dev) { #ifdef DEBUG alt_printf("[triple_speed_ethernet_init] Error opening RX SGDMA\n"); #endif }
sgdma_rx_dev = alt_avalon_sgdma_open(SGDMA2_RX_NAME); if(!sgdma_rx_dev) { #ifdef DEBUG alt_printf("[triple_speed_ethernet_init] Error opening TX SGDMA\n"); #endif }
IOWR_ALTERA_AVALON_SGDMA_CONTROL(SGDMA2_RX_BASE,ALTERA_AVALON_SGDMA_CONTROL_SOFT WARERESET_MSK); IOWR_ALTERA_AVALON_SGDMA_CONTROL(SGDMA2_RX_BASE, 0x0);
// reset the mac IOWR_ALTERA_TSEMAC_CMD_CONFIG(TSE2_BASE , ALTERA_TSEMAC_CMD_SW_RESET_MSK | ALTERA_TSEMAC_CMD_TX_ENA_MSK | ALTERA_TSEMAC_CMD_RX_ENA_MSK | ALTERA_TSEMAC_CMD_PROMIS_EN_MSK); while(IORD_ALTERA_TSEMAC_CMD_CONFIG(TSE2_BASE) & ALTERA_TSEMAC_CMD_SW_RESET_MSK) { }
// Initialize MAC registers IOWR_ALTERA_TSEMAC_FRM_LENGTH(TSE2_BASE, ALTERA_TSE_MAX_FRAME_LENGTH); IOWR_ALTERA_TSEMAC_RX_ALMOST_EMPTY(TSE2_BASE, 8); IOWR_ALTERA_TSEMAC_RX_ALMOST_FULL(TSE2_BASE, 8); IOWR_ALTERA_TSEMAC_TX_ALMOST_EMPTY(TSE2_BASE, 8); IOWR_ALTERA_TSEMAC_TX_ALMOST_FULL(TSE2_BASE, 3); IOWR_ALTERA_TSEMAC_TX_SECTION_FULL(TSE2_BASE, 0); IOWR_ALTERA_TSEMAC_RX_SECTION_FULL(TSE2_BASE, 0); IOWR_ALTERA_TSEMAC_TX_CMD_STAT(TSE2_BASE,0); IOWR_ALTERA_TSEMAC_RX_CMD_STAT(TSE2_BASE,0);
IOWR_ALTERA_TSEMAC_MAC_0(TSE2_BASE,((int)(MACADDR2[0]) | (int)(MACADDR2[1] << 8) | (int)(MACADDR2[2] << 16) | (int)(MACADDR2[3] << 24))); IOWR_ALTERA_TSEMAC_MAC_1(TSE2_BASE,(((int)(MACADDR2[4]) | (int)(MACADDR2[5] << 8)) & 0xFFFF));
IOWR_ALTERA_TSEMAC_CMD_CONFIG(TSE2_BASE, ALTERA_TSEMAC_CMD_TX_ENA_MSK | ALTERA_TSEMAC_CMD_RX_ENA_MSK | ALTERA_TSEMAC_CMD_TX_ADDR_INS_MSK | ALTERA_TSEMAC_CMD_RX_ERR_DISC_MSK | ALTERA_TSEMAC_CMD_PAD_EN_MSK );
alt_avalon_sgdma_register_callback(sgdma_rx_dev,(alt_avalon_sgdma_callback)&tse_sgdmaRx_isr,(alt_u16)ALTERA_TSE_SGDMA_INTR_MASK,sgdma_rx_dev);
//объявляет буфер некешируемой областью памяти (устанавливает в 1 31-й бит адреса блока) alt_u32 *up; //uncached_packet_payload; up = (void *)alt_remap_uncached ( (void *)pkt, 4);
//подготовка дескрипторов к проведению очередной операции alt_avalon_sgdma_construct_stream_to_mem_desc( (alt_sgdma_descriptor *) &desc[ALTERA_TSE_FIRST_RX_SGDMA_DESC_OFST], // descriptor I want to work with (alt_sgdma_descriptor *) &desc[ALTERA_TSE_SECOND_RX_SGDMA_DESC_OFST], // pointer to "next" up, // starting write_address 0, // read until EOP - переносить пакет до конца данных 0);
while ( (IORD_ALTERA_AVALON_SGDMA_STATUS(SGDMA2_RX_BASE) & ALTERA_AVALON_SGDMA_STATUS_BUSY_MSK) ) {}
//начало асинхронной транзакции t2=alt_avalon_sgdma_do_async_transfer(sgdma_rx_dev, &desc[ALTERA_TSE_FIRST_RX_SGDMA_DESC_OFST]);
#ifdef DEBUG t2 = IORD_ALTERA_TSEMAC_MAC_0(TSE2_BASE); alt_printf("MAC 0 : %x\n",t2); t2 = IORD_ALTERA_TSEMAC_MAC_1(TSE2_BASE); alt_printf("MAC 1 : %x\n",t2); t2 = IORD_ALTERA_TSEMAC_CMD_CONFIG(TSE2_BASE); alt_printf("TSE Command Reg : %x\n",t2); #endif
|
|
|
|
|
Jun 4 2016, 20:19
|

фанат Linux'а
    
Группа: Свой
Сообщений: 1 353
Регистрация: 23-10-05
Из: SPB.RU
Пользователь №: 10 008

|
Цитата(abarsky111 @ May 30 2016, 18:42)  Несколько лет назад подробно разбирался со связкой 88E1111+CycloneIV, на этом форуме всё уже было с детальными пояснениями. Большое спасибо форумчанам, особенно vadimuzzz! Если есть уверенность, что разводка+подключение ПЛИС и марвела сделаны правильно, то дело в программировании регистров. У меня функция инициализации выглядела так (там кое-что лишнее, применительно к моей конкретной реализации + отладочная информация, но разобраться можно ): Да, схему передирали с пары референс-дизайнов, подключили всё что даже к гигабиту не относится (TX_CLK), вижу что при подключении к 100-мегабитному интерфейсу у меня и клоки ровно в 5 раз замедляются (125->25) - всё как бы окей. Цитата(abarsky111 @ May 30 2016, 18:42)  t2 = IORD_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x14);//Extended PHY Specific Control Register IOWR_ALTERA_TSEMAC_MDIO(TSE2_BASE,0,0x14,t2|0x83);//Add Delay to RX_CLK for RXD Outputs; Add Delay to GTX_CLK for TXD Inputs А что значат эти биты? RGMII timing control? И включение передатчика? Где мне посмотреть что у меня выбран режим именно GMII/copper?Читал описание регистра 27.3:0 (HWCFG_MODE) - его я задал конфигурационными пинами и младшие 4 бита равны 1111, что соответствует именно GMII to Copper. 27: 0x808F = 1000_0000_1000_1111
--------------------
|
|
|
|
Сообщений в этой теме
AVR 88E1111 + Cyclone 4 May 16 2016, 17:49 _Anatoliy Цитата(AVR @ May 16 2016, 20:49)
У меня ... May 16 2016, 18:32 AVR Цитата(_Anatoliy @ May 16 2016, 21:32) У ... May 16 2016, 18:41  Jury093 Цитата(AVR @ May 16 2016, 21:41) Он разве... May 16 2016, 20:53  _Anatoliy Цитата(AVR @ May 16 2016, 21:41) Он разве... May 17 2016, 04:28 doom13 Цитата(AVR @ May 16 2016, 20:49) Есть сам... May 16 2016, 19:31 AVR Цитата(doom13 @ May 16 2016, 22:31) А как... May 16 2016, 19:34 doom13 А с ресетом всё в порядке? Если память не изменяет... May 16 2016, 19:58 AVR Цитата(doom13 @ May 16 2016, 22:58) А с р... May 16 2016, 19:59  doom13 Цитата(AVR @ May 16 2016, 22:59) Стоит ми... May 16 2016, 20:14   AVR Цитата(doom13 @ May 16 2016, 23:14) Согла... May 28 2016, 20:24    krux Цитата(AVR @ May 28 2016, 23:24) Пока не ... May 29 2016, 13:57     AVR Цитата(krux @ May 29 2016, 16:57) ему над... May 29 2016, 15:13 dxp У меня была похожая ситуация. Loopback через линию... May 17 2016, 06:27 _Anatoliy А по ходу вопрос чем вызвана любовь к многоножкам?... May 17 2016, 09:08  AVR Цитата(_Anatoliy @ May 17 2016, 12:08) А ... May 17 2016, 09:59  doom13 Цитата(AVR @ Jun 4 2016, 23:19) А что зна... Jun 6 2016, 07:00   AVR Цитата(doom13 @ Jun 6 2016, 10:00) RGMII ... Jun 6 2016, 07:20 Wic Извините за глупый вопрос. А пробовали проверять н... Jun 6 2016, 08:27 AVR Цитата(Wic @ Jun 6 2016, 11:27) Извините ... Jun 6 2016, 08:40  abarsky111 Цитата(AVR @ Jun 6 2016, 11:40) Поэтому с... Jun 6 2016, 13:17   AVR Цитата(abarsky111 @ Jun 6 2016, 16:17) А ... Jun 6 2016, 13:30    abarsky111 Цитата(AVR @ Jun 6 2016, 16:30) Я не испо... Jun 6 2016, 14:37     AVR Цитата(abarsky111 @ Jun 6 2016, 17:37) Уж... Jun 6 2016, 20:44 Wic AVR, надеюсь самописные модули были проверены на д... Jun 7 2016, 09:21 AVR Цитата(Wic @ Jun 7 2016, 12:21) AVR, наде... Jun 7 2016, 10:06 krux я некоторое время назад уже выкладывал на форум св... Jun 7 2016, 09:53
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0
|
|
|