#
331722 |
|
29-Mar-2018 |
eadler |
Revert r330897:
This was intended to be a non-functional change. It wasn't. The commit message was thus wrong. In addition it broke arm, and merged crypto related code.
Revert with prejudice.
This revert skips files touched in r316370 since that commit was since MFCed. This revert also skips files that require $FreeBSD$ property changes.
Thank you to those who helped me get out of this mess including but not limited to gonzo, kevans, rgrimes.
Requested by: gjb (re)
|
#
330897 |
|
14-Mar-2018 |
eadler |
Partial merge of the SPDX changes
These changes are incomplete but are making it difficult to determine what other changes can/should be merged.
No objections from: pfg
|
#
302408 |
|
07-Jul-2016 |
gjb |
Copy head@r302406 to stable/11 as part of the 11.0-RELEASE cycle. Prune svn:mergeinfo from the new branch, as nothing has been merged here.
Additional commits post-branch will follow.
Approved by: re (implicit) Sponsored by: The FreeBSD Foundation |
#
297793 |
|
10-Apr-2016 |
pfg |
Cleanup unnecessary semicolons from the kernel.
Found with devel/coccinelle.
|
#
292738 |
|
26-Dec-2015 |
adrian |
[mdio] migrate mdiobus out of etherswitch and into a top-level device of its own.
The mdio driver interface is generally useful for devices that require MDIO without the full MII bus interface. This lifts the driver/interface out of etherswitch(4), and adds a mdio(4) man page.
Submitted by: Landon Fuller <landon@landonf.org> Differential Revision: https://reviews.freebsd.org/D4606
|
#
279797 |
|
08-Mar-2015 |
adrian |
Methodise a couple more of the VLAN methods.
|
#
279790 |
|
08-Mar-2015 |
adrian |
Add per-port vlan support for the AR8327.
All the per-port support is really doing is applying a port visibility mask to each of the switchports. Everything still look like a single portgroup (vlan id 1), but the per-port visibility mask is modified.
Whilst I'm here, also add some initial dot1q support - the pvid stuff is doing the right thing, but it's not useful without the rest of the VLAN table programming.
It's enough for me to be able to use the LAN/WAN port distinction on the AP135, where there isn't (for now!) a dedicated PHY for the "WAN" port.
Tested:
* AP135, QCA9558 SoC + AR8327 switch
|
#
279767 |
|
08-Mar-2015 |
adrian |
Fix up support for the AR8327.
* Even though I got the registers around "right", it seems I'm not tickling the MDIO access correctly for the internal PHY bus. Some of the switches are fine poking at the external PHY registers; others aren't. So, enable direct PHY bus access for the AR8327, and leave the existing code in place for the others.
* Go and shuffle the register access around. Whilst here, restore the 2ms delay if changing page.
* Comment out some of the stub printf()s; there's some upcoming work to add port VLAN support.
Tested:
* AP135 development board * Carambola2 - AR9331 SoC
|
#
269147 |
|
26-Jul-2014 |
adrian |
Add another revision of the AR8327.
|
#
268564 |
|
12-Jul-2014 |
rpaulo |
Revert r268543.
We should probably fix sys/gpio.h instead.
|
#
268543 |
|
11-Jul-2014 |
rpaulo |
Move iic.h to sys/ so that it's automatically installed in /usr/include/sys.
This lets us call iic(4) ioctls without needing the kernel source code and follows the same model of GPIO.
MFC after: 3 weeks
|
#
262681 |
|
02-Mar-2014 |
adrian |
Add ATU flush support.
The OpenWRT AR8xxx switch support flushes the ATU (address translation unit) after each port link 'up' status change. I've modified this to just flush on any port transition.
Whilst here, bump the number of ports on the AR8327 to 6, rather than the default of 5. It's DB120 specific; I'll go and make this configurable later.
There's some debugging code in here still; I am still debugging whether this is or isn't working fully.
Tested:
* DB120, AR9344 + AR8327 switch
Obtained from: OpenWRT
|
#
262431 |
|
24-Feb-2014 |
adrian |
Link the AR8327 to the build.
|
#
262429 |
|
24-Feb-2014 |
adrian |
Methodize the arswitch VLAN routines.
These differ per chipset family in subtle and evil ways.
It becomes very noticable on the AR8327 where the layout is just plain wrong.
|
#
262208 |
|
19-Feb-2014 |
adrian |
Extract out the port VLAN flags/setup code and throw it into two new HAL methods.
This allows the AR8327 code to override it as appropriate.
Tested:
* DB120 - AR8327 and AR9340 on-board switch; only running 'etherswitchcfg' to check configs. The actual VLAN programming wasn't tested.
|
#
262206 |
|
19-Feb-2014 |
adrian |
Turn the port init function into a HAL method and initialise it to the default port init code.
This needs to be overridden for the AR8327.
|
#
262203 |
|
19-Feb-2014 |
adrian |
Change arswitch_ports_init() to arswitch_port_init(), and teach it to take a single port to setup.
This may end up later being used as part of some logic to program the PHY for a single port, rather than having to reinitialise them all at once.
Tested:
* DB120
|
#
262202 |
|
19-Feb-2014 |
adrian |
Add in the AR8327 probe/attach code and switch type.
It detects fine, but (as expected) it won't attach just yet, let alone pass traffic.
Tested:
* DB120, AR8327 switch
|
#
262201 |
|
19-Feb-2014 |
adrian |
Store away the chip version and revision; some AR8327 code depends upon the chip revision.
|
#
257284 |
|
28-Oct-2013 |
glebius |
- Provide necessary includes, that before came via if.h pollution. - Remove unnecessary ones.
Sponsored by: Netflix Sponsored by: Nginx, Inc.
|
#
256582 |
|
16-Oct-2013 |
adrian |
Add support for the AR9340 switch to the switch framework.
* Do the hardware setup in the right order! * Modify/improve the chip probe check so it can actually probe the 7240/9340 directly (although it's not yet used..) * Initialise and fetch the is_mii option * Fix some debugging whilst I'm here.
This is enough to get things off the ground.
Tested:
* AR9344 SoC
|
#
253572 |
|
23-Jul-2013 |
loos |
Add the support for 802.1q and port based vlans for arswitch.
Tested on: RB450G (standalone ar8316), RSPRO (standalone ar8316) and TPLink MR-3220 (ar724x integrated switch).
Approved by: adrian (mentor) Obtained from: zrouter
|
#
250383 |
|
08-May-2013 |
adrian |
Correctly mark the CPU port.
Submitted by: Luiz Otavio O Souza <loos.br@gmail.com> Reviewed by: ray
|
#
249775 |
|
22-Apr-2013 |
adrian |
Update arswitch to the new API.
|
#
242716 |
|
07-Nov-2012 |
ray |
Disable automatic attachment of arswitch. It can't be auto-detected (like PHYs do) and cause a problems trying to attach another instance to child mdio.
Submitted by: Luiz Otavio O Souza Approved by: adrian (menthor)
|
#
241578 |
|
15-Oct-2012 |
ray |
Locking for etherswitch framework: * add lock/unlock methods; * add lock/unlock default implementation; * surround switch IOCTLs with locking; * add lock/unlock implementation for arswitch;
Submitted by: Luiz Otavio O Souza Approved by: adrian (mentor)
|
#
241577 |
|
15-Oct-2012 |
ray |
Defaulting to id "0" if ar7240_probe(dev) success, fix warning when building with DEBUG.
Submitted by: Luiz Otavio O Souza Approved by: adrian (mentor)
|
#
235377 |
|
12-May-2012 |
adrian |
Setup the CPU port and broadcast map on the AR7240, rather than depending upon the bootloader initialising it.
The aim is to eventually support a full switch set and reinitialisation rather than relying on a consistent bootloader setup.
Remove the port flood config from arswitch.c, it's not yet used and it's totally incorrect.
Whilst I'm here, also add in a comment describing why the full switch reset is disabled.
Obtained from: Linux (OpenWRT) - Values
|
#
235323 |
|
12-May-2012 |
adrian |
Further arswitch work:
* Add in the AR724x support. It probes the same as an AR8216/AR8316, so just add in a hint to force the probe success rather than auto-detecting it.
* Add in the missing entries from conf/files, lacking in the previous commit.
The register values and CPU port / mirror port initialisation value was obtained from Linux OpenWRT ag71xx_ar7240.c.
The DELAY(1000) to let things settle is my local workaround. For some reason, PHY4 doesn't seem to probe very reliably without it. It's quite possible that we're missing some MDIO bus initialisation code in if_arge for the AR724x case. As I dislike DELAY() workarounds in general, it's definitely worth trying to figure out why this is the case.
Tested on: AP93 (AR7240) reference design
Obtained from: Linux OpenWRT
|
#
235288 |
|
11-May-2012 |
adrian |
Commit the first pass of the etherswitch support.
This is designed to support the very basic ethernet switch chip behaviour, specifically:
* accessing switch register space; * accessing per-PHY registers (for switches that actually expose PHYs); * basic vlan group support, which applies for the rtl8366 driver but not for the atheros switches.
This also includes initial support for:
* rtl8366rb support - which is a 10/100/1000 switch which supports vlan groups; * Initial Atheros AR8316 switch support - which is a 10/100/1000 switch which supports an alternate vlan configuration (so the vlan group methods are stubbed.)
The general idea here is that the switch driver may speak to a variety of backend busses (mdio, i2c, spi, whatever) and expose:
* If applicable, one or more MDIO busses which ethernet interfaces can then attach PHYs to via miiproxy/mdioproxy;
* exposes miibusses, one for each port at the moment, so ..
* .. a PHY can be exposed on each miibus, for each switch port, with all of the existing MII/ifnet framework.
However:
* The ifnet is manually created for now, and it isn't linked into the interface list, nor can you (currently) send/receive frames on this ifnet. At some point in the future there may be _some_ support for this, for switches with a multi-port, isolated mode.
* I'm still in the process of sorting out correct(er) locking.
TODO:
* ray's switch code in zrouter (zrouter.org) includes a much more developed newbus API that covers the various switch methods, as well as a capability API so drivers, the switch layer and the userland utility can properly control the subset of supported features.
The plan is to sort that out later, once the rest of ray's switch drivers are brought over and extended to export MII busses and PHYs.
Submitted by: Stefan Bethke <stb@lassitu.de> Reviewed by: ray
|