forked from torvalds/linux
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
alx: add a simple AR816x/AR817x device driver
This is a very simple driver, based on the original vendor driver that Qualcomm/Atheros published/submitted previously, but reworked to make the code saner. However, it also lost a number of features (TSO/GSO, VLAN acceleration and multi- queue support) in the process, as well as debugging support features I didn't have any use for. The only thing I left is checksum offload. More features can obviously be added, but this seemed like a good start for having a driver in mainline at all. Johannes Stezenbach has verified that the driver works on AR8161, I have a AR8171 myself. The E2200 device ID I found on github in somebody's repository. Signed-off-by: Johannes Berg <[email protected]> Signed-off-by: David S. Miller <[email protected]>
- Loading branch information
Showing
9 changed files
with
4,568 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
obj-$(CONFIG_ALX) += alx.o | ||
alx-objs := main.o ethtool.o hw.o | ||
ccflags-y += -D__CHECK_ENDIAN__ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,114 @@ | ||
/* | ||
* Copyright (c) 2013 Johannes Berg <[email protected]> | ||
* | ||
* This file is free software: you may copy, redistribute and/or modify it | ||
* under the terms of the GNU General Public License as published by the | ||
* Free Software Foundation, either version 2 of the License, or (at your | ||
* option) any later version. | ||
* | ||
* This file is distributed in the hope that it will be useful, but | ||
* WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
* General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU General Public License | ||
* along with this program. If not, see <http://www.gnu.org/licenses/>. | ||
* | ||
* This file incorporates work covered by the following copyright and | ||
* permission notice: | ||
* | ||
* Copyright (c) 2012 Qualcomm Atheros, Inc. | ||
* | ||
* Permission to use, copy, modify, and/or distribute this software for any | ||
* purpose with or without fee is hereby granted, provided that the above | ||
* copyright notice and this permission notice appear in all copies. | ||
* | ||
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||
*/ | ||
|
||
#ifndef _ALX_H_ | ||
#define _ALX_H_ | ||
|
||
#include <linux/types.h> | ||
#include <linux/etherdevice.h> | ||
#include <linux/dma-mapping.h> | ||
#include <linux/spinlock.h> | ||
#include "hw.h" | ||
|
||
#define ALX_WATCHDOG_TIME (5 * HZ) | ||
|
||
struct alx_buffer { | ||
struct sk_buff *skb; | ||
DEFINE_DMA_UNMAP_ADDR(dma); | ||
DEFINE_DMA_UNMAP_LEN(size); | ||
}; | ||
|
||
struct alx_rx_queue { | ||
struct alx_rrd *rrd; | ||
dma_addr_t rrd_dma; | ||
|
||
struct alx_rfd *rfd; | ||
dma_addr_t rfd_dma; | ||
|
||
struct alx_buffer *bufs; | ||
|
||
u16 write_idx, read_idx; | ||
u16 rrd_read_idx; | ||
}; | ||
#define ALX_RX_ALLOC_THRESH 32 | ||
|
||
struct alx_tx_queue { | ||
struct alx_txd *tpd; | ||
dma_addr_t tpd_dma; | ||
struct alx_buffer *bufs; | ||
u16 write_idx, read_idx; | ||
}; | ||
|
||
#define ALX_DEFAULT_TX_WORK 128 | ||
|
||
enum alx_device_quirks { | ||
ALX_DEV_QUIRK_MSI_INTX_DISABLE_BUG = BIT(0), | ||
}; | ||
|
||
struct alx_priv { | ||
struct net_device *dev; | ||
|
||
struct alx_hw hw; | ||
|
||
/* all descriptor memory */ | ||
struct { | ||
dma_addr_t dma; | ||
void *virt; | ||
int size; | ||
} descmem; | ||
|
||
/* protect int_mask updates */ | ||
spinlock_t irq_lock; | ||
u32 int_mask; | ||
|
||
int tx_ringsz; | ||
int rx_ringsz; | ||
int rxbuf_size; | ||
|
||
struct napi_struct napi; | ||
struct alx_tx_queue txq; | ||
struct alx_rx_queue rxq; | ||
|
||
struct work_struct link_check_wk; | ||
struct work_struct reset_wk; | ||
|
||
u16 msg_enable; | ||
|
||
bool msi; | ||
}; | ||
|
||
extern const struct ethtool_ops alx_ethtool_ops; | ||
extern const char alx_drv_name[]; | ||
|
||
#endif |
Oops, something went wrong.