if_ed_sic.c revision 330897
1/*- 2 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD 3 * 4 * Copyright (c) 2005, M. Warner Losh 5 * All rights reserved. 6 * Copyright (c) 1995, David Greenman 7 * All rights reserved. 8 * 9 * Redistribution and use in source and binary forms, with or without 10 * modification, are permitted provided that the following conditions 11 * are met: 12 * 1. Redistributions of source code must retain the above copyright 13 * notice unmodified, this list of conditions, and the following 14 * disclaimer. 15 * 2. Redistributions in binary form must reproduce the above copyright 16 * notice, this list of conditions and the following disclaimer in the 17 * documentation and/or other materials provided with the distribution. 18 * 19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 * SUCH DAMAGE. 30 */ 31 32#include <sys/cdefs.h> 33__FBSDID("$FreeBSD: stable/11/sys/dev/ed/if_ed_sic.c 330897 2018-03-14 03:19:51Z eadler $"); 34 35#include "opt_ed.h" 36 37#ifdef ED_SIC 38#include <sys/param.h> 39#include <sys/systm.h> 40#include <sys/sockio.h> 41#include <sys/mbuf.h> 42#include <sys/kernel.h> 43#include <sys/socket.h> 44#include <sys/syslog.h> 45 46#include <sys/bus.h> 47 48#include <machine/bus.h> 49#include <sys/rman.h> 50#include <machine/resource.h> 51 52#include <net/ethernet.h> 53#include <net/if.h> 54#include <net/if_arp.h> 55#include <net/if_dl.h> 56#include <net/if_mib.h> 57#include <net/if_media.h> 58 59#include <net/bpf.h> 60 61#include <dev/ed/if_edreg.h> 62#include <dev/ed/if_edvar.h> 63 64/* 65 * Probe and vendor-specific initialization routine for SIC boards 66 */ 67int 68ed_probe_SIC(device_t dev, int port_rid, int flags) 69{ 70 struct ed_softc *sc = device_get_softc(dev); 71 int error; 72 int i; 73 u_int memsize; 74 u_long pmem; 75 u_char sum; 76 77 error = ed_alloc_port(dev, 0, ED_SIC_IO_PORTS); 78 if (error) 79 return (error); 80 81 sc->asic_offset = ED_SIC_ASIC_OFFSET; 82 sc->nic_offset = ED_SIC_NIC_OFFSET; 83 84 memsize = 16384; 85 /* XXX Needs to allow different msize */ 86 error = ed_alloc_memory(dev, 0, memsize); 87 if (error) 88 return (error); 89 90 sc->mem_start = 0; 91 sc->mem_size = memsize; 92 93 pmem = rman_get_start(sc->mem_res); 94 error = ed_isa_mem_ok(dev, pmem, memsize); 95 if (error) 96 return (error); 97 98 /* Reset card to force it into a known state. */ 99 ed_asic_outb(sc, 0, 0x00); 100 DELAY(100); 101 102 /* 103 * Here we check the card ROM, if the checksum passes, and the 104 * type code and ethernet address check out, then we know we have 105 * an SIC card. 106 */ 107 ed_asic_outb(sc, 0, 0x81); 108 DELAY(100); 109 110 sum = bus_space_read_1(sc->mem_bst, sc->mem_bsh, 6); 111 for (i = 0; i < ETHER_ADDR_LEN; i++) 112 sum ^= (sc->enaddr[i] = 113 bus_space_read_1(sc->mem_bst, sc->mem_bsh, i)); 114#ifdef ED_DEBUG 115 device_printf(dev, "ed_probe_sic: got address %6D\n", 116 sc->enaddr, ":"); 117#endif 118 if (sum != 0) 119 return (ENXIO); 120 if ((sc->enaddr[0] | sc->enaddr[1] | sc->enaddr[2]) == 0) 121 return (ENXIO); 122 123 sc->vendor = ED_VENDOR_SIC; 124 sc->type_str = "SIC"; 125 sc->isa16bit = 0; 126 sc->cr_proto = 0; 127 128 /* 129 * SIC RAM page 0x0000-0x3fff(or 0x7fff) 130 */ 131 ed_asic_outb(sc, 0, 0x80); 132 DELAY(100); 133 134 error = ed_clear_memory(dev); 135 if (error) 136 return (error); 137 138 sc->mem_shared = 1; 139 sc->mem_end = sc->mem_start + sc->mem_size; 140 141 /* 142 * allocate one xmit buffer if < 16k, two buffers otherwise 143 */ 144 if ((sc->mem_size < 16384) || (flags & ED_FLAGS_NO_MULTI_BUFFERING)) 145 sc->txb_cnt = 1; 146 else 147 sc->txb_cnt = 2; 148 sc->tx_page_start = 0; 149 150 sc->rec_page_start = sc->tx_page_start + ED_TXBUF_SIZE * sc->txb_cnt; 151 sc->rec_page_stop = sc->tx_page_start + sc->mem_size / ED_PAGE_SIZE; 152 153 sc->mem_ring = sc->mem_start + sc->txb_cnt * ED_PAGE_SIZE * ED_TXBUF_SIZE; 154 155 sc->sc_write_mbufs = ed_shmem_write_mbufs; 156 return (0); 157} 158 159#endif /* ED_SIC */ 160