====== Differences ====== This shows you the differences between two versions of the page.

Link to this comparison view

Next revision
Previous revision
soc:2009:asdlkf:journal:week3 [2009/06/07 14:56]
asdlkf created
soc:2009:asdlkf:journal:week3 [2009/06/16 21:21] (current)
asdlkf
Line 14: Line 14:
      - "​D-Link System Inc DGE-530T Gigabit Ethernet Adapter (rev 11) (rev 11)"      - "​D-Link System Inc DGE-530T Gigabit Ethernet Adapter (rev 11) (rev 11)"
  
 +- After several hours of '​putski-ing'​ around, I began speaking with Marty again. after about 45 minutes, the two of us were unable to determine why building with DEBUG=pci,​skge was not enabling debugging.
 +
 +June 8: Around 1:00 pm, i received a call from Marty that he had had Michael figure out what was causing the lack of debugging messages; I pci.c was not being included in the built library because none of its functions were being invoked. ​
 +
 +- Added a call to adjust_pci_device() to cause make to actually insert debugging messages; and i was off to the races.
 +
 +- Copied the assignment line of adapter->​regs from mdeck'​s code (the 0x4000 offset line).
 +
 +- inserted debug messages to verify my register addresses were correct
 +
 +- Read the mac address from my dhcp server logs: 00:​01:​6c:​d0:​16:​87
 +- Read the mac address from my skeleton driver : 00:​21:​91:​91:​10:​6d
 +
 +... ... concluded I had read the wrong addresses.
 +
 +Spent about 30 minutes chasing my tail.
 +
 +- Remembered that the nic that was booting and pulling the pxe image from the dhcp/tftp server was NOT the DGE-530T...
 +
 +- Realized i was correctly pulling the mac address already...
 +
 +-June 9
 +
 +-  Performed nothing "​productive",​ but lots of usefull playing. Accessed various registers. Broke my screen a few times by dumping raw register data to the screen as char. 
 +
 +-  Learned how to perform a software reset of the device; got familiar with several important register locations:
 +0x0100-0x0105:​ mac address
 +0x0118: configuration bits
 +0x011b: chip information
 +
 +- I'm not entirely sure what of these are important or what to continue with. More tomorrow
 +
 +June 10
 +
 +I wasn't really sure where to go today; so I ended up playing with IO. 
 +
 +Sample output:
 +
 +gPXE initialising devices...
 +skge_probe
 +
 +June 14: almost finished probe()- about 70% done
 +- loaded the rest of the PCI_ROM statements
 +- moved skge_adapter to skge.h (from skge.c)
 +- converted: yukon_reset,​ genesis_reset,​ genesis_init,​ gm_phy_write
 +
 +- wrote: skge_enable_test_mode
 +
 +- all instances of writeb, writew, writel, and writeq'​s calling statements were corrected
 +
 +- Moved most DBG statements to use DBG2 instead of DBG (such as mac address and other "just checking if this is working"​ DBG statements)
 +
 +- removed some unnessary statements and added constants to replace them
 +
 + - (such as X = a & b & c & d & e ===> X= <​pre-combined magic constant>​)
 +
 +- Completed: skge_initialize
 +
 +- In progress: probe()
 + - todo in probe():
 +
 + - skge_devinit()
 +
 + - register_netdev()
 +
 + - request_irq()
 +
 + - skge_show_addr()
 +
 + - pci_set_drvdata()
 +
 +
 +
 +
 +
 +-- Chris 

QR Code
QR Code soc:2009:asdlkf:journal:week3 (generated for current page)