====== 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:week6 [2009/06/29 16:47]
asdlkf created
soc:2009:asdlkf:journal:week6 [2009/07/07 17:25] (current)
asdlkf
Line 1: Line 1:
-June 29:+June 29 6:45 PM:
  
 Current status: Up until now, I have completed most of the data structure definitions,​ skge_probe(),​ and skge_open(). I am obviously quite behind compared to my project plan, but that is not something I can easily resolve; However; It does look like I will have time still left over at the end of writing the skge driver for some other prospects in this task. Possibly tg3? Current status: Up until now, I have completed most of the data structure definitions,​ skge_probe(),​ and skge_open(). I am obviously quite behind compared to my project plan, but that is not something I can easily resolve; However; It does look like I will have time still left over at the end of writing the skge driver for some other prospects in this task. Possibly tg3?
Line 5: Line 5:
 So, after basicly 3 days off (except for a little work on saturday during and after my meeting) I'm ready to get going. It's 6:47 PM and I'm about to start on skge_transmit(). So, after basicly 3 days off (except for a little work on saturday during and after my meeting) I'm ready to get going. It's 6:47 PM and I'm about to start on skge_transmit().
  
 +
 +June 29 2:00 AM (really June 30):
 +
 +It's been a productive night; I discovered and fixed another memory issue with the allocation of Adapter;
 +Once that was dealt with, I implemented skge_transmit and skge_poll.
 +I'm not certian as I haven'​t setup wireshark yet, but I believe that I just saw my skge driver transmit it's first packet. ​
 +
 +I also pretty much overhaulled the DBGP commands so that anyone interested in writing a driver can literally just look at the output and understand all that is going on.
 +
 +<​code>​
 +
 +skge_probe - start
 +|
 +|-> Allocating 88 bytes of private space
 +|-> Registering skge_operations with the core
 +|-> Creating link to device
 +|-> Allocated 68 bytes for the adapter at 0x18d74
 +|-> Zero out from 0x18d74 to 0x19f84
 +|-> Adapter Base set to 18d7c
 +|-> ioaddr set to d800
 +|-> Using IRQ Number 10
 +|-> Assigned the Back and pdev pointers
 +|-> Defining the length of the regiser locations
 +|-> Mac Address of Port 1 : 00:​21:​91:​91:​10:​6d
 +|-> Beginning skge_initialize
 +|   ​|->​ Triggering a software reset
 +|   ​|->​ Waiting for one second . . . Done.
 +|   ​|->​ Enabling Test Mode
 +|   ​| ​  ​|->​ Removing error bits
 +|   ​| ​  ​|->​ Disabling Test Mode
 +|   |
 +|   ​|->​ Chip ID:
 +|   ​| ​  ​|->​ Detected ​  : b1
 +|   ​| ​  ​|->​ Reference Examples:
 +|   ​| ​      ​|->​ Genesis ​   : a
 +|   ​| ​      ​|->​ Yukon      : b0
 +|   ​| ​      ​|->​ Yukon Lite : b1
 +|   ​| ​      ​|->​ Yukon LP   : b2
 +|   |
 +|   ​|->​ Detecting Chip Type:
 +|   ​| ​  ​|->​ Marvell
 +|   |
 +|   ​|->​ Configuration Register ​  : 0x93
 +|   ​|->​ Number of Ports Detected : 1
 +|   ​|->​ Chip Revision ​           : 0x9
 +|   ​|->​ Calculating Ram Properties
 +|   ​| ​  ​|->​ ram_size ​                : 65536
 +|   ​| ​  ​|->​ ram_offset ​              : 0
 +|   |
 +|   ​|->​ Interface Mask is Register Value.
 +|   ​|->​ Forking into card specific initialization for Non-Genesis settings
 +|   ​| ​  ​|->​ Switching to VCC
 +|   ​| ​  ​|->​ Checking for stuck hardware bit (not-stuck (good))
 +|   ​| ​  ​|->​ Clearing error bits
 +|   ​| ​  ​|->​ Performing Software Reset
 +|   |
 +|   ​|->​ Stopping the card's hardware clocks
 +|   ​|->​ Turning the LED on
 +|   ​|->​ Enabling the transmit arbiter for port #0
 +|   ​|->​ Setting timeout initial values
 +|   ​|->​ Setting up the clocks
 +|   ​|->​ Resetting port #0
 +|   ​|->​ Entering yukon_reset
 +|   ​| ​  ​|->​ Disabling PHY IRQ's
 +|   ​| ​  ​|->​ Clearing MC Hash 1/4
 +|   ​| ​  ​|->​ Clearing MC Hash 2/4
 +|   ​| ​  ​|->​ Clearing MC Hash 3/4
 +|   ​| ​  ​|->​ Clearing MC Hash 4/4
 +|   ​| ​  ​|->​ Clearing temporary registers
 +|   |
 +|
 +|-> Entering skge_devinit:​ 0
 +|   ​|->​ Linking to private space
 +|   ​|->​ Setting up pointers
 +|   ​|->​ Defining tx (8) and rx (8) ring sizes
 +|   ​|->​ Defining modes, duplexing, and advertising
 +|   ​|->​ Setting link down prior to actual link detection
 +|
 +|-> Registering Netdev
 +|-> Setting Pci Device pointer
 +|-> Exiting skge_probe (return:0)
 +
 +
 +
 +
 +gPXE 0.9.7+ -- Open Source Boot Firmware -- http://​etherboot.org
 +Features: HTTP DNS TFTP AoE iSCSI bzImage COMBOOT ELF Multiboot PXE PXEXT
 +
 +skge_open - start
 +|
 +|-> Defining Receive Buffer of 1536
 +yukon_mac_init - Yukon Lite >= A3 - Yukon Lite >= A3 - Autoneg enabled. - flow:S or R-
 +Function: yukon_init - start
 +Function: yukon_init - end
 +yukon_mac_init - endadapter : 101748
 +rxqaddr : 85956
 +port    : 0
 +ram_addr: 0
 +chunk: 32768
 +skge_open - end - return 0
 +net0: 00:​21:​91:​91:​10:​6d on PCI00:08.0 (open)
 +  [Link:down, TX:0 TXE:0 RX:0 RXE:0]
 +Waiting for link-up on net0...skge : phy interrupt status 0x40 0x8100
 +skge : phy interrupt status 0x9040 0x514c
 +skge : phy interrupt status 0x5c60 0x7d2c
 +Yukon - link up - startskge net0: Link is up at 100 Mbps, full duplex
 +Yukon - link up - end ok
 +DHCP (net0 00:​21:​91:​91:​10:​6d).skge_transmit - start
 +skge_transmit - end
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +skge : phy interrupt status 0x0 0x6d2c
 +.skge_transmit - start
 +skge_transmit - end
 +skge : phy interrupt status 0x0 0x6d2c
 +
 +
 +
 +</​code>​
 +
 +Up to july 3, big hole in my memory as to what happened when: Basicly, I spent some time working with Andytim trying to trace out what was happening with my transmit method and never ended up finding anything wrong. A few other eyes looked at it with me and ... no results. ​
 -- Chris -- Chris

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