проблемы с получением доступа к EEPROM у чипа i82546 (эзернет)

Ответить

Код подтверждения
Введите код в точности так, как вы его видите. Регистр символов не имеет значения.

BBCode ВКЛЮЧЁН
[img] ВКЛЮЧЁН
[url] ВКЛЮЧЁН
Смайлики ОТКЛЮЧЕНЫ

Обзор темы
   

Развернуть Обзор темы: проблемы с получением доступа к EEPROM у чипа i82546 (эзернет)

проблемы с получением доступа к EEPROM у чипа i82546 (эзернет)

Arisu » 06 июн 2007, 10:51

(у вас тут нету отдельного форума по работе с железом, по этому пишу в АСМ т.к. это вроде ближе. Но если что - переносите)

Мучаю этот нещасный интеловский изернет (82546GB) с его епромом выносным.

Столкнулся с непоняткой: по какой-то причине чип (контроллер интеловский) не даёт разрешение на работу с его епромом. Хотя я всё делаю по инструкции. (интеловский контроллер выступает в роли Master(SPI) )

Вот в даташите написано:

To directly access the eeprom, software should follow these steps:
1. Write a 1b to the EEPROM request bit (EECD.REQ)
2. Read the EEPROM grant bit (EECD.GNT) until it becomes 1b. It remains 0b as long as the hardware is accessing the EEPROM.
3. можете читать и писать теперь

Вот мой код:

(
в регистре EECD:
6 бит это REQ,
7 бит это GNT,
5-4 биты это FWE (доступ на запись)
)

(
функции InDword и OutDword соответственно в порты пишут и читают.
)



Код:
/* ----------------------------------------------------------------- */
void GntEEPROMAcces( DWORD *EECDAddr )
{
DWORD Reg;

/* reset REQ, GNT and FWE */
FreeEEPROMAccess( EECDAddr ); //(тут просто нолики в эти биты записываются для надёжности)

/* 1b to REQ */
Reg = InDword( *EECDAddr );
Reg = Reg | 0x40;
OutDword( Reg, *EECDAddr );

/* waiting 1b from GNT */
while ( 1 ) {
Reg = InDword( *EECDAddr );
if ( Reg & 0x80 ) break;
}

/* 10b to FWE */
Reg = InDword( *EECDAddr );
Reg = Reg & 0xFFFFFFCF;
Reg = Reg & 0x20;
OutDword( Reg, *EECDAddr );

return;
} /* --------------------------------------------------------------- */

Вот и весь урюк в том, что вот вот этой еденицы в GNT я могу ждать хоть до завтрашнего утра.. не ставит он её и всё тут.

ЗЫ
на всякий:
EECD это 32 битный регистр и ввод/вывод у него тоже 32-битный.
ЗЫ2
SPI тут не причём! до него дело ещё не дошло! я пока общаюсь только с Master чипом

Вернуться к началу