2021-07-06 21:15:26 +01:00
<!DOCTYPE HTML>
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html;charset=US-ASCII" >
2021-07-11 22:47:19 +01:00
< meta name = "generator" content = "ZealOS V0.07" >
2021-07-06 21:15:26 +01:00
< style type = "text/css" >
body {background-color:#000000;}
.cF0{color:#ffffff;background-color:#000000;}
.cF1{color:#3465a4;background-color:#000000;}
.cF2{color:#4e9a06;background-color:#000000;}
.cF3{color:#06989a;background-color:#000000;}
.cF4{color:#a24444;background-color:#000000;}
.cF5{color:#75507b;background-color:#000000;}
.cF6{color:#ce982f;background-color:#000000;}
.cF7{color:#bcc0b9;background-color:#000000;}
.cF8{color:#555753;background-color:#000000;}
.cF9{color:#729fcf;background-color:#000000;}
.cFA{color:#82bc49;background-color:#000000;}
.cFB{color:#34e2e2;background-color:#000000;}
.cFC{color:#ac3535;background-color:#000000;}
.cFD{color:#ad7fa8;background-color:#000000;}
.cFE{color:#fce94f;background-color:#000000;}
.cFF{color:#000000;background-color:#000000;}
< / style >
< / head >
< body >
< pre style = "font-family:monospace;font-size:12pt" >
< a name = "l1" > < / a > < span class = cF2 > /*< / span > < span class = cF0 > < / span > < span class = cF2 > Intel(R) E1000 Driver< / span > < span class = cF0 >
< a name = "l2" > < / a > < / span > < span class = cF2 > Author: TomAwezome< / span > < span class = cF0 >
< a name = "l3" > < / a >
< a name = "l4" > < / a > < / span > < span class = cF2 > Driver is based on:< / span > < span class = cF0 >
2021-07-08 03:36:01 +01:00
< a name = "l5" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > 01000101's example i825xx driver< / span > < span class = cF0 >
< a name = "l6" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > OSDev Intel(R) 8254x documentation< / span > < span class = cF0 >
< a name = "l7" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > Intel(R) PCI/PCI-X Family of Gigabit Ethernet Controllers Software Developer's Manual< / span > < span class = cF0 >
< a name = "l8" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > Linux E1000 driver< / span > < span class = cF0 >
2021-07-06 21:15:26 +01:00
< a name = "l9" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > any other useful sources.< / span > < span class = cF0 >
< a name = "l10" > < / a >
< a name = "l11" > < / a > < / span > < span class = cF2 > Guidelines:< / span > < span class = cF0 >
< a name = "l12" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > Magic numbers are bad. #defines are good.< / span > < span class = cF0 >
< a name = "l13" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > Understandability over LOC.< / span > < span class = cF0 >
< a name = "l14" > < / a > < / span > < span class = cF2 > -< / span > < span class = cF0 > < / span > < span class = cF2 > Clear documentation.< / span > < span class = cF0 >
< a name = "l15" > < / a > < / span > < span class = cF2 > */< / span > < span class = cF0 >
< a name = "l16" > < / a >
2021-07-07 07:22:37 +01:00
< a name = "l17" > < / a > < / span > < span class = cF2 > // TODO: clean up entire driver< / span > < span class = cF0 >
< a name = "l18" > < / a >
2021-07-08 03:36:01 +01:00
< a name = "l19" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_CTRL < / span > < span class = cFE > 0x0000< / span > < span class = cF0 >
< a name = "l20" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_EERD < / span > < span class = cFE > 0x0014< / span > < span class = cF0 > < / span > < span class = cF2 > // EEPROM Read< / span > < span class = cF0 >
< a name = "l21" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_IMS < / span > < span class = cFE > 0x00D0< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l22" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RCTL < / span > < span class = cFE > 0x0100< / span > < span class = cF0 >
< a name = "l23" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TCTL < / span > < span class = cFE > 0x0400< / span > < span class = cF0 >
< a name = "l24" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RDBAL < / span > < span class = cFE > 0x2800< / span > < span class = cF0 >
< a name = "l25" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RDBAH < / span > < span class = cFE > 0x2804< / span > < span class = cF0 >
< a name = "l26" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RDLEN < / span > < span class = cFE > 0x2808< / span > < span class = cF0 >
< a name = "l27" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RDH < / span > < span class = cFE > 0x2810< / span > < span class = cF0 >
< a name = "l28" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_RDT < / span > < span class = cFE > 0x2818< / span > < span class = cF0 >
< a name = "l29" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TDBAL < / span > < span class = cFE > 0x3800< / span > < span class = cF0 >
< a name = "l30" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TDBAH < / span > < span class = cFE > 0x3804< / span > < span class = cF0 >
< a name = "l31" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TDLEN < / span > < span class = cFE > 0x3808< / span > < span class = cF0 >
< a name = "l32" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TDH < / span > < span class = cFE > 0x3810< / span > < span class = cF0 >
< a name = "l33" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_TDT < / span > < span class = cFE > 0x3818< / span > < span class = cF0 >
< a name = "l34" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_REG_MTA < / span > < span class = cFE > 0x5200< / span > < span class = cF0 > < / span > < span class = cF2 > // Multicast Table Array< / span > < span class = cF0 >
< a name = "l35" > < / a >
< a name = "l36" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_CTRLf_SLU < / span > < span class = cFE > 6< / span > < span class = cF0 > < / span > < span class = cF2 > // Set Link Up ?< / span > < span class = cF0 >
< a name = "l37" > < / a >
< a name = "l38" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_CTRLF_SLU (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_CTRLf_SLU) < / span > < span class = cF2 > // Set Link Up ?< / span > < span class = cF0 >
2021-07-07 07:22:37 +01:00
< a name = "l39" > < / a >
2021-07-09 06:35:05 +01:00
< a name = "l40" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_EN < / span > < span class = cFE > 1< / span > < span class = cF0 >
< a name = "l41" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_SBP < / span > < span class = cFE > 2< / span > < span class = cF0 >
< a name = "l42" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_UPE < / span > < span class = cFE > 3< / span > < span class = cF0 >
< a name = "l43" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_MPE < / span > < span class = cFE > 4< / span > < span class = cF0 >
< a name = "l44" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_LPE < / span > < span class = cFE > 5< / span > < span class = cF0 >
< a name = "l45" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLf_RDMTS_HALF< / span > < span class = cF0 >
< a name = "l46" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_RDMTS_QUARTER < / span > < span class = cFE > 8< / span > < span class = cF0 >
< a name = "l47" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_RDMTS_EIGHTH < / span > < span class = cFE > 9< / span > < span class = cF0 >
< a name = "l48" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_BAM < / span > < span class = cFE > 15< / span > < span class = cF0 >
< a name = "l49" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_BSIZE_1024 < / span > < span class = cFE > 16< / span > < span class = cF0 >
< a name = "l50" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_BSIZE_512 < / span > < span class = cFE > 17< / span > < span class = cF0 >
< a name = "l51" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_BSIZE_256 < / span > < span class = cFE > 18< / span > < span class = cF0 >
< a name = "l52" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLf_BSIZE_2048< / span > < span class = cF0 >
< a name = "l53" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLf_BSIZE_4096< / span > < span class = cF0 >
< a name = "l54" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLf_BSIZE_8192< / span > < span class = cF0 >
< a name = "l55" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLf_BSIZE_16384< / span > < span class = cF0 >
< a name = "l56" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLf_SECRC < / span > < span class = cFE > 26< / span > < span class = cF0 >
< a name = "l57" > < / a >
< a name = "l58" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_EN (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_EN)
< a name = "l59" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_SBP (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_SBP)
< a name = "l60" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_UPE (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_UPE)
< a name = "l61" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_MPE (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_MPE)
< a name = "l62" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_LPE (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_LPE)
< a name = "l63" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLF_RDMTS_HALF< / span > < span class = cF0 >
< a name = "l64" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_RDMTS_QUARTER (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_RDMTS_QUARTER)
< a name = "l65" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_RDMTS_EIGHTH (< / span > < span class = cFE > 2< / span > < span class = cF0 > < < E1000_RCTLf_RDMTS_QUARTER)
< a name = "l66" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_BAM (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_BAM)
< a name = "l67" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_BSIZE_1024 (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_BSIZE_1024)
< a name = "l68" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_BSIZE_512 (< / span > < span class = cFE > 2< / span > < span class = cF0 > < < E1000_RCTLf_BSIZE_1024)
< a name = "l69" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_BSIZE_256 (< / span > < span class = cFE > 3< / span > < span class = cF0 > < < E1000_RCTLf_BSIZE_1024)
< a name = "l70" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLF_BSIZE_2048< / span > < span class = cF0 >
< a name = "l71" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLF_BSIZE_4096< / span > < span class = cF0 >
< a name = "l72" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLF_BSIZE_8192< / span > < span class = cF0 >
< a name = "l73" > < / a > < / span > < span class = cF2 > //#define E1000_RCTLF_BSIZE_16384< / span > < span class = cF0 >
< a name = "l74" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RCTLF_SECRC (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_RCTLf_SECRC)
< a name = "l75" > < / a >
< a name = "l76" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_TCTLf_EN < / span > < span class = cFE > 1< / span > < span class = cF0 >
< a name = "l77" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_TCTLf_PSP < / span > < span class = cFE > 3< / span > < span class = cF0 >
< a name = "l78" > < / a >
< a name = "l79" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_TCTLF_EN (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_TCTLf_EN)
< a name = "l80" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_TCTLF_PSP (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < E1000_TCTLf_PSP)
< a name = "l81" > < / a >
< a name = "l82" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_RX_BUFF_COUNT < / span > < span class = cFE > 32< / span > < span class = cF0 > < / span > < span class = cF2 > // 01000101's driver uses 768 for each of these...< / span > < span class = cF0 >
< a name = "l83" > < / a > #< / span > < span class = cF1 > define< / span > < span class = cF0 > E1000_TX_BUFF_COUNT < / span > < span class = cFE > 8< / span > < span class = cF0 >
< a name = "l84" > < / a >
< a name = "l85" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > CE1000DescriptorEntryRX
< a name = "l86" > < / a > {
< a name = "l87" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > address;
< a name = "l88" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > length;
< a name = "l89" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > checksum;
< a name = "l90" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > status;
< a name = "l91" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > errors;
< a name = "l92" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > special;
< a name = "l93" > < / a > };
< a name = "l94" > < / a >
< a name = "l95" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > CE1000DescriptorEntryTX
< a name = "l96" > < / a > {
< a name = "l97" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > address;
< a name = "l98" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > length;
< a name = "l99" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > cso;
< a name = "l100" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > cmd;
< a name = "l101" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > sta;
< a name = "l102" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > css;
< a name = "l103" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > special;
< a name = "l104" > < / a > };
< a name = "l105" > < / a >
< a name = "l106" > < / a > < / span > < span class = cF1 > class< / span > < span class = cF0 > CE1000
< a name = "l107" > < / a > {
< a name = "l108" > < / a > < / span > < span class = cF9 > CPCIDev< / span > < span class = cF0 > *pci;
< a name = "l109" > < / a >
< a name = "l110" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > mac_address[< / span > < span class = cFE > 6< / span > < span class = cF0 > ];
< a name = "l111" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > mmio_address;
2021-07-09 21:56:43 +01:00
< a name = "l112" > < / a >
< a name = "l113" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > current_rx_de_index; < / span > < span class = cF2 > // Current Receive DE being processed. Gets incremented, wrapped to 0 at max of E1000_RX_BUFF_COUNT.< / span > < span class = cF0 >
< a name = "l114" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > current_tx_de_index; < / span > < span class = cF2 > // Current Transmit DE being processed. Gets incremented, wrapped to 0 at max of E1000_TX_BUFF_COUNT.< / span > < span class = cF0 >
< a name = "l115" > < / a >
< a name = "l116" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *rx_de_buffer; < / span > < span class = cF2 > // Uncached-alias of pointer to the buffer of RX Descriptor Entries.< / span > < span class = cF0 >
< a name = "l117" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *tx_de_buffer; < / span > < span class = cF2 > // Uncached-alias of pointer to the buffer of TX Descriptor Entries.< / span > < span class = cF0 >
< a name = "l118" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *rx_de_buffer_phys; < / span > < span class = cF2 > // Pointer to the buffer of RX Descriptor Entries. (Code Heap, lower 2Gb)< / span > < span class = cF0 >
< a name = "l119" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *tx_de_buffer_phys; < / span > < span class = cF2 > // Pointer to the buffer of TX Descriptor Entries. (Code Heap, lower 2Gb)< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l120" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l121" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > rx_buffer_addr; < / span > < span class = cF2 > // Uncached-alias of address of receive buffers.< / span > < span class = cF0 >
< a name = "l122" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > tx_buffer_addr; < / span > < span class = cF2 > // Uncached-alias of address of transmit buffers.< / span > < span class = cF0 >
< a name = "l123" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > rx_buffer_addr_phys; < / span > < span class = cF2 > // Physical address of actual receive buffers (< 4 Gb)< / span > < span class = cF0 >
< a name = "l124" > < / a > < / span > < span class = cF9 > U64< / span > < span class = cF0 > tx_buffer_addr_phys; < / span > < span class = cF2 > // Physical address of actual transmit buffers (< 4 Gb)< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l125" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l126" > < / a >
< a name = "l127" > < / a > } e1000; < / span > < span class = cF2 > // e1000 is the global variable we store all of this into.< / span > < span class = cF0 >
< a name = "l128" > < / a >
< a name = "l129" > < / a > < / span > < span class = cF9 > CPCIDev< / span > < span class = cF0 > *E1000PCIDevFind()
< a name = "l130" > < / a > {< / span > < span class = cF2 > // Find and return E1000 card as a CPCIDev pointer.< / span > < span class = cF0 >
< a name = "l131" > < / a >
< a name = "l132" > < / a > < / span > < span class = cF9 > CPCIDev< / span > < span class = cF0 > *pci = < / span > < span class = cF5 > PCIDevFind< / span > < span class = cF0 > (< / span > < span class = cF3 > PCIC_NETWORK< / span > < span class = cF0 > ,, PCIV_E1000);
< a name = "l133" > < / a >
< a name = "l134" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!pci)
< a name = "l135" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l136" > < / a >
< a name = "l137" > < / a > < / span > < span class = cF5 > ClassRep< / span > < span class = cF0 > (pci);
< a name = "l138" > < / a >
< a name = "l139" > < / a > < / span > < span class = cF1 > switch< / span > < span class = cF0 > (pci-> device_id)
< a name = "l140" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l141" > < / a > < / span > < span class = cF1 > case< / span > < span class = cF0 > PCID_82545EM:
< a name = "l142" > < / a > < / span > < span class = cF1 > break< / span > < span class = cF0 > ;
< a name = "l143" > < / a >
< a name = "l144" > < / a > < / span > < span class = cF1 > default< / span > < span class = cF0 > :
< a name = "l145" > < / a > pci = < / span > < span class = cF3 > NULL< / span > < span class = cF0 > ;
< a name = "l146" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l147" > < / a >
< a name = "l148" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > pci;
< a name = "l149" > < / a > }
< a name = "l150" > < / a >
< a name = "l151" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > E1000MMIORead(< / span > < span class = cF9 > U32< / span > < span class = cF0 > < / span > < span class = cF1 > offset< / span > < span class = cF0 > )
< a name = "l152" > < / a > {
< a name = "l153" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > *val = e1000.mmio_address + < / span > < span class = cF1 > offset< / span > < span class = cF0 > ;
< a name = "l154" > < / a >
< a name = "l155" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > *val;
< a name = "l156" > < / a > }
< a name = "l157" > < / a >
< a name = "l158" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000MMIOWrite(< / span > < span class = cF9 > U32< / span > < span class = cF0 > < / span > < span class = cF1 > offset< / span > < span class = cF0 > , < / span > < span class = cF9 > U32< / span > < span class = cF0 > val)
< a name = "l159" > < / a > {
< a name = "l160" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > *addr = e1000.mmio_address + < / span > < span class = cF1 > offset< / span > < span class = cF0 > ;
< a name = "l161" > < / a >
< a name = "l162" > < / a > *addr = val;
< a name = "l163" > < / a > }
< a name = "l164" > < / a >
< a name = "l165" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > E1000EEPROMRead(< / span > < span class = cF1 > U8< / span > < span class = cF0 > word)
< a name = "l166" > < / a > { < / span > < span class = cF2 > // word arg is which U16 to read< / span > < span class = cF0 >
< a name = "l167" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > data;
< a name = "l168" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > temp;
< a name = "l169" > < / a >
< a name = "l170" > < / a > E1000MMIOWrite(E1000_REG_EERD, < / span > < span class = cFE > 1< / span > < span class = cF0 > | word < < < / span > < span class = cFE > 8< / span > < span class = cF0 > );
< a name = "l171" > < / a >
< a name = "l172" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (!< / span > < span class = cF7 > (< / span > < span class = cF0 > (temp = E1000MMIORead< / span > < span class = cF7 > (< / span > < span class = cF0 > E1000_REG_EERD< / span > < span class = cF7 > )< / span > < span class = cF0 > ) & (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 4< / span > < span class = cF0 > )< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l173" > < / a > < / span > < span class = cF5 > Sleep< / span > < span class = cF0 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > );
< a name = "l174" > < / a >
< a name = "l175" > < / a > data = (temp > > < / span > < span class = cFE > 16< / span > < span class = cF0 > ) & < / span > < span class = cFE > 0xFFFF< / span > < span class = cF0 > ;
< a name = "l176" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > data;
< a name = "l177" > < / a > }
< a name = "l178" > < / a >
< a name = "l179" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000MACGet()
< a name = "l180" > < / a > {
< a name = "l181" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
< a name = "l182" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > mac;
< a name = "l183" > < / a >
< a name = "l184" > < / a > NetLog(< / span > < span class = cF6 > " E1000 MAC GET: Getting MAC Address." < / span > < span class = cF0 > );
< a name = "l185" > < / a >
< a name = "l186" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (i = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; i < < / span > < span class = cFE > 3< / span > < span class = cF0 > ; i++)
< a name = "l187" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l188" > < / a > mac = E1000EEPROMRead(i);
< a name = "l189" > < / a > e1000.mac_address[< / span > < span class = cFE > 2< / span > < span class = cF0 > *i] = mac & < / span > < span class = cFE > 0xFF< / span > < span class = cF0 > ;
< a name = "l190" > < / a > e1000.mac_address[< / span > < span class = cFE > 2< / span > < span class = cF0 > *i+< / span > < span class = cFE > 1< / span > < span class = cF0 > ] = (mac > > < / span > < span class = cFE > 8< / span > < span class = cF0 > ) & < / span > < span class = cFE > 0xFF< / span > < span class = cF0 > ;
< a name = "l191" > < / a > NetLog(< / span > < span class = cF6 > " %02X %02X" < / span > < span class = cF0 > , mac.u8[< / span > < span class = cFE > 0< / span > < span class = cF0 > ], mac.u8[< / span > < span class = cFE > 1< / span > < span class = cF0 > ]);
< a name = "l192" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l193" > < / a >
< a name = "l194" > < / a > }
< a name = "l195" > < / a >
< a name = "l196" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > E1000PacketReceive(< / span > < span class = cF1 > U8< / span > < span class = cF0 > **packet_buffer_out, < / span > < span class = cF9 > U16< / span > < span class = cF0 > *packet_length_out)
< a name = "l197" > < / a > {
< a name = "l198" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index = e1000.current_rx_de_index;
< a name = "l199" > < / a > CE1000DescriptorEntryRX *entry = & e1000.rx_de_buffer[de_index * < / span > < span class = cF1 > sizeof< / span > < span class = cF0 > (CE1000DescriptorEntryRX)];
< a name = "l200" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > drop = < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
< a name = "l201" > < / a >
< a name = "l202" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (entry-> length < < / span > < span class = cFE > 60< / span > < span class = cF0 > )
< a name = "l203" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l204" > < / a > NetErr(< / span > < span class = cF6 > " E1000 PACKET RECEIVE: Short Packet" < / span > < span class = cF0 > );
< a name = "l205" > < / a > drop = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l206" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l207" > < / a >
< a name = "l208" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (entry-> status & < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 1< / span > < span class = cF7 > )< / span > < span class = cF0 > ) < / span > < span class = cF2 > // EOP ?? TODO #define< / span > < span class = cF0 >
< a name = "l209" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l210" > < / a > NetErr(< / span > < span class = cF6 > " E1000 PACKET RECEIVE: No EOP Set" < / span > < span class = cF0 > );
< a name = "l211" > < / a > drop = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l212" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l213" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l214" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (entry-> errors)
< a name = "l215" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l216" > < / a > NetErr(< / span > < span class = cF6 > " E1000 PACKET RECEIVE: RX DE Error Bits Set" < / span > < span class = cF0 > );
< a name = "l217" > < / a > drop = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l218" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l219" > < / a >
< a name = "l220" > < / a > e1000.current_rx_de_index = (e1000.current_rx_de_index + < / span > < span class = cFE > 1< / span > < span class = cF0 > ) & (E1000_RX_BUFF_COUNT - < / span > < span class = cFE > 1< / span > < span class = cF0 > );
< a name = "l221" > < / a >
< a name = "l222" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!drop)
< a name = "l223" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l224" > < / a > *packet_buffer_out = entry-> address;
< a name = "l225" > < / a > *packet_length_out = entry-> length;
< a name = "l226" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l227" > < / a > < / span > < span class = cF1 > else< / span > < span class = cF0 >
< a name = "l228" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l229" > < / a > NetErr(< / span > < span class = cF6 > " E1000 PACKET RECEIVE: Dropping packet." < / span > < span class = cF0 > );
< a name = "l230" > < / a > de_index = -< / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l231" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l232" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l233" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > de_index;
< a name = "l234" > < / a > }
< a name = "l235" > < / a >
< a name = "l236" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000ReceivePacketRelease(< / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index)
< a name = "l237" > < / a > {
< a name = "l238" > < / a > CE1000DescriptorEntryRX *entry = & e1000.rx_de_buffer[de_index * < / span > < span class = cF1 > sizeof< / span > < span class = cF0 > (CE1000DescriptorEntryRX)];
< a name = "l239" > < / a > entry-> status = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l240" > < / a >
< a name = "l241" > < / a > E1000MMIOWrite(E1000_REG_RDT, e1000.current_rx_de_index);
< a name = "l242" > < / a > }
< a name = "l243" > < / a >
< a name = "l244" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > E1000DriverOwnsRX(CE1000DescriptorEntryRX *entry)
< a name = "l245" > < / a > {
< a name = "l246" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > < / span > < span class = cF5 > Bt< / span > < span class = cF0 > (& entry-> status, < / span > < span class = cFE > 0< / span > < span class = cF0 > ); < / span > < span class = cF2 > // ?? TODO #define< / span > < span class = cF0 >
< a name = "l247" > < / a > }
< a name = "l248" > < / a >
< a name = "l249" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > E1000TransmitPacketAllocate(< / span > < span class = cF1 > U8< / span > < span class = cF0 > **packet_buffer_out, < / span > < span class = cF9 > I64< / span > < span class = cF0 > length)
< a name = "l250" > < / a > { < / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index = e1000.current_tx_de_index;
< a name = "l251" > < / a >
< a name = "l252" > < / a > CE1000DescriptorEntryTX *entry = & e1000.tx_de_buffer[de_index * < / span > < span class = cF1 > sizeof< / span > < span class = cF0 > (CE1000DescriptorEntryTX)];
< a name = "l253" > < / a >
< a name = "l254" > < / a > *packet_buffer_out = e1000.tx_buffer_addr + de_index * ETHERNET_FRAME_SIZE;
< a name = "l255" > < / a >
< a name = "l256" > < / a > < / span > < span class = cF5 > MemSet< / span > < span class = cF0 > (*packet_buffer_out, < / span > < span class = cFE > 0< / span > < span class = cF0 > , ETHERNET_FRAME_SIZE); < / span > < span class = cF2 > // Clear buffer contents in advance.< / span > < span class = cF0 >
< a name = "l257" > < / a >
< a name = "l258" > < / a > entry-> address = *packet_buffer_out;
< a name = "l259" > < / a > entry-> length = length;
< a name = "l260" > < / a > entry-> cmd = (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 3< / span > < span class = cF0 > ) | < / span > < span class = cFE > 3< / span > < span class = cF0 > ; < / span > < span class = cF2 > // ??? TODO #define< / span > < span class = cF0 >
< a name = "l261" > < / a >
< a name = "l262" > < / a > NetLog(< / span > < span class = cF6 > " E1000 ALLOCATE TX PACKET: de_index: %X." < / span > < span class = cF0 > , de_index);
< a name = "l263" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > de_index;
< a name = "l264" > < / a > }
< a name = "l265" > < / a >
< a name = "l266" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000TransmitPacketFinish(< / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index)
< a name = "l267" > < / a > {
< a name = "l268" > < / a > CE1000DescriptorEntryTX *entry = & e1000.tx_de_buffer[de_index * < / span > < span class = cF1 > sizeof< / span > < span class = cF0 > (CE1000DescriptorEntryTX)];
< a name = "l269" > < / a >
< a name = "l270" > < / a > e1000.current_tx_de_index = (e1000.current_tx_de_index + < / span > < span class = cFE > 1< / span > < span class = cF0 > ) & (E1000_TX_BUFF_COUNT - < / span > < span class = cFE > 1< / span > < span class = cF0 > );
< a name = "l271" > < / a > E1000MMIOWrite(E1000_REG_TDT, e1000.current_tx_de_index);
< a name = "l272" > < / a >
< a name = "l273" > < / a > < / span > < span class = cF5 > ClassRep< / span > < span class = cF0 > (entry);
< a name = "l274" > < / a >
< a name = "l275" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (!< / span > < span class = cF7 > (< / span > < span class = cF0 > entry-> sta & < / span > < span class = cFE > 0xF< / span > < span class = cF7 > )< / span > < span class = cF0 > ) < / span > < span class = cF2 > // ???< / span > < span class = cF0 >
< a name = "l276" > < / a > < / span > < span class = cF5 > Yield< / span > < span class = cF0 > ;
2021-07-09 06:35:05 +01:00
< a name = "l277" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l278" > < / a > NetLog(< / span > < span class = cF6 > " E1000 FINISH TX PACKET: TX DE index: %X." < / span > < span class = cF0 > , de_index);
< a name = "l279" > < / a > }
< a name = "l280" > < / a >
< a name = "l281" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > EthernetFrameFinish(< / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index)
< a name = "l282" > < / a > {< / span > < span class = cF2 > //Alias for driver Finish TX function.< / span > < span class = cF0 >
< a name = "l283" > < / a > E1000TransmitPacketFinish(de_index);
< a name = "l284" > < / a > }
< a name = "l285" > < / a >
< a name = "l286" > < / a > < / span > < span class = cF1 > interrupt< / span > < span class = cF0 > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000IRQ()
< a name = "l287" > < / a > { < / span > < span class = cF2 > // TODO need #defines< / span > < span class = cF0 >
< a name = "l288" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > icr = E1000MMIORead(< / span > < span class = cFE > 0xC0< / span > < span class = cF0 > ); < / span > < span class = cF2 > // ???< / span > < span class = cF0 >
< a name = "l289" > < / a > < / span > < span class = cF1 > Bool< / span > < span class = cF0 > poll = < / span > < span class = cF3 > FALSE< / span > < span class = cF0 > ;
< a name = "l290" > < / a > CE1000DescriptorEntryRX *entry = e1000.rx_de_buffer;
< a name = "l291" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *packet_buffer;
< a name = "l292" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > packet_length;
< a name = "l293" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index;
< a name = "l294" > < / a >
< a name = "l295" > < / a > icr & = ~< / span > < span class = cFE > 3< / span > < span class = cF0 > ; < / span > < span class = cF2 > // ??< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l296" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l297" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (icr & < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 2< / span > < span class = cF7 > )< / span > < span class = cF0 > ) < / span > < span class = cF2 > // ?? 'link status change' ??< / span > < span class = cF0 >
< a name = "l298" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l299" > < / a > icr & = ~(< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 2< / span > < span class = cF0 > );
< a name = "l300" > < / a > E1000MMIOWrite(E1000_REG_CTRL, E1000MMIORead< / span > < span class = cF7 > (< / span > < span class = cF0 > E1000_REG_CTRL< / span > < span class = cF7 > )< / span > < span class = cF0 > | E1000_CTRLF_SLU);
< a name = "l301" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l302" > < / a >
< a name = "l303" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (icr & < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 6< / span > < span class = cF7 > )< / span > < span class = cF0 > || icr & < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 4< / span > < span class = cF7 > )< / span > < span class = cF0 > ) < / span > < span class = cF2 > // ?? 'rx underrun / min threshold' ??< / span > < span class = cF0 >
< a name = "l304" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l305" > < / a > icr = ~(< / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 6< / span > < span class = cF7 > )< / span > < span class = cF0 > | < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 4< / span > < span class = cF7 > )< / span > < span class = cF0 > ); < / span > < span class = cF2 > // ??< / span > < span class = cF0 >
< a name = "l306" > < / a >
< a name = "l307" > < / a > poll = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l308" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l309" > < / a >
< a name = "l310" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (icr & < / span > < span class = cF7 > (< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 7< / span > < span class = cF7 > )< / span > < span class = cF0 > ) < / span > < span class = cF2 > // ?? 'packet pending?< / span > < span class = cF0 >
< a name = "l311" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l312" > < / a > icr & = ~(< / span > < span class = cFE > 1< / span > < span class = cF0 > < < < / span > < span class = cFE > 7< / span > < span class = cF0 > );
2021-07-09 06:35:05 +01:00
< a name = "l313" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l314" > < / a > poll = < / span > < span class = cF3 > TRUE< / span > < span class = cF0 > ;
< a name = "l315" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l316" > < / a >
< a name = "l317" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (poll)
< a name = "l318" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l319" > < / a > < / span > < span class = cF1 > while< / span > < span class = cF0 > (E1000DriverOwnsRX< / span > < span class = cF7 > (< / span > < span class = cF0 > & entry[e1000.current_rx_de_index]< / span > < span class = cF7 > )< / span > < span class = cF0 > )
< a name = "l320" > < / a > {
< a name = "l321" > < / a > NetLog(< / span > < span class = cF6 > " $BG,LTCYAN$$FG,WHITE$" < / span > < span class = cF0 >
< a name = "l322" > < / a > < / span > < span class = cF6 > " ==== E1000 IRQ ====" < / span > < span class = cF0 >
< a name = "l323" > < / a > < / span > < span class = cF6 > " $BG$$FG$" < / span > < span class = cF0 > );
< a name = "l324" > < / a >
< a name = "l325" > < / a > NetLog(< / span > < span class = cF6 > " $BD,CYAN$$FD,WHITE$" < / span > < span class = cF0 >
< a name = "l326" > < / a > < / span > < span class = cF6 > " E1000 IRQ: Saw owned RX DE index %d." < / span > < span class = cF0 > , e1000.current_rx_de_index);
< a name = "l327" > < / a >
< a name = "l328" > < / a > de_index = E1000PacketReceive(& packet_buffer, & packet_length);
< a name = "l329" > < / a >
< a name = "l330" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (de_index > = < / span > < span class = cFE > 0< / span > < span class = cF0 > )
< a name = "l331" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l332" > < / a > NetLog(< / span > < span class = cF6 > " E1000 IRQ: Pushing copy into Net Queue, releasing receive packet." < / span > < span class = cF0 > );
< a name = "l333" > < / a > NetQueuePush(packet_buffer, packet_length);
< a name = "l334" > < / a > E1000ReceivePacketRelease(de_index);
< a name = "l335" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l336" > < / a >
< a name = "l337" > < / a > NetLog(< / span > < span class = cF6 > " E1000 IRQ: Exiting.\n" < / span > < span class = cF0 >
< a name = "l338" > < / a > < / span > < span class = cF6 > " $BD,WHITE$$FD,LTGRAY$" < / span > < span class = cF0 >
< a name = "l339" > < / a > < / span > < span class = cF6 > " $BG,LTCYAN$$FG,WHITE$" < / span > < span class = cF0 >
< a name = "l340" > < / a > < / span > < span class = cF6 > " ===================" < / span > < span class = cF0 >
< a name = "l341" > < / a > < / span > < span class = cF6 > " $BG$$FG$" < / span > < span class = cF0 > );
< a name = "l342" > < / a > }
< a name = "l343" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
2021-07-09 06:35:05 +01:00
< a name = "l344" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l345" > < / a >
< a name = "l346" > < / a >
< a name = "l347" > < / a > E1000MMIORead(< / span > < span class = cFE > 0xC0< / span > < span class = cF0 > ); < / span > < span class = cF2 > // ?? 'clear pending interrupts' ??< / span > < span class = cF0 >
< a name = "l348" > < / a >
< a name = "l349" > < / a > *(< / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + < / span > < span class = cF3 > LAPIC_EOI< / span > < span class = cF0 > )(< / span > < span class = cF9 > U32< / span > < span class = cF0 > *) = < / span > < span class = cFE > 0< / span > < span class = cF0 > ;
< a name = "l350" > < / a >
< a name = "l351" > < / a > }
< a name = "l352" > < / a >
< a name = "l353" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > PCIInterruptsReroute(< / span > < span class = cF9 > I64< / span > < span class = cF0 > base)
< a name = "l354" > < / a > { < / span > < span class = cF2 > // todo: comments explaining process, maybe better var names< / span > < span class = cF0 >
< a name = "l355" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
< a name = "l356" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *da = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + < / span > < span class = cF3 > IOAPIC_REG< / span > < span class = cF0 > ;
< a name = "l357" > < / a > < / span > < span class = cF9 > U32< / span > < span class = cF0 > *_d = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + < / span > < span class = cF3 > IOAPIC_DATA< / span > < span class = cF0 > ;
< a name = "l358" > < / a >
< a name = "l359" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (i = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; i < < / span > < span class = cFE > 4< / span > < span class = cF0 > ; i++)
< a name = "l360" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l361" > < / a > *da = < / span > < span class = cF3 > IOREDTAB< / span > < span class = cF0 > + i * < / span > < span class = cFE > 2< / span > < span class = cF0 > + < / span > < span class = cFE > 1< / span > < span class = cF0 > ;
< a name = "l362" > < / a > *_d = < / span > < span class = cFB > dev< / span > < span class = cF0 > .mp_apic_ids[INT_DEST_CPU] < < < / span > < span class = cFE > 24< / span > < span class = cF0 > ;
< a name = "l363" > < / a > *da = < / span > < span class = cF3 > IOREDTAB< / span > < span class = cF0 > + i * < / span > < span class = cFE > 2< / span > < span class = cF0 > ;
< a name = "l364" > < / a > *_d = < / span > < span class = cFE > 0x4000< / span > < span class = cF0 > + base + i;
< a name = "l365" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l366" > < / a > }
< a name = "l367" > < / a >
2021-07-09 06:35:05 +01:00
< a name = "l368" > < / a >
2021-07-09 21:56:43 +01:00
< a name = "l369" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000InterruptsSetup()
< a name = "l370" > < / a > { < / span > < span class = cF2 > // .. ?< / span > < span class = cF0 >
< a name = "l371" > < / a > < / span > < span class = cF5 > IntEntrySet< / span > < span class = cF0 > (I_E1000_0, & E1000IRQ);
< a name = "l372" > < / a > < / span > < span class = cF5 > IntEntrySet< / span > < span class = cF0 > (I_E1000_1, & E1000IRQ);
< a name = "l373" > < / a > < / span > < span class = cF5 > IntEntrySet< / span > < span class = cF0 > (I_E1000_2, & E1000IRQ);
< a name = "l374" > < / a > < / span > < span class = cF5 > IntEntrySet< / span > < span class = cF0 > (I_E1000_3, & E1000IRQ);
< a name = "l375" > < / a > PCIInterruptsReroute(I_E1000_0);
< a name = "l376" > < / a > }
< a name = "l377" > < / a >
< a name = "l378" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000InitRX()
< a name = "l379" > < / a > {
< a name = "l380" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index;
< a name = "l381" > < / a >
< a name = "l382" > < / a > e1000.rx_de_buffer_phys = < / span > < span class = cF5 > CAllocAligned< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > CE1000DescriptorEntryRX< / span > < span class = cF7 > )< / span > < span class = cF0 > * E1000_RX_BUFF_COUNT,
< a name = "l383" > < / a > < / span > < span class = cFE > 16< / span > < span class = cF0 > ,
< a name = "l384" > < / a > < / span > < span class = cF5 > Fs< / span > < span class = cF0 > -> code_heap);
< a name = "l385" > < / a >
< a name = "l386" > < / a > e1000.rx_de_buffer = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + e1000.rx_de_buffer_phys;
< a name = "l387" > < / a >
< a name = "l388" > < / a > e1000.rx_buffer_addr_phys = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (ETHERNET_FRAME_SIZE * E1000_RX_BUFF_COUNT, < / span > < span class = cF5 > Fs< / span > < span class = cF0 > -> code_heap);
< a name = "l389" > < / a >
< a name = "l390" > < / a > e1000.rx_buffer_addr = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + e1000.rx_buffer_addr_phys;
< a name = "l391" > < / a >
< a name = "l392" > < / a > < / span > < span class = cF2 > // iterate de's and make packet buffers for each< / span > < span class = cF0 >
< a name = "l393" > < / a > CE1000DescriptorEntryRX *entry = e1000.rx_de_buffer;
< a name = "l394" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (de_index = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; de_index < E1000_RX_BUFF_COUNT; de_index++)
< a name = "l395" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l396" > < / a > entry-> address = e1000.rx_buffer_addr + de_index * ETHERNET_FRAME_SIZE; < / span > < span class = cF2 > // is this right? might need to change ?..< / span > < span class = cF0 >
< a name = "l397" > < / a > < / span > < span class = cF2 > // 01000101 MAlloc's 8208 for each DE< / span > < span class = cF0 >
< a name = "l398" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > PCNetDescriptorEntryInit(& entry[de_index],< / span > < span class = cF0 >
< a name = "l399" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > pcnet.rx_buffer_addr + de_index * ETHERNET_FRAME_SIZE,< / span > < span class = cF0 >
< a name = "l400" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > TRUE); // TRUE for is_rx.< / span > < span class = cF0 >
< a name = "l401" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l402" > < / a >
< a name = "l403" > < / a > < / span > < span class = cF2 > // setup rx de ring buffer< / span > < span class = cF0 >
< a name = "l404" > < / a > E1000MMIOWrite(E1000_REG_RDBAH, e1000.rx_de_buffer > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ); < / span > < span class = cF2 > // should we be using uncached addr here ?< / span > < span class = cF0 >
< a name = "l405" > < / a > E1000MMIOWrite(E1000_REG_RDBAL, e1000.rx_de_buffer & < / span > < span class = cFE > 0xFFFFFFFF< / span > < span class = cF0 > );
< a name = "l406" > < / a >
< a name = "l407" > < / a > < / span > < span class = cF2 > // set receive buffer length< / span > < span class = cF0 >
< a name = "l408" > < / a > E1000MMIOWrite(E1000_REG_RDLEN, E1000_RX_BUFF_COUNT * < / span > < span class = cFE > 16< / span > < span class = cF0 > );
< a name = "l409" > < / a >
< a name = "l410" > < / a > < / span > < span class = cF2 > // set head tail pointers< / span > < span class = cF0 >
< a name = "l411" > < / a > E1000MMIOWrite(E1000_REG_RDH, < / span > < span class = cFE > 0< / span > < span class = cF0 > );
< a name = "l412" > < / a > E1000MMIOWrite(E1000_REG_RDT, E1000_RX_BUFF_COUNT);
< a name = "l413" > < / a >
< a name = "l414" > < / a > < / span > < span class = cF2 > // set receive control reg< / span > < span class = cF0 >
< a name = "l415" > < / a > E1000MMIOWrite(E1000_REG_RCTL, E1000_RCTLF_SBP |
< a name = "l416" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > E1000_RCTLF_UPE< / span > < span class = cF0 > < / span > < span class = cF2 > |< / span > < span class = cF0 >
< a name = "l417" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > E1000_RCTLF_RDMTS_HALF< / span > < span class = cF0 > < / span > < span class = cF2 > |< / span > < span class = cF0 >
< a name = "l418" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > E1000_RCTLF_BSIZE_2048< / span > < span class = cF0 > < / span > < span class = cF2 > |< / span > < span class = cF0 >
< a name = "l419" > < / a > < / span > < span class = cF2 > //< / span > < span class = cF0 > < / span > < span class = cF2 > E1000_RCTLF_MPE< / span > < span class = cF0 > < / span > < span class = cF2 > |< / span > < span class = cF0 >
< a name = "l420" > < / a > E1000_RCTLF_SECRC |
< a name = "l421" > < / a > E1000_RCTLF_LPE |
< a name = "l422" > < / a > E1000_RCTLF_BAM);
< a name = "l423" > < / a > }
< a name = "l424" > < / a >
< a name = "l425" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000InitTX()
< a name = "l426" > < / a > {
< a name = "l427" > < / a > e1000.tx_de_buffer_phys = < / span > < span class = cF5 > CAllocAligned< / span > < span class = cF0 > (< / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > CE1000DescriptorEntryTX< / span > < span class = cF7 > )< / span > < span class = cF0 > * E1000_TX_BUFF_COUNT,
< a name = "l428" > < / a > < / span > < span class = cFE > 16< / span > < span class = cF0 > ,
< a name = "l429" > < / a > < / span > < span class = cF5 > Fs< / span > < span class = cF0 > -> code_heap);
< a name = "l430" > < / a >
< a name = "l431" > < / a > e1000.tx_de_buffer = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + e1000.tx_de_buffer_phys;
< a name = "l432" > < / a >
< a name = "l433" > < / a > e1000.tx_buffer_addr_phys = < / span > < span class = cF5 > CAlloc< / span > < span class = cF0 > (ETHERNET_FRAME_SIZE * E1000_TX_BUFF_COUNT, < / span > < span class = cF5 > Fs< / span > < span class = cF0 > -> code_heap);
< a name = "l434" > < / a >
< a name = "l435" > < / a > e1000.tx_buffer_addr = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + e1000.tx_buffer_addr_phys;
< a name = "l436" > < / a >
< a name = "l437" > < / a > < / span > < span class = cF2 > // setup tx de ring buffer< / span > < span class = cF0 >
< a name = "l438" > < / a > E1000MMIOWrite(E1000_REG_TDBAH, e1000.tx_de_buffer > > < / span > < span class = cFE > 32< / span > < span class = cF0 > ); < / span > < span class = cF2 > // should we be using uncached addr here ?< / span > < span class = cF0 >
< a name = "l439" > < / a > E1000MMIOWrite(E1000_REG_TDBAL, e1000.tx_de_buffer & < / span > < span class = cFE > 0xFFFFFFFF< / span > < span class = cF0 > );
< a name = "l440" > < / a >
< a name = "l441" > < / a > < / span > < span class = cF2 > // set tx buffer length< / span > < span class = cF0 >
< a name = "l442" > < / a > E1000MMIOWrite(E1000_REG_TDLEN, E1000_TX_BUFF_COUNT * < / span > < span class = cFE > 16< / span > < span class = cF0 > );
< a name = "l443" > < / a >
< a name = "l444" > < / a > < / span > < span class = cF2 > // set head tail pointers< / span > < span class = cF0 >
< a name = "l445" > < / a > E1000MMIOWrite(E1000_REG_TDH, < / span > < span class = cFE > 0< / span > < span class = cF0 > );
< a name = "l446" > < / a > E1000MMIOWrite(E1000_REG_TDT, E1000_RX_BUFF_COUNT);
< a name = "l447" > < / a >
< a name = "l448" > < / a > < / span > < span class = cF2 > // set transmit control reg< / span > < span class = cF0 >
< a name = "l449" > < / a > E1000MMIOWrite(E1000_REG_TCTL, E1000_TCTLF_EN | E1000_TCTLF_PSP);
< a name = "l450" > < / a >
< a name = "l451" > < / a > }
< a name = "l452" > < / a >
< a name = "l453" > < / a >
< a name = "l454" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > E1000Init()
< a name = "l455" > < / a > {
< a name = "l456" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > i;
< a name = "l457" > < / a >
< a name = "l458" > < / a > < / span > < span class = cF5 > MemSet< / span > < span class = cF0 > (& e1000, < / span > < span class = cFE > 0< / span > < span class = cF0 > , < / span > < span class = cF1 > sizeof< / span > < span class = cF7 > (< / span > < span class = cF0 > CE1000< / span > < span class = cF7 > )< / span > < span class = cF0 > ); < / span > < span class = cF2 > // e1000 global var will hold member data the driver uses often.< / span > < span class = cF0 >
< a name = "l459" > < / a > < / span > < span class = cF6 > " \nE1000 driver WIP\n\n" < / span > < span class = cF0 > ;
< a name = "l460" > < / a >
< a name = "l461" > < / a > e1000.pci = E1000PCIDevFind;
< a name = "l462" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (!e1000.pci)
< a name = "l463" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > ; < / span > < span class = cF2 > // if we don't find the card, quit.< / span > < span class = cF0 >
< a name = "l464" > < / a >
< a name = "l465" > < / a >
< a name = "l466" > < / a > e1000.mmio_address = < / span > < span class = cFB > dev< / span > < span class = cF0 > .uncached_alias + e1000.pci-> base[< / span > < span class = cFE > 0< / span > < span class = cF0 > ] & ~< / span > < span class = cFE > 0xF< / span > < span class = cF0 > ;
< a name = "l467" > < / a > < / span > < span class = cF2 > // Assuming card supports MMIO... lower 4 bits are hardwired zero (?)< / span > < span class = cF0 >
< a name = "l468" > < / a >
< a name = "l469" > < / a > < / span > < span class = cF6 > " \nMMIO address: 0x%0X\n" < / span > < span class = cF0 > , e1000.mmio_address;
< a name = "l470" > < / a >
< a name = "l471" > < / a > < / span > < span class = cF2 > // init rx/tx addrs? (linux)< / span > < span class = cF0 >
< a name = "l472" > < / a >
< a name = "l473" > < / a > < / span > < span class = cF2 > // eeprom? MAC ?< / span > < span class = cF0 >
< a name = "l474" > < / a > E1000MACGet;
< a name = "l475" > < / a >
< a name = "l476" > < / a > < / span > < span class = cF2 > // setup link? (01000101's driver)< / span > < span class = cF0 >
< a name = "l477" > < / a > E1000MMIOWrite(E1000_REG_CTRL, E1000MMIORead< / span > < span class = cF7 > (< / span > < span class = cF0 > E1000_REG_CTRL< / span > < span class = cF7 > )< / span > < span class = cF0 > | E1000_CTRLF_SLU);
< a name = "l478" > < / a >
< a name = "l479" > < / a > < / span > < span class = cF2 > // zero out multicast hash? (linux)< / span > < span class = cF0 >
< a name = "l480" > < / a > < / span > < span class = cF2 > // zero out multicast table array (01000101's driver)< / span > < span class = cF0 >
< a name = "l481" > < / a > < / span > < span class = cF1 > for< / span > < span class = cF0 > (i = < / span > < span class = cFE > 0< / span > < span class = cF0 > ; i < < / span > < span class = cFE > 128< / span > < span class = cF0 > ; i++)
< a name = "l482" > < / a > E1000MMIOWrite(E1000_REG_MTA + i*< / span > < span class = cFE > 4< / span > < span class = cF0 > , < / span > < span class = cFE > 0< / span > < span class = cF0 > );
< a name = "l483" > < / a >
< a name = "l484" > < / a > < / span > < span class = cF2 > // setup link? (linux)< / span > < span class = cF0 >
< a name = "l485" > < / a >
< a name = "l486" > < / a > < / span > < span class = cF2 > // clear all statistics regs after link establish attempt (linux)< / span > < span class = cF0 >
< a name = "l487" > < / a >
< a name = "l488" > < / a > < / span > < span class = cF2 > // enable & clear existing interupts (01000101's driver)< / span > < span class = cF0 >
< a name = "l489" > < / a > E1000MMIOWrite(E1000_REG_IMS, < / span > < span class = cFE > 0x1F6DC< / span > < span class = cF0 > ); < / span > < span class = cF2 > // TODO: WHAT IS THIS< / span > < span class = cF0 >
< a name = "l490" > < / a > E1000MMIORead(< / span > < span class = cFE > 0xC0< / span > < span class = cF0 > ); < / span > < span class = cF2 > // TODO : WHAT IS THIS ???< / span > < span class = cF0 >
< a name = "l491" > < / a >
< a name = "l492" > < / a > < / span > < span class = cF2 > // start rx tx?< / span > < span class = cF0 >
< a name = "l493" > < / a > E1000InitRX;
< a name = "l494" > < / a > E1000InitTX;
< a name = "l495" > < / a >
< a name = "l496" > < / a > E1000InterruptsSetup;
< a name = "l497" > < / a >
< a name = "l498" > < / a >
< a name = "l499" > < / a > NetErr(< / span > < span class = cF6 > " TODO E1000" < / span > < span class = cF0 > );
< a name = "l500" > < / a > < / span > < span class = cF6 > " \n" < / span > < span class = cF0 > ;
< a name = "l501" > < / a > < / span > < span class = cF5 > ClassRep< / span > < span class = cF0 > (& e1000);
< a name = "l502" > < / a > }
< a name = "l503" > < / a >
< a name = "l504" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > EthernetFrameAllocate(< / span > < span class = cF1 > U8< / span > < span class = cF0 > **packet_buffer_out,
< a name = "l505" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *source_address,
< a name = "l506" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *destination_address,
< a name = "l507" > < / a > < / span > < span class = cF9 > U16< / span > < span class = cF0 > ethertype,
< a name = "l508" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > packet_length)
< a name = "l509" > < / a > {
< a name = "l510" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *ethernet_frame;
< a name = "l511" > < / a > < / span > < span class = cF9 > I64< / span > < span class = cF0 > de_index;
< a name = "l512" > < / a >
< a name = "l513" > < / a > < / span > < span class = cF2 > //need to see if 3 years later VirtualBox supports APAD_XMT!< / span > < span class = cF0 >
< a name = "l514" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (packet_length < ETHERNET_MIN_FRAME_SIZE)
< a name = "l515" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l516" > < / a > NetWarn(< / span > < span class = cF6 > " ETHERNET FRAME ALLOCATE: Truncating length" < / span > < span class = cF0 > );
< a name = "l517" > < / a > packet_length = ETHERNET_MIN_FRAME_SIZE;
< a name = "l518" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l519" > < / a >
< a name = "l520" > < / a > de_index = E1000TransmitPacketAllocate(& ethernet_frame, ETHERNET_MAC_HEADER_LENGTH + packet_length);
< a name = "l521" > < / a >
< a name = "l522" > < / a > < / span > < span class = cF1 > if< / span > < span class = cF0 > (de_index < < / span > < span class = cFE > 0< / span > < span class = cF0 > )
< a name = "l523" > < / a > < / span > < span class = cF7 > {< / span > < span class = cF0 >
< a name = "l524" > < / a > NetErr(< / span > < span class = cF6 > " ETHERNET FRAME ALLOCATE: Failure" < / span > < span class = cF0 > );
< a name = "l525" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > -< / span > < span class = cFE > 1< / span > < span class = cF0 > ; < / span > < span class = cF2 > // Positive value expected. Functions calling this must factor this in.< / span > < span class = cF0 >
< a name = "l526" > < / a > < / span > < span class = cF7 > }< / span > < span class = cF0 >
< a name = "l527" > < / a >
< a name = "l528" > < / a > < / span > < span class = cF5 > MemCopy< / span > < span class = cF0 > (ethernet_frame, destination_address, MAC_ADDRESS_LENGTH);
< a name = "l529" > < / a > < / span > < span class = cF5 > MemCopy< / span > < span class = cF0 > (ethernet_frame + MAC_ADDRESS_LENGTH, source_address, MAC_ADDRESS_LENGTH);
< a name = "l530" > < / a >
< a name = "l531" > < / a > ethernet_frame[ETHERNET_ETHERTYPE_OFFSET] = ethertype > > < / span > < span class = cFE > 8< / span > < span class = cF0 > ;
< a name = "l532" > < / a > ethernet_frame[ETHERNET_ETHERTYPE_OFFSET + < / span > < span class = cFE > 1< / span > < span class = cF0 > ] = ethertype & < / span > < span class = cFE > 0xFF< / span > < span class = cF0 > ;
< a name = "l533" > < / a >
< a name = "l534" > < / a > *packet_buffer_out = ethernet_frame + ETHERNET_MAC_HEADER_LENGTH;
< a name = "l535" > < / a >
< a name = "l536" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > de_index;
< a name = "l537" > < / a >
< a name = "l538" > < / a > }
< a name = "l539" > < / a >
< a name = "l540" > < / a > < / span > < span class = cF1 > U8< / span > < span class = cF0 > *EthernetMACGet()
< a name = "l541" > < / a > {
< a name = "l542" > < / a > < / span > < span class = cF1 > return< / span > < span class = cF0 > e1000.mac_address;
< a name = "l543" > < / a > }
< a name = "l544" > < / a >
< a name = "l545" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > NetStop()
< a name = "l546" > < / a > {
< a name = "l547" > < / a >
< a name = "l548" > < / a > }
< a name = "l549" > < / a >
< a name = "l550" > < / a > < / span > < span class = cF1 > U0< / span > < span class = cF0 > NetStart()
< a name = "l551" > < / a > {
< a name = "l552" > < / a >
< a name = "l553" > < / a > }
< a name = "l554" > < / a >
< a name = "l555" > < / a > E1000Init;< / span > < / pre > < / body >
2021-07-06 21:15:26 +01:00
< / html >