mirror of
https://github.com/hanwckf/immortalwrt-mt798x.git
synced 2025-01-09 02:43:53 +08:00
Merge Official Source
This commit is contained in:
commit
0b234c70ec
12
COPYING
Normal file
12
COPYING
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
OpenWrt is provided under:
|
||||||
|
|
||||||
|
SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
|
||||||
|
Being under the terms of the GNU General Public License version 2 only,
|
||||||
|
according with:
|
||||||
|
|
||||||
|
LICENSES/GPL-2.0
|
||||||
|
|
||||||
|
In addition, other licenses may also apply.
|
||||||
|
|
||||||
|
All contributions to OpenWrt are subject to this COPYING file.
|
674
LICENSE
674
LICENSE
@ -1,674 +0,0 @@
|
|||||||
GNU GENERAL PUBLIC LICENSE
|
|
||||||
Version 3, 29 June 2007
|
|
||||||
|
|
||||||
Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/>
|
|
||||||
Everyone is permitted to copy and distribute verbatim copies
|
|
||||||
of this license document, but changing it is not allowed.
|
|
||||||
|
|
||||||
Preamble
|
|
||||||
|
|
||||||
The GNU General Public License is a free, copyleft license for
|
|
||||||
software and other kinds of works.
|
|
||||||
|
|
||||||
The licenses for most software and other practical works are designed
|
|
||||||
to take away your freedom to share and change the works. By contrast,
|
|
||||||
the GNU General Public License is intended to guarantee your freedom to
|
|
||||||
share and change all versions of a program--to make sure it remains free
|
|
||||||
software for all its users. We, the Free Software Foundation, use the
|
|
||||||
GNU General Public License for most of our software; it applies also to
|
|
||||||
any other work released this way by its authors. You can apply it to
|
|
||||||
your programs, too.
|
|
||||||
|
|
||||||
When we speak of free software, we are referring to freedom, not
|
|
||||||
price. Our General Public Licenses are designed to make sure that you
|
|
||||||
have the freedom to distribute copies of free software (and charge for
|
|
||||||
them if you wish), that you receive source code or can get it if you
|
|
||||||
want it, that you can change the software or use pieces of it in new
|
|
||||||
free programs, and that you know you can do these things.
|
|
||||||
|
|
||||||
To protect your rights, we need to prevent others from denying you
|
|
||||||
these rights or asking you to surrender the rights. Therefore, you have
|
|
||||||
certain responsibilities if you distribute copies of the software, or if
|
|
||||||
you modify it: responsibilities to respect the freedom of others.
|
|
||||||
|
|
||||||
For example, if you distribute copies of such a program, whether
|
|
||||||
gratis or for a fee, you must pass on to the recipients the same
|
|
||||||
freedoms that you received. You must make sure that they, too, receive
|
|
||||||
or can get the source code. And you must show them these terms so they
|
|
||||||
know their rights.
|
|
||||||
|
|
||||||
Developers that use the GNU GPL protect your rights with two steps:
|
|
||||||
(1) assert copyright on the software, and (2) offer you this License
|
|
||||||
giving you legal permission to copy, distribute and/or modify it.
|
|
||||||
|
|
||||||
For the developers' and authors' protection, the GPL clearly explains
|
|
||||||
that there is no warranty for this free software. For both users' and
|
|
||||||
authors' sake, the GPL requires that modified versions be marked as
|
|
||||||
changed, so that their problems will not be attributed erroneously to
|
|
||||||
authors of previous versions.
|
|
||||||
|
|
||||||
Some devices are designed to deny users access to install or run
|
|
||||||
modified versions of the software inside them, although the manufacturer
|
|
||||||
can do so. This is fundamentally incompatible with the aim of
|
|
||||||
protecting users' freedom to change the software. The systematic
|
|
||||||
pattern of such abuse occurs in the area of products for individuals to
|
|
||||||
use, which is precisely where it is most unacceptable. Therefore, we
|
|
||||||
have designed this version of the GPL to prohibit the practice for those
|
|
||||||
products. If such problems arise substantially in other domains, we
|
|
||||||
stand ready to extend this provision to those domains in future versions
|
|
||||||
of the GPL, as needed to protect the freedom of users.
|
|
||||||
|
|
||||||
Finally, every program is threatened constantly by software patents.
|
|
||||||
States should not allow patents to restrict development and use of
|
|
||||||
software on general-purpose computers, but in those that do, we wish to
|
|
||||||
avoid the special danger that patents applied to a free program could
|
|
||||||
make it effectively proprietary. To prevent this, the GPL assures that
|
|
||||||
patents cannot be used to render the program non-free.
|
|
||||||
|
|
||||||
The precise terms and conditions for copying, distribution and
|
|
||||||
modification follow.
|
|
||||||
|
|
||||||
TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
0. Definitions.
|
|
||||||
|
|
||||||
"This License" refers to version 3 of the GNU General Public License.
|
|
||||||
|
|
||||||
"Copyright" also means copyright-like laws that apply to other kinds of
|
|
||||||
works, such as semiconductor masks.
|
|
||||||
|
|
||||||
"The Program" refers to any copyrightable work licensed under this
|
|
||||||
License. Each licensee is addressed as "you". "Licensees" and
|
|
||||||
"recipients" may be individuals or organizations.
|
|
||||||
|
|
||||||
To "modify" a work means to copy from or adapt all or part of the work
|
|
||||||
in a fashion requiring copyright permission, other than the making of an
|
|
||||||
exact copy. The resulting work is called a "modified version" of the
|
|
||||||
earlier work or a work "based on" the earlier work.
|
|
||||||
|
|
||||||
A "covered work" means either the unmodified Program or a work based
|
|
||||||
on the Program.
|
|
||||||
|
|
||||||
To "propagate" a work means to do anything with it that, without
|
|
||||||
permission, would make you directly or secondarily liable for
|
|
||||||
infringement under applicable copyright law, except executing it on a
|
|
||||||
computer or modifying a private copy. Propagation includes copying,
|
|
||||||
distribution (with or without modification), making available to the
|
|
||||||
public, and in some countries other activities as well.
|
|
||||||
|
|
||||||
To "convey" a work means any kind of propagation that enables other
|
|
||||||
parties to make or receive copies. Mere interaction with a user through
|
|
||||||
a computer network, with no transfer of a copy, is not conveying.
|
|
||||||
|
|
||||||
An interactive user interface displays "Appropriate Legal Notices"
|
|
||||||
to the extent that it includes a convenient and prominently visible
|
|
||||||
feature that (1) displays an appropriate copyright notice, and (2)
|
|
||||||
tells the user that there is no warranty for the work (except to the
|
|
||||||
extent that warranties are provided), that licensees may convey the
|
|
||||||
work under this License, and how to view a copy of this License. If
|
|
||||||
the interface presents a list of user commands or options, such as a
|
|
||||||
menu, a prominent item in the list meets this criterion.
|
|
||||||
|
|
||||||
1. Source Code.
|
|
||||||
|
|
||||||
The "source code" for a work means the preferred form of the work
|
|
||||||
for making modifications to it. "Object code" means any non-source
|
|
||||||
form of a work.
|
|
||||||
|
|
||||||
A "Standard Interface" means an interface that either is an official
|
|
||||||
standard defined by a recognized standards body, or, in the case of
|
|
||||||
interfaces specified for a particular programming language, one that
|
|
||||||
is widely used among developers working in that language.
|
|
||||||
|
|
||||||
The "System Libraries" of an executable work include anything, other
|
|
||||||
than the work as a whole, that (a) is included in the normal form of
|
|
||||||
packaging a Major Component, but which is not part of that Major
|
|
||||||
Component, and (b) serves only to enable use of the work with that
|
|
||||||
Major Component, or to implement a Standard Interface for which an
|
|
||||||
implementation is available to the public in source code form. A
|
|
||||||
"Major Component", in this context, means a major essential component
|
|
||||||
(kernel, window system, and so on) of the specific operating system
|
|
||||||
(if any) on which the executable work runs, or a compiler used to
|
|
||||||
produce the work, or an object code interpreter used to run it.
|
|
||||||
|
|
||||||
The "Corresponding Source" for a work in object code form means all
|
|
||||||
the source code needed to generate, install, and (for an executable
|
|
||||||
work) run the object code and to modify the work, including scripts to
|
|
||||||
control those activities. However, it does not include the work's
|
|
||||||
System Libraries, or general-purpose tools or generally available free
|
|
||||||
programs which are used unmodified in performing those activities but
|
|
||||||
which are not part of the work. For example, Corresponding Source
|
|
||||||
includes interface definition files associated with source files for
|
|
||||||
the work, and the source code for shared libraries and dynamically
|
|
||||||
linked subprograms that the work is specifically designed to require,
|
|
||||||
such as by intimate data communication or control flow between those
|
|
||||||
subprograms and other parts of the work.
|
|
||||||
|
|
||||||
The Corresponding Source need not include anything that users
|
|
||||||
can regenerate automatically from other parts of the Corresponding
|
|
||||||
Source.
|
|
||||||
|
|
||||||
The Corresponding Source for a work in source code form is that
|
|
||||||
same work.
|
|
||||||
|
|
||||||
2. Basic Permissions.
|
|
||||||
|
|
||||||
All rights granted under this License are granted for the term of
|
|
||||||
copyright on the Program, and are irrevocable provided the stated
|
|
||||||
conditions are met. This License explicitly affirms your unlimited
|
|
||||||
permission to run the unmodified Program. The output from running a
|
|
||||||
covered work is covered by this License only if the output, given its
|
|
||||||
content, constitutes a covered work. This License acknowledges your
|
|
||||||
rights of fair use or other equivalent, as provided by copyright law.
|
|
||||||
|
|
||||||
You may make, run and propagate covered works that you do not
|
|
||||||
convey, without conditions so long as your license otherwise remains
|
|
||||||
in force. You may convey covered works to others for the sole purpose
|
|
||||||
of having them make modifications exclusively for you, or provide you
|
|
||||||
with facilities for running those works, provided that you comply with
|
|
||||||
the terms of this License in conveying all material for which you do
|
|
||||||
not control copyright. Those thus making or running the covered works
|
|
||||||
for you must do so exclusively on your behalf, under your direction
|
|
||||||
and control, on terms that prohibit them from making any copies of
|
|
||||||
your copyrighted material outside their relationship with you.
|
|
||||||
|
|
||||||
Conveying under any other circumstances is permitted solely under
|
|
||||||
the conditions stated below. Sublicensing is not allowed; section 10
|
|
||||||
makes it unnecessary.
|
|
||||||
|
|
||||||
3. Protecting Users' Legal Rights From Anti-Circumvention Law.
|
|
||||||
|
|
||||||
No covered work shall be deemed part of an effective technological
|
|
||||||
measure under any applicable law fulfilling obligations under article
|
|
||||||
11 of the WIPO copyright treaty adopted on 20 December 1996, or
|
|
||||||
similar laws prohibiting or restricting circumvention of such
|
|
||||||
measures.
|
|
||||||
|
|
||||||
When you convey a covered work, you waive any legal power to forbid
|
|
||||||
circumvention of technological measures to the extent such circumvention
|
|
||||||
is effected by exercising rights under this License with respect to
|
|
||||||
the covered work, and you disclaim any intention to limit operation or
|
|
||||||
modification of the work as a means of enforcing, against the work's
|
|
||||||
users, your or third parties' legal rights to forbid circumvention of
|
|
||||||
technological measures.
|
|
||||||
|
|
||||||
4. Conveying Verbatim Copies.
|
|
||||||
|
|
||||||
You may convey verbatim copies of the Program's source code as you
|
|
||||||
receive it, in any medium, provided that you conspicuously and
|
|
||||||
appropriately publish on each copy an appropriate copyright notice;
|
|
||||||
keep intact all notices stating that this License and any
|
|
||||||
non-permissive terms added in accord with section 7 apply to the code;
|
|
||||||
keep intact all notices of the absence of any warranty; and give all
|
|
||||||
recipients a copy of this License along with the Program.
|
|
||||||
|
|
||||||
You may charge any price or no price for each copy that you convey,
|
|
||||||
and you may offer support or warranty protection for a fee.
|
|
||||||
|
|
||||||
5. Conveying Modified Source Versions.
|
|
||||||
|
|
||||||
You may convey a work based on the Program, or the modifications to
|
|
||||||
produce it from the Program, in the form of source code under the
|
|
||||||
terms of section 4, provided that you also meet all of these conditions:
|
|
||||||
|
|
||||||
a) The work must carry prominent notices stating that you modified
|
|
||||||
it, and giving a relevant date.
|
|
||||||
|
|
||||||
b) The work must carry prominent notices stating that it is
|
|
||||||
released under this License and any conditions added under section
|
|
||||||
7. This requirement modifies the requirement in section 4 to
|
|
||||||
"keep intact all notices".
|
|
||||||
|
|
||||||
c) You must license the entire work, as a whole, under this
|
|
||||||
License to anyone who comes into possession of a copy. This
|
|
||||||
License will therefore apply, along with any applicable section 7
|
|
||||||
additional terms, to the whole of the work, and all its parts,
|
|
||||||
regardless of how they are packaged. This License gives no
|
|
||||||
permission to license the work in any other way, but it does not
|
|
||||||
invalidate such permission if you have separately received it.
|
|
||||||
|
|
||||||
d) If the work has interactive user interfaces, each must display
|
|
||||||
Appropriate Legal Notices; however, if the Program has interactive
|
|
||||||
interfaces that do not display Appropriate Legal Notices, your
|
|
||||||
work need not make them do so.
|
|
||||||
|
|
||||||
A compilation of a covered work with other separate and independent
|
|
||||||
works, which are not by their nature extensions of the covered work,
|
|
||||||
and which are not combined with it such as to form a larger program,
|
|
||||||
in or on a volume of a storage or distribution medium, is called an
|
|
||||||
"aggregate" if the compilation and its resulting copyright are not
|
|
||||||
used to limit the access or legal rights of the compilation's users
|
|
||||||
beyond what the individual works permit. Inclusion of a covered work
|
|
||||||
in an aggregate does not cause this License to apply to the other
|
|
||||||
parts of the aggregate.
|
|
||||||
|
|
||||||
6. Conveying Non-Source Forms.
|
|
||||||
|
|
||||||
You may convey a covered work in object code form under the terms
|
|
||||||
of sections 4 and 5, provided that you also convey the
|
|
||||||
machine-readable Corresponding Source under the terms of this License,
|
|
||||||
in one of these ways:
|
|
||||||
|
|
||||||
a) Convey the object code in, or embodied in, a physical product
|
|
||||||
(including a physical distribution medium), accompanied by the
|
|
||||||
Corresponding Source fixed on a durable physical medium
|
|
||||||
customarily used for software interchange.
|
|
||||||
|
|
||||||
b) Convey the object code in, or embodied in, a physical product
|
|
||||||
(including a physical distribution medium), accompanied by a
|
|
||||||
written offer, valid for at least three years and valid for as
|
|
||||||
long as you offer spare parts or customer support for that product
|
|
||||||
model, to give anyone who possesses the object code either (1) a
|
|
||||||
copy of the Corresponding Source for all the software in the
|
|
||||||
product that is covered by this License, on a durable physical
|
|
||||||
medium customarily used for software interchange, for a price no
|
|
||||||
more than your reasonable cost of physically performing this
|
|
||||||
conveying of source, or (2) access to copy the
|
|
||||||
Corresponding Source from a network server at no charge.
|
|
||||||
|
|
||||||
c) Convey individual copies of the object code with a copy of the
|
|
||||||
written offer to provide the Corresponding Source. This
|
|
||||||
alternative is allowed only occasionally and noncommercially, and
|
|
||||||
only if you received the object code with such an offer, in accord
|
|
||||||
with subsection 6b.
|
|
||||||
|
|
||||||
d) Convey the object code by offering access from a designated
|
|
||||||
place (gratis or for a charge), and offer equivalent access to the
|
|
||||||
Corresponding Source in the same way through the same place at no
|
|
||||||
further charge. You need not require recipients to copy the
|
|
||||||
Corresponding Source along with the object code. If the place to
|
|
||||||
copy the object code is a network server, the Corresponding Source
|
|
||||||
may be on a different server (operated by you or a third party)
|
|
||||||
that supports equivalent copying facilities, provided you maintain
|
|
||||||
clear directions next to the object code saying where to find the
|
|
||||||
Corresponding Source. Regardless of what server hosts the
|
|
||||||
Corresponding Source, you remain obligated to ensure that it is
|
|
||||||
available for as long as needed to satisfy these requirements.
|
|
||||||
|
|
||||||
e) Convey the object code using peer-to-peer transmission, provided
|
|
||||||
you inform other peers where the object code and Corresponding
|
|
||||||
Source of the work are being offered to the general public at no
|
|
||||||
charge under subsection 6d.
|
|
||||||
|
|
||||||
A separable portion of the object code, whose source code is excluded
|
|
||||||
from the Corresponding Source as a System Library, need not be
|
|
||||||
included in conveying the object code work.
|
|
||||||
|
|
||||||
A "User Product" is either (1) a "consumer product", which means any
|
|
||||||
tangible personal property which is normally used for personal, family,
|
|
||||||
or household purposes, or (2) anything designed or sold for incorporation
|
|
||||||
into a dwelling. In determining whether a product is a consumer product,
|
|
||||||
doubtful cases shall be resolved in favor of coverage. For a particular
|
|
||||||
product received by a particular user, "normally used" refers to a
|
|
||||||
typical or common use of that class of product, regardless of the status
|
|
||||||
of the particular user or of the way in which the particular user
|
|
||||||
actually uses, or expects or is expected to use, the product. A product
|
|
||||||
is a consumer product regardless of whether the product has substantial
|
|
||||||
commercial, industrial or non-consumer uses, unless such uses represent
|
|
||||||
the only significant mode of use of the product.
|
|
||||||
|
|
||||||
"Installation Information" for a User Product means any methods,
|
|
||||||
procedures, authorization keys, or other information required to install
|
|
||||||
and execute modified versions of a covered work in that User Product from
|
|
||||||
a modified version of its Corresponding Source. The information must
|
|
||||||
suffice to ensure that the continued functioning of the modified object
|
|
||||||
code is in no case prevented or interfered with solely because
|
|
||||||
modification has been made.
|
|
||||||
|
|
||||||
If you convey an object code work under this section in, or with, or
|
|
||||||
specifically for use in, a User Product, and the conveying occurs as
|
|
||||||
part of a transaction in which the right of possession and use of the
|
|
||||||
User Product is transferred to the recipient in perpetuity or for a
|
|
||||||
fixed term (regardless of how the transaction is characterized), the
|
|
||||||
Corresponding Source conveyed under this section must be accompanied
|
|
||||||
by the Installation Information. But this requirement does not apply
|
|
||||||
if neither you nor any third party retains the ability to install
|
|
||||||
modified object code on the User Product (for example, the work has
|
|
||||||
been installed in ROM).
|
|
||||||
|
|
||||||
The requirement to provide Installation Information does not include a
|
|
||||||
requirement to continue to provide support service, warranty, or updates
|
|
||||||
for a work that has been modified or installed by the recipient, or for
|
|
||||||
the User Product in which it has been modified or installed. Access to a
|
|
||||||
network may be denied when the modification itself materially and
|
|
||||||
adversely affects the operation of the network or violates the rules and
|
|
||||||
protocols for communication across the network.
|
|
||||||
|
|
||||||
Corresponding Source conveyed, and Installation Information provided,
|
|
||||||
in accord with this section must be in a format that is publicly
|
|
||||||
documented (and with an implementation available to the public in
|
|
||||||
source code form), and must require no special password or key for
|
|
||||||
unpacking, reading or copying.
|
|
||||||
|
|
||||||
7. Additional Terms.
|
|
||||||
|
|
||||||
"Additional permissions" are terms that supplement the terms of this
|
|
||||||
License by making exceptions from one or more of its conditions.
|
|
||||||
Additional permissions that are applicable to the entire Program shall
|
|
||||||
be treated as though they were included in this License, to the extent
|
|
||||||
that they are valid under applicable law. If additional permissions
|
|
||||||
apply only to part of the Program, that part may be used separately
|
|
||||||
under those permissions, but the entire Program remains governed by
|
|
||||||
this License without regard to the additional permissions.
|
|
||||||
|
|
||||||
When you convey a copy of a covered work, you may at your option
|
|
||||||
remove any additional permissions from that copy, or from any part of
|
|
||||||
it. (Additional permissions may be written to require their own
|
|
||||||
removal in certain cases when you modify the work.) You may place
|
|
||||||
additional permissions on material, added by you to a covered work,
|
|
||||||
for which you have or can give appropriate copyright permission.
|
|
||||||
|
|
||||||
Notwithstanding any other provision of this License, for material you
|
|
||||||
add to a covered work, you may (if authorized by the copyright holders of
|
|
||||||
that material) supplement the terms of this License with terms:
|
|
||||||
|
|
||||||
a) Disclaiming warranty or limiting liability differently from the
|
|
||||||
terms of sections 15 and 16 of this License; or
|
|
||||||
|
|
||||||
b) Requiring preservation of specified reasonable legal notices or
|
|
||||||
author attributions in that material or in the Appropriate Legal
|
|
||||||
Notices displayed by works containing it; or
|
|
||||||
|
|
||||||
c) Prohibiting misrepresentation of the origin of that material, or
|
|
||||||
requiring that modified versions of such material be marked in
|
|
||||||
reasonable ways as different from the original version; or
|
|
||||||
|
|
||||||
d) Limiting the use for publicity purposes of names of licensors or
|
|
||||||
authors of the material; or
|
|
||||||
|
|
||||||
e) Declining to grant rights under trademark law for use of some
|
|
||||||
trade names, trademarks, or service marks; or
|
|
||||||
|
|
||||||
f) Requiring indemnification of licensors and authors of that
|
|
||||||
material by anyone who conveys the material (or modified versions of
|
|
||||||
it) with contractual assumptions of liability to the recipient, for
|
|
||||||
any liability that these contractual assumptions directly impose on
|
|
||||||
those licensors and authors.
|
|
||||||
|
|
||||||
All other non-permissive additional terms are considered "further
|
|
||||||
restrictions" within the meaning of section 10. If the Program as you
|
|
||||||
received it, or any part of it, contains a notice stating that it is
|
|
||||||
governed by this License along with a term that is a further
|
|
||||||
restriction, you may remove that term. If a license document contains
|
|
||||||
a further restriction but permits relicensing or conveying under this
|
|
||||||
License, you may add to a covered work material governed by the terms
|
|
||||||
of that license document, provided that the further restriction does
|
|
||||||
not survive such relicensing or conveying.
|
|
||||||
|
|
||||||
If you add terms to a covered work in accord with this section, you
|
|
||||||
must place, in the relevant source files, a statement of the
|
|
||||||
additional terms that apply to those files, or a notice indicating
|
|
||||||
where to find the applicable terms.
|
|
||||||
|
|
||||||
Additional terms, permissive or non-permissive, may be stated in the
|
|
||||||
form of a separately written license, or stated as exceptions;
|
|
||||||
the above requirements apply either way.
|
|
||||||
|
|
||||||
8. Termination.
|
|
||||||
|
|
||||||
You may not propagate or modify a covered work except as expressly
|
|
||||||
provided under this License. Any attempt otherwise to propagate or
|
|
||||||
modify it is void, and will automatically terminate your rights under
|
|
||||||
this License (including any patent licenses granted under the third
|
|
||||||
paragraph of section 11).
|
|
||||||
|
|
||||||
However, if you cease all violation of this License, then your
|
|
||||||
license from a particular copyright holder is reinstated (a)
|
|
||||||
provisionally, unless and until the copyright holder explicitly and
|
|
||||||
finally terminates your license, and (b) permanently, if the copyright
|
|
||||||
holder fails to notify you of the violation by some reasonable means
|
|
||||||
prior to 60 days after the cessation.
|
|
||||||
|
|
||||||
Moreover, your license from a particular copyright holder is
|
|
||||||
reinstated permanently if the copyright holder notifies you of the
|
|
||||||
violation by some reasonable means, this is the first time you have
|
|
||||||
received notice of violation of this License (for any work) from that
|
|
||||||
copyright holder, and you cure the violation prior to 30 days after
|
|
||||||
your receipt of the notice.
|
|
||||||
|
|
||||||
Termination of your rights under this section does not terminate the
|
|
||||||
licenses of parties who have received copies or rights from you under
|
|
||||||
this License. If your rights have been terminated and not permanently
|
|
||||||
reinstated, you do not qualify to receive new licenses for the same
|
|
||||||
material under section 10.
|
|
||||||
|
|
||||||
9. Acceptance Not Required for Having Copies.
|
|
||||||
|
|
||||||
You are not required to accept this License in order to receive or
|
|
||||||
run a copy of the Program. Ancillary propagation of a covered work
|
|
||||||
occurring solely as a consequence of using peer-to-peer transmission
|
|
||||||
to receive a copy likewise does not require acceptance. However,
|
|
||||||
nothing other than this License grants you permission to propagate or
|
|
||||||
modify any covered work. These actions infringe copyright if you do
|
|
||||||
not accept this License. Therefore, by modifying or propagating a
|
|
||||||
covered work, you indicate your acceptance of this License to do so.
|
|
||||||
|
|
||||||
10. Automatic Licensing of Downstream Recipients.
|
|
||||||
|
|
||||||
Each time you convey a covered work, the recipient automatically
|
|
||||||
receives a license from the original licensors, to run, modify and
|
|
||||||
propagate that work, subject to this License. You are not responsible
|
|
||||||
for enforcing compliance by third parties with this License.
|
|
||||||
|
|
||||||
An "entity transaction" is a transaction transferring control of an
|
|
||||||
organization, or substantially all assets of one, or subdividing an
|
|
||||||
organization, or merging organizations. If propagation of a covered
|
|
||||||
work results from an entity transaction, each party to that
|
|
||||||
transaction who receives a copy of the work also receives whatever
|
|
||||||
licenses to the work the party's predecessor in interest had or could
|
|
||||||
give under the previous paragraph, plus a right to possession of the
|
|
||||||
Corresponding Source of the work from the predecessor in interest, if
|
|
||||||
the predecessor has it or can get it with reasonable efforts.
|
|
||||||
|
|
||||||
You may not impose any further restrictions on the exercise of the
|
|
||||||
rights granted or affirmed under this License. For example, you may
|
|
||||||
not impose a license fee, royalty, or other charge for exercise of
|
|
||||||
rights granted under this License, and you may not initiate litigation
|
|
||||||
(including a cross-claim or counterclaim in a lawsuit) alleging that
|
|
||||||
any patent claim is infringed by making, using, selling, offering for
|
|
||||||
sale, or importing the Program or any portion of it.
|
|
||||||
|
|
||||||
11. Patents.
|
|
||||||
|
|
||||||
A "contributor" is a copyright holder who authorizes use under this
|
|
||||||
License of the Program or a work on which the Program is based. The
|
|
||||||
work thus licensed is called the contributor's "contributor version".
|
|
||||||
|
|
||||||
A contributor's "essential patent claims" are all patent claims
|
|
||||||
owned or controlled by the contributor, whether already acquired or
|
|
||||||
hereafter acquired, that would be infringed by some manner, permitted
|
|
||||||
by this License, of making, using, or selling its contributor version,
|
|
||||||
but do not include claims that would be infringed only as a
|
|
||||||
consequence of further modification of the contributor version. For
|
|
||||||
purposes of this definition, "control" includes the right to grant
|
|
||||||
patent sublicenses in a manner consistent with the requirements of
|
|
||||||
this License.
|
|
||||||
|
|
||||||
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
|
||||||
patent license under the contributor's essential patent claims, to
|
|
||||||
make, use, sell, offer for sale, import and otherwise run, modify and
|
|
||||||
propagate the contents of its contributor version.
|
|
||||||
|
|
||||||
In the following three paragraphs, a "patent license" is any express
|
|
||||||
agreement or commitment, however denominated, not to enforce a patent
|
|
||||||
(such as an express permission to practice a patent or covenant not to
|
|
||||||
sue for patent infringement). To "grant" such a patent license to a
|
|
||||||
party means to make such an agreement or commitment not to enforce a
|
|
||||||
patent against the party.
|
|
||||||
|
|
||||||
If you convey a covered work, knowingly relying on a patent license,
|
|
||||||
and the Corresponding Source of the work is not available for anyone
|
|
||||||
to copy, free of charge and under the terms of this License, through a
|
|
||||||
publicly available network server or other readily accessible means,
|
|
||||||
then you must either (1) cause the Corresponding Source to be so
|
|
||||||
available, or (2) arrange to deprive yourself of the benefit of the
|
|
||||||
patent license for this particular work, or (3) arrange, in a manner
|
|
||||||
consistent with the requirements of this License, to extend the patent
|
|
||||||
license to downstream recipients. "Knowingly relying" means you have
|
|
||||||
actual knowledge that, but for the patent license, your conveying the
|
|
||||||
covered work in a country, or your recipient's use of the covered work
|
|
||||||
in a country, would infringe one or more identifiable patents in that
|
|
||||||
country that you have reason to believe are valid.
|
|
||||||
|
|
||||||
If, pursuant to or in connection with a single transaction or
|
|
||||||
arrangement, you convey, or propagate by procuring conveyance of, a
|
|
||||||
covered work, and grant a patent license to some of the parties
|
|
||||||
receiving the covered work authorizing them to use, propagate, modify
|
|
||||||
or convey a specific copy of the covered work, then the patent license
|
|
||||||
you grant is automatically extended to all recipients of the covered
|
|
||||||
work and works based on it.
|
|
||||||
|
|
||||||
A patent license is "discriminatory" if it does not include within
|
|
||||||
the scope of its coverage, prohibits the exercise of, or is
|
|
||||||
conditioned on the non-exercise of one or more of the rights that are
|
|
||||||
specifically granted under this License. You may not convey a covered
|
|
||||||
work if you are a party to an arrangement with a third party that is
|
|
||||||
in the business of distributing software, under which you make payment
|
|
||||||
to the third party based on the extent of your activity of conveying
|
|
||||||
the work, and under which the third party grants, to any of the
|
|
||||||
parties who would receive the covered work from you, a discriminatory
|
|
||||||
patent license (a) in connection with copies of the covered work
|
|
||||||
conveyed by you (or copies made from those copies), or (b) primarily
|
|
||||||
for and in connection with specific products or compilations that
|
|
||||||
contain the covered work, unless you entered into that arrangement,
|
|
||||||
or that patent license was granted, prior to 28 March 2007.
|
|
||||||
|
|
||||||
Nothing in this License shall be construed as excluding or limiting
|
|
||||||
any implied license or other defenses to infringement that may
|
|
||||||
otherwise be available to you under applicable patent law.
|
|
||||||
|
|
||||||
12. No Surrender of Others' Freedom.
|
|
||||||
|
|
||||||
If conditions are imposed on you (whether by court order, agreement or
|
|
||||||
otherwise) that contradict the conditions of this License, they do not
|
|
||||||
excuse you from the conditions of this License. If you cannot convey a
|
|
||||||
covered work so as to satisfy simultaneously your obligations under this
|
|
||||||
License and any other pertinent obligations, then as a consequence you may
|
|
||||||
not convey it at all. For example, if you agree to terms that obligate you
|
|
||||||
to collect a royalty for further conveying from those to whom you convey
|
|
||||||
the Program, the only way you could satisfy both those terms and this
|
|
||||||
License would be to refrain entirely from conveying the Program.
|
|
||||||
|
|
||||||
13. Use with the GNU Affero General Public License.
|
|
||||||
|
|
||||||
Notwithstanding any other provision of this License, you have
|
|
||||||
permission to link or combine any covered work with a work licensed
|
|
||||||
under version 3 of the GNU Affero General Public License into a single
|
|
||||||
combined work, and to convey the resulting work. The terms of this
|
|
||||||
License will continue to apply to the part which is the covered work,
|
|
||||||
but the special requirements of the GNU Affero General Public License,
|
|
||||||
section 13, concerning interaction through a network will apply to the
|
|
||||||
combination as such.
|
|
||||||
|
|
||||||
14. Revised Versions of this License.
|
|
||||||
|
|
||||||
The Free Software Foundation may publish revised and/or new versions of
|
|
||||||
the GNU General Public License from time to time. Such new versions will
|
|
||||||
be similar in spirit to the present version, but may differ in detail to
|
|
||||||
address new problems or concerns.
|
|
||||||
|
|
||||||
Each version is given a distinguishing version number. If the
|
|
||||||
Program specifies that a certain numbered version of the GNU General
|
|
||||||
Public License "or any later version" applies to it, you have the
|
|
||||||
option of following the terms and conditions either of that numbered
|
|
||||||
version or of any later version published by the Free Software
|
|
||||||
Foundation. If the Program does not specify a version number of the
|
|
||||||
GNU General Public License, you may choose any version ever published
|
|
||||||
by the Free Software Foundation.
|
|
||||||
|
|
||||||
If the Program specifies that a proxy can decide which future
|
|
||||||
versions of the GNU General Public License can be used, that proxy's
|
|
||||||
public statement of acceptance of a version permanently authorizes you
|
|
||||||
to choose that version for the Program.
|
|
||||||
|
|
||||||
Later license versions may give you additional or different
|
|
||||||
permissions. However, no additional obligations are imposed on any
|
|
||||||
author or copyright holder as a result of your choosing to follow a
|
|
||||||
later version.
|
|
||||||
|
|
||||||
15. Disclaimer of Warranty.
|
|
||||||
|
|
||||||
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
|
|
||||||
APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT
|
|
||||||
HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY
|
|
||||||
OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
|
|
||||||
THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
||||||
PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM
|
|
||||||
IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF
|
|
||||||
ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
|
|
||||||
|
|
||||||
16. Limitation of Liability.
|
|
||||||
|
|
||||||
IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
|
||||||
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS
|
|
||||||
THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY
|
|
||||||
GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE
|
|
||||||
USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF
|
|
||||||
DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD
|
|
||||||
PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS),
|
|
||||||
EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF
|
|
||||||
SUCH DAMAGES.
|
|
||||||
|
|
||||||
17. Interpretation of Sections 15 and 16.
|
|
||||||
|
|
||||||
If the disclaimer of warranty and limitation of liability provided
|
|
||||||
above cannot be given local legal effect according to their terms,
|
|
||||||
reviewing courts shall apply local law that most closely approximates
|
|
||||||
an absolute waiver of all civil liability in connection with the
|
|
||||||
Program, unless a warranty or assumption of liability accompanies a
|
|
||||||
copy of the Program in return for a fee.
|
|
||||||
|
|
||||||
END OF TERMS AND CONDITIONS
|
|
||||||
|
|
||||||
How to Apply These Terms to Your New Programs
|
|
||||||
|
|
||||||
If you develop a new program, and you want it to be of the greatest
|
|
||||||
possible use to the public, the best way to achieve this is to make it
|
|
||||||
free software which everyone can redistribute and change under these terms.
|
|
||||||
|
|
||||||
To do so, attach the following notices to the program. It is safest
|
|
||||||
to attach them to the start of each source file to most effectively
|
|
||||||
state the exclusion of warranty; and each file should have at least
|
|
||||||
the "copyright" line and a pointer to where the full notice is found.
|
|
||||||
|
|
||||||
<one line to give the program's name and a brief idea of what it does.>
|
|
||||||
Copyright (C) <year> <name of author>
|
|
||||||
|
|
||||||
This program is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU General Public License as published by
|
|
||||||
the Free Software Foundation, either version 3 of the License, or
|
|
||||||
(at your option) any later version.
|
|
||||||
|
|
||||||
This program 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 <https://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
Also add information on how to contact you by electronic and paper mail.
|
|
||||||
|
|
||||||
If the program does terminal interaction, make it output a short
|
|
||||||
notice like this when it starts in an interactive mode:
|
|
||||||
|
|
||||||
<program> Copyright (C) <year> <name of author>
|
|
||||||
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
|
||||||
This is free software, and you are welcome to redistribute it
|
|
||||||
under certain conditions; type `show c' for details.
|
|
||||||
|
|
||||||
The hypothetical commands `show w' and `show c' should show the appropriate
|
|
||||||
parts of the General Public License. Of course, your program's commands
|
|
||||||
might be different; for a GUI interface, you would use an "about box".
|
|
||||||
|
|
||||||
You should also get your employer (if you work as a programmer) or school,
|
|
||||||
if any, to sign a "copyright disclaimer" for the program, if necessary.
|
|
||||||
For more information on this, and how to apply and follow the GNU GPL, see
|
|
||||||
<https://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
The GNU General Public License does not permit incorporating your program
|
|
||||||
into proprietary programs. If your program is a subroutine library, you
|
|
||||||
may consider it more useful to permit linking proprietary applications with
|
|
||||||
the library. If this is what you want to do, use the GNU Lesser General
|
|
||||||
Public License instead of this License. But first, please read
|
|
||||||
<https://www.gnu.org/licenses/why-not-lgpl.html>.
|
|
32
LICENSES/BSD-2-Clause
Normal file
32
LICENSES/BSD-2-Clause
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
Valid-License-Identifier: BSD-2-Clause
|
||||||
|
SPDX-URL: https://spdx.org/licenses/BSD-2-Clause.html
|
||||||
|
Usage-Guide:
|
||||||
|
To use the BSD 2-clause "Simplified" License put the following SPDX
|
||||||
|
tag/value pair into a comment according to the placement guidelines in
|
||||||
|
the licensing rules documentation:
|
||||||
|
SPDX-License-Identifier: BSD-2-Clause
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
Copyright (c) <year> <owner> . All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
36
LICENSES/BSD-3-Clause
Normal file
36
LICENSES/BSD-3-Clause
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
Valid-License-Identifier: BSD-3-Clause
|
||||||
|
SPDX-URL: https://spdx.org/licenses/BSD-3-Clause.html
|
||||||
|
Usage-Guide:
|
||||||
|
To use the BSD 3-clause "New" or "Revised" License put the following SPDX
|
||||||
|
tag/value pair into a comment according to the placement guidelines in
|
||||||
|
the licensing rules documentation:
|
||||||
|
SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
Copyright (c) <year> <owner> . All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are met:
|
||||||
|
|
||||||
|
1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
3. Neither the name of the copyright holder nor the names of its
|
||||||
|
contributors may be used to endorse or promote products derived from this
|
||||||
|
software without specific prior written permission.
|
||||||
|
|
||||||
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
261
LICENSES/GPL-1.0
Normal file
261
LICENSES/GPL-1.0
Normal file
@ -0,0 +1,261 @@
|
|||||||
|
Valid-License-Identifier: GPL-1.0-or-later
|
||||||
|
Valid-License-Identifier: GPL-1.0+
|
||||||
|
SPDX-URL: https://spdx.org/licenses/GPL-1.0.html
|
||||||
|
Usage-Guide:
|
||||||
|
The GNU General Public License (GPL) version 1 should not be used in new
|
||||||
|
code. For existing kernel code the 'or any later version' option is
|
||||||
|
required to be compatible with the general license of the project: GPLv2.
|
||||||
|
To use the license in source code, put the following SPDX tag/value pair
|
||||||
|
into a comment according to the placement guidelines in the licensing
|
||||||
|
rules documentation:
|
||||||
|
SPDX-License-Identifier: GPL-1.0-or-later
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 1, February 1989
|
||||||
|
|
||||||
|
Copyright (C) 1989 Free Software Foundation, Inc.
|
||||||
|
675 Mass Ave, Cambridge, MA 02139, USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The license agreements of most software companies try to keep users
|
||||||
|
at the mercy of those companies. By contrast, our General Public
|
||||||
|
License is intended to guarantee your freedom to share and change free
|
||||||
|
software--to make sure the software is free for all its users. The
|
||||||
|
General Public License applies to the Free Software Foundation's
|
||||||
|
software and to any other program whose authors commit to using it.
|
||||||
|
You can use it for your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Specifically, the General Public License is designed to make
|
||||||
|
sure that you have the freedom to give away or sell copies of free
|
||||||
|
software, that you receive source code or can get it if you want it,
|
||||||
|
that you can change the software or use pieces of it in new free
|
||||||
|
programs; and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to make restrictions that forbid
|
||||||
|
anyone to deny you these rights or to ask you to surrender the rights.
|
||||||
|
These restrictions translate to certain responsibilities for you if you
|
||||||
|
distribute copies of the software, or if you modify it.
|
||||||
|
|
||||||
|
For example, if you distribute copies of a such a program, whether
|
||||||
|
gratis or for a fee, you must give the recipients all the rights that
|
||||||
|
you have. You must make sure that they, too, receive or can get the
|
||||||
|
source code. And you must tell them their rights.
|
||||||
|
|
||||||
|
We protect your rights with two steps: (1) copyright the software, and
|
||||||
|
(2) offer you this license which gives you legal permission to copy,
|
||||||
|
distribute and/or modify the software.
|
||||||
|
|
||||||
|
Also, for each author's protection and ours, we want to make certain
|
||||||
|
that everyone understands that there is no warranty for this free
|
||||||
|
software. If the software is modified by someone else and passed on, we
|
||||||
|
want its recipients to know that what they have is not the original, so
|
||||||
|
that any problems introduced by others will not reflect on the original
|
||||||
|
authors' reputations.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License Agreement applies to any program or other work which
|
||||||
|
contains a notice placed by the copyright holder saying it may be
|
||||||
|
distributed under the terms of this General Public License. The
|
||||||
|
"Program", below, refers to any such program or work, and a "work based
|
||||||
|
on the Program" means either the Program or any work containing the
|
||||||
|
Program or a portion of it, either verbatim or with modifications. Each
|
||||||
|
licensee is addressed as "you".
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Program's source
|
||||||
|
code as you receive it, in any medium, provided that you conspicuously and
|
||||||
|
appropriately publish on each copy an appropriate copyright notice and
|
||||||
|
disclaimer of warranty; keep intact all the notices that refer to this
|
||||||
|
General Public License and to the absence of any warranty; and give any
|
||||||
|
other recipients of the Program a copy of this General Public License
|
||||||
|
along with the Program. You may charge a fee for the physical act of
|
||||||
|
transferring a copy.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Program or any portion of
|
||||||
|
it, and copy and distribute such modifications under the terms of Paragraph
|
||||||
|
1 above, provided that you also do the following:
|
||||||
|
|
||||||
|
a) cause the modified files to carry prominent notices stating that
|
||||||
|
you changed the files and the date of any change; and
|
||||||
|
|
||||||
|
b) cause the whole of any work that you distribute or publish, that
|
||||||
|
in whole or in part contains the Program or any part thereof, either
|
||||||
|
with or without modifications, to be licensed at no charge to all
|
||||||
|
third parties under the terms of this General Public License (except
|
||||||
|
that you may choose to grant warranty protection to some or all
|
||||||
|
third parties, at your option).
|
||||||
|
|
||||||
|
c) If the modified program normally reads commands interactively when
|
||||||
|
run, you must cause it, when started running for such interactive use
|
||||||
|
in the simplest and most usual way, to print or display an
|
||||||
|
announcement including an appropriate copyright notice and a notice
|
||||||
|
that there is no warranty (or else, saying that you provide a
|
||||||
|
warranty) and that users may redistribute the program under these
|
||||||
|
conditions, and telling the user how to view a copy of this General
|
||||||
|
Public License.
|
||||||
|
|
||||||
|
d) You may charge a fee for the physical act of transferring a
|
||||||
|
copy, and you may at your option offer warranty protection in
|
||||||
|
exchange for a fee.
|
||||||
|
|
||||||
|
Mere aggregation of another independent work with the Program (or its
|
||||||
|
derivative) on a volume of a storage or distribution medium does not bring
|
||||||
|
the other work under the scope of these terms.
|
||||||
|
|
||||||
|
3. You may copy and distribute the Program (or a portion or derivative of
|
||||||
|
it, under Paragraph 2) in object code or executable form under the terms of
|
||||||
|
Paragraphs 1 and 2 above provided that you also do one of the following:
|
||||||
|
|
||||||
|
a) accompany it with the complete corresponding machine-readable
|
||||||
|
source code, which must be distributed under the terms of
|
||||||
|
Paragraphs 1 and 2 above; or,
|
||||||
|
|
||||||
|
b) accompany it with a written offer, valid for at least three
|
||||||
|
years, to give any third party free (except for a nominal charge
|
||||||
|
for the cost of distribution) a complete machine-readable copy of the
|
||||||
|
corresponding source code, to be distributed under the terms of
|
||||||
|
Paragraphs 1 and 2 above; or,
|
||||||
|
|
||||||
|
c) accompany it with the information you received as to where the
|
||||||
|
corresponding source code may be obtained. (This alternative is
|
||||||
|
allowed only for noncommercial distribution and only if you
|
||||||
|
received the program in object code or executable form alone.)
|
||||||
|
|
||||||
|
Source code for a work means the preferred form of the work for making
|
||||||
|
modifications to it. For an executable file, complete source code means
|
||||||
|
all the source code for all modules it contains; but, as a special
|
||||||
|
exception, it need not include source code for modules which are standard
|
||||||
|
libraries that accompany the operating system on which the executable
|
||||||
|
file runs, or for standard header files or definitions files that
|
||||||
|
accompany that operating system.
|
||||||
|
|
||||||
|
4. You may not copy, modify, sublicense, distribute or transfer the
|
||||||
|
Program except as expressly provided under this General Public License.
|
||||||
|
Any attempt otherwise to copy, modify, sublicense, distribute or transfer
|
||||||
|
the Program is void, and will automatically terminate your rights to use
|
||||||
|
the Program under this License. However, parties who have received
|
||||||
|
copies, or rights to use copies, from you under this General Public
|
||||||
|
License will not have their licenses terminated so long as such parties
|
||||||
|
remain in full compliance.
|
||||||
|
|
||||||
|
5. By copying, distributing or modifying the Program (or any work based
|
||||||
|
on the Program) you indicate your acceptance of this license to do so,
|
||||||
|
and all its terms and conditions.
|
||||||
|
|
||||||
|
6. Each time you redistribute the Program (or any work based on the
|
||||||
|
Program), the recipient automatically receives a license from the original
|
||||||
|
licensor to copy, distribute or modify the Program subject to these
|
||||||
|
terms and conditions. You may not impose any further restrictions on the
|
||||||
|
recipients' exercise of the rights granted herein.
|
||||||
|
|
||||||
|
7. The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Program
|
||||||
|
specifies a version number of the license which applies to it and "any
|
||||||
|
later version", you have the option of following the terms and conditions
|
||||||
|
either of that version or of any later version published by the Free
|
||||||
|
Software Foundation. If the Program does not specify a version number of
|
||||||
|
the license, you may choose any version ever published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
|
||||||
|
8. If you wish to incorporate parts of the Program into other free
|
||||||
|
programs whose distribution conditions are different, write to the author
|
||||||
|
to ask for permission. For software which is copyrighted by the Free
|
||||||
|
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||||
|
make exceptions for this. Our decision will be guided by the two goals
|
||||||
|
of preserving the free status of all derivatives of our free software and
|
||||||
|
of promoting the sharing and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
9. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||||
|
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||||
|
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||||
|
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||||
|
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||||
|
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||||
|
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||||
|
REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
10. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||||
|
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||||
|
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||||
|
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||||
|
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||||
|
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||||
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
Appendix: How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to humanity, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these
|
||||||
|
terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest to
|
||||||
|
attach them to the start of each source file to most effectively convey
|
||||||
|
the exclusion of warranty; and each file should have at least the
|
||||||
|
"copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) 19yy <name of author>
|
||||||
|
|
||||||
|
This program is free software; you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation; either version 1, or (at your option)
|
||||||
|
any later version.
|
||||||
|
|
||||||
|
This program 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, write to the Free Software
|
||||||
|
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program is interactive, make it output a short notice like this
|
||||||
|
when it starts in an interactive mode:
|
||||||
|
|
||||||
|
Gnomovision version 69, Copyright (C) 19xx name of author
|
||||||
|
Gnomovision comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the
|
||||||
|
appropriate parts of the General Public License. Of course, the
|
||||||
|
commands you use may be called something other than `show w' and `show
|
||||||
|
c'; they could even be mouse-clicks or menu items--whatever suits your
|
||||||
|
program.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||||
|
necessary. Here a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the
|
||||||
|
program `Gnomovision' (a program to direct compilers to make passes
|
||||||
|
at assemblers) written by James Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1989
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
That's all there is to it!
|
419
LICENSES/GPL-2.0
Normal file
419
LICENSES/GPL-2.0
Normal file
@ -0,0 +1,419 @@
|
|||||||
|
Valid-License-Identifier: GPL-2.0-only
|
||||||
|
Valid-License-Identifier: GPL-2.0
|
||||||
|
Valid-License-Identifier: GPL-2.0-or-later
|
||||||
|
Valid-License-Identifier: GPL-2.0+
|
||||||
|
SPDX-URL: https://spdx.org/licenses/GPL-2.0.html
|
||||||
|
Usage-Guide:
|
||||||
|
To use this license in source code, put one of the following SPDX
|
||||||
|
tag/value pairs into a comment according to the placement
|
||||||
|
guidelines in the licensing rules documentation.
|
||||||
|
For 'GNU General Public License (GPL) version 2 only' use:
|
||||||
|
SPDX-License-Identifier: GPL-2.0-only
|
||||||
|
For 'GNU General Public License (GPL) version 2 or any later version' use:
|
||||||
|
SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
Version 2, June 1991
|
||||||
|
|
||||||
|
Copyright (C) 1989, 1991 Free Software Foundation, Inc.
|
||||||
|
51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
Everyone is permitted to copy and distribute verbatim copies
|
||||||
|
of this license document, but changing it is not allowed.
|
||||||
|
|
||||||
|
Preamble
|
||||||
|
|
||||||
|
The licenses for most software are designed to take away your
|
||||||
|
freedom to share and change it. By contrast, the GNU General Public
|
||||||
|
License is intended to guarantee your freedom to share and change free
|
||||||
|
software--to make sure the software is free for all its users. This
|
||||||
|
General Public License applies to most of the Free Software
|
||||||
|
Foundation's software and to any other program whose authors commit to
|
||||||
|
using it. (Some other Free Software Foundation software is covered by
|
||||||
|
the GNU Library General Public License instead.) You can apply it to
|
||||||
|
your programs, too.
|
||||||
|
|
||||||
|
When we speak of free software, we are referring to freedom, not
|
||||||
|
price. Our General Public Licenses are designed to make sure that you
|
||||||
|
have the freedom to distribute copies of free software (and charge for
|
||||||
|
them if you wish), that you receive source code or can get it if you
|
||||||
|
want it, that you can change the software or use pieces of it in new
|
||||||
|
free programs, and that you know you can do these things.
|
||||||
|
|
||||||
|
To protect your rights, we need to prevent others from denying you
|
||||||
|
these rights or asking you to surrender the rights. Therefore, you have
|
||||||
|
certain responsibilities if you distribute copies of the software, or if
|
||||||
|
you modify it: responsibilities to respect the freedom of others.
|
||||||
|
|
||||||
|
For example, if you distribute copies of such a program, whether
|
||||||
|
gratis or for a fee, you must pass on to the recipients the same
|
||||||
|
freedoms that you received. You must make sure that they, too, receive
|
||||||
|
or can get the source code. And you must show them these terms so they
|
||||||
|
know their rights.
|
||||||
|
|
||||||
|
Developers that use the GNU GPL protect your rights with two steps:
|
||||||
|
(1) assert copyright on the software, and (2) offer you this License
|
||||||
|
giving you legal permission to copy, distribute and/or modify it.
|
||||||
|
|
||||||
|
For the developers' and authors' protection, the GPL clearly explains
|
||||||
|
that there is no warranty for this free software. For both users' and
|
||||||
|
authors' sake, the GPL requires that modified versions be marked as
|
||||||
|
changed, so that their problems will not be attributed erroneously to
|
||||||
|
authors of previous versions.
|
||||||
|
|
||||||
|
Some devices are designed to deny users access to install or run
|
||||||
|
modified versions of the software inside them, although the manufacturer
|
||||||
|
can do so. This is fundamentally incompatible with the aim of
|
||||||
|
protecting users' freedom to change the software. The systematic
|
||||||
|
pattern of such abuse occurs in the area of products for individuals to
|
||||||
|
use, which is precisely where it is most unacceptable. Therefore, we
|
||||||
|
have designed this version of the GPL to prohibit the practice for those
|
||||||
|
products. If such problems arise substantially in other domains, we
|
||||||
|
stand ready to extend this provision to those domains in future versions
|
||||||
|
of the GPL, as needed to protect the freedom of users.
|
||||||
|
|
||||||
|
Finally, every program is threatened constantly by software patents.
|
||||||
|
States should not allow patents to restrict development and use of
|
||||||
|
software on general-purpose computers, but in those that do, we wish to
|
||||||
|
avoid the special danger that patents applied to a free program could
|
||||||
|
make it effectively proprietary. To prevent this, the GPL assures that
|
||||||
|
patents cannot be used to render the program non-free.
|
||||||
|
|
||||||
|
The precise terms and conditions for copying, distribution and
|
||||||
|
modification follow.
|
||||||
|
|
||||||
|
GNU GENERAL PUBLIC LICENSE
|
||||||
|
TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
|
||||||
|
|
||||||
|
0. This License applies to any program or other work which contains
|
||||||
|
a notice placed by the copyright holder saying it may be distributed
|
||||||
|
under the terms of this General Public License. The "Program", below,
|
||||||
|
refers to any such program or work, and a "work based on the Program"
|
||||||
|
means either the Program or any derivative work under copyright law:
|
||||||
|
that is to say, a work containing the Program or a portion of it,
|
||||||
|
either verbatim or with modifications and/or translated into another
|
||||||
|
language. (Hereinafter, translation is included without limitation in
|
||||||
|
the term "modification".) Each licensee is addressed as "you".
|
||||||
|
|
||||||
|
Activities other than copying, distribution and modification are not
|
||||||
|
covered by this License; they are outside its scope. The act of
|
||||||
|
running the Program is not restricted, and the output from the Program
|
||||||
|
is covered only if its contents constitute a work based on the
|
||||||
|
Program (independent of having been made by running the Program).
|
||||||
|
Whether that is true depends on what the Program does.
|
||||||
|
|
||||||
|
1. You may copy and distribute verbatim copies of the Program's
|
||||||
|
source code as you receive it, in any medium, provided that you
|
||||||
|
conspicuously and appropriately publish on each copy an appropriate
|
||||||
|
copyright notice and disclaimer of warranty; keep intact all the
|
||||||
|
notices that refer to this License and to the absence of any warranty;
|
||||||
|
and give any other recipients of the Program a copy of this License
|
||||||
|
along with the Program.
|
||||||
|
|
||||||
|
You may charge a fee for the physical act of transferring a copy, and
|
||||||
|
you may at your option offer warranty protection in exchange for a fee.
|
||||||
|
|
||||||
|
2. You may modify your copy or copies of the Program or any portion
|
||||||
|
of it, thus forming a work based on the Program, and copy and
|
||||||
|
distribute such modifications or work under the terms of Section 1
|
||||||
|
above, provided that you also meet all of these conditions:
|
||||||
|
|
||||||
|
a) You must cause the modified files to carry prominent notices
|
||||||
|
stating that you changed the files and the date of any change.
|
||||||
|
|
||||||
|
b) You must cause any work that you distribute or publish, that in
|
||||||
|
whole or in part contains or is derived from the Program or any
|
||||||
|
part thereof, to be licensed as a whole at no charge to all third
|
||||||
|
parties under the terms of this License.
|
||||||
|
|
||||||
|
c) If the modified program normally reads commands interactively
|
||||||
|
when run, you must cause it, when started running for such
|
||||||
|
interactive use in the most ordinary way, to print or display an
|
||||||
|
announcement including an appropriate copyright notice and a
|
||||||
|
notice that there is no warranty (or else, saying that you provide
|
||||||
|
a warranty) and that users may redistribute the program under
|
||||||
|
these conditions, and telling the user how to view a copy of this
|
||||||
|
License. (Exception: if the Program itself is interactive but
|
||||||
|
does not normally print such an announcement, your work based on
|
||||||
|
the Program is not required to print an announcement.)
|
||||||
|
|
||||||
|
These requirements apply to the modified work as a whole. If
|
||||||
|
identifiable sections of that work are not derived from the Program,
|
||||||
|
and can be reasonably considered independent and separate works in
|
||||||
|
themselves, then this License, and its terms, do not apply to those
|
||||||
|
sections when you distribute them as separate works. But when you
|
||||||
|
distribute the same sections as part of a whole which is a work based
|
||||||
|
on the Program, the distribution of the whole must be on the terms of
|
||||||
|
this License, whose permissions for other licensees extend to the
|
||||||
|
entire whole, and thus to each and every part regardless of who wrote it.
|
||||||
|
|
||||||
|
Thus, it is not the intent of this section to claim rights or contest
|
||||||
|
your rights to work written entirely by you; rather, the intent is to
|
||||||
|
exercise the right to control the distribution of derivative or
|
||||||
|
collective works based on the Program.
|
||||||
|
|
||||||
|
In addition, mere aggregation of another work not based on the Program
|
||||||
|
with the Program (or with a work based on the Program) on a volume of
|
||||||
|
a storage or distribution medium does not bring the other work under
|
||||||
|
the scope of this License.
|
||||||
|
|
||||||
|
3. You may copy and distribute the Program (or a work based on it,
|
||||||
|
under Section 2) in object code or executable form under the terms of
|
||||||
|
Sections 1 and 2 above provided that you also do one of the following:
|
||||||
|
|
||||||
|
a) Accompany it with the complete corresponding machine-readable
|
||||||
|
source code, which must be distributed under the terms of Sections
|
||||||
|
1 and 2 above on a medium customarily used for software interchange; or,
|
||||||
|
|
||||||
|
b) Accompany it with a written offer, valid for at least three
|
||||||
|
years, to give any third party, for a charge no more than your
|
||||||
|
cost of physically performing source distribution, a complete
|
||||||
|
machine-readable copy of the corresponding source code, to be
|
||||||
|
distributed under the terms of Sections 1 and 2 above on a medium
|
||||||
|
customarily used for software interchange; or,
|
||||||
|
|
||||||
|
c) Accompany it with the information you received as to the offer
|
||||||
|
to distribute corresponding source code. (This alternative is
|
||||||
|
allowed only for noncommercial distribution and only if you
|
||||||
|
received the program in object code or executable form with such
|
||||||
|
an offer, in accord with Subsection b above.)
|
||||||
|
|
||||||
|
The source code for a work means the preferred form of the work for
|
||||||
|
making modifications to it. For an executable work, complete source
|
||||||
|
code means all the source code for all modules it contains, plus any
|
||||||
|
associated interface definition files, plus the scripts used to
|
||||||
|
control compilation and installation of the executable. However, as a
|
||||||
|
special exception, the source code distributed need not include
|
||||||
|
anything that is normally distributed (in either source or binary
|
||||||
|
form) with the major components (compiler, kernel, and so on) of the
|
||||||
|
operating system on which the executable runs, unless that component
|
||||||
|
itself accompanies the executable.
|
||||||
|
|
||||||
|
If distribution of executable or object code is made by offering
|
||||||
|
access to copy from a designated place, then offering equivalent
|
||||||
|
access to copy the source code from the same place counts as
|
||||||
|
distribution of the source code, even though third parties are not
|
||||||
|
compelled to copy the source along with the object code.
|
||||||
|
|
||||||
|
4. You may not copy, modify, sublicense, or distribute the Program
|
||||||
|
except as expressly provided under this License. Any attempt
|
||||||
|
otherwise to copy, modify, sublicense or distribute the Program is
|
||||||
|
void, and will automatically terminate your rights under this License.
|
||||||
|
However, parties who have received copies, or rights, from you under
|
||||||
|
this License will not have their licenses terminated so long as such
|
||||||
|
parties remain in full compliance.
|
||||||
|
|
||||||
|
5. You are not required to accept this License, since you have not
|
||||||
|
signed it. However, nothing else grants you permission to modify or
|
||||||
|
distribute the Program or its derivative works. These actions are
|
||||||
|
prohibited by law if you do not accept this License. Therefore, by
|
||||||
|
modifying or distributing the Program (or any work based on the
|
||||||
|
Program), you indicate your acceptance of this License to do so, and
|
||||||
|
all its terms and conditions for copying, distributing or modifying
|
||||||
|
the Program or works based on it.
|
||||||
|
|
||||||
|
6. Each time you redistribute the Program (or any work based on the
|
||||||
|
Program), the recipient automatically receives a license from the
|
||||||
|
original licensor to copy, distribute or modify the Program subject to
|
||||||
|
these terms and conditions. You may not impose any further
|
||||||
|
restrictions on the recipients' exercise of the rights granted herein.
|
||||||
|
You are not responsible for enforcing compliance by third parties to
|
||||||
|
this License.
|
||||||
|
|
||||||
|
Each contributor grants you a non-exclusive, worldwide, royalty-free
|
||||||
|
patent license under the contributor's essential patent claims, to
|
||||||
|
make, use, sell, offer for sale, import and otherwise run, modify and
|
||||||
|
propagate the contents of its contributor version.
|
||||||
|
|
||||||
|
In the following three paragraphs, a "patent license" is any express
|
||||||
|
agreement or commitment, however denominated, not to enforce a patent
|
||||||
|
(such as an express permission to practice a patent or covenant not to
|
||||||
|
sue for patent infringement). To "grant" such a patent license to a
|
||||||
|
party means to make such an agreement or commitment not to enforce a
|
||||||
|
patent against the party.
|
||||||
|
|
||||||
|
If you convey a covered work, knowingly relying on a patent license,
|
||||||
|
and the Corresponding Source of the work is not available for anyone
|
||||||
|
to copy, free of charge and under the terms of this License, through a
|
||||||
|
publicly available network server or other readily accessible means,
|
||||||
|
then you must either (1) cause the Corresponding Source to be so
|
||||||
|
available, or (2) arrange to deprive yourself of the benefit of the
|
||||||
|
patent license for this particular work, or (3) arrange, in a manner
|
||||||
|
consistent with the requirements of this License, to extend the patent
|
||||||
|
license to downstream recipients. "Knowingly relying" means you have
|
||||||
|
actual knowledge that, but for the patent license, your conveying the
|
||||||
|
covered work in a country, or your recipient's use of the covered work
|
||||||
|
in a country, would infringe one or more identifiable patents in that
|
||||||
|
country that you have reason to believe are valid.
|
||||||
|
|
||||||
|
If, pursuant to or in connection with a single transaction or
|
||||||
|
arrangement, you convey, or propagate by procuring conveyance of, a
|
||||||
|
covered work, and grant a patent license to some of the parties
|
||||||
|
receiving the covered work authorizing them to use, propagate, modify
|
||||||
|
or convey a specific copy of the covered work, then the patent license
|
||||||
|
you grant is automatically extended to all recipients of the covered
|
||||||
|
work and works based on it.
|
||||||
|
|
||||||
|
A patent license is "discriminatory" if it does not include within
|
||||||
|
the scope of its coverage, prohibits the exercise of, or is
|
||||||
|
conditioned on the non-exercise of one or more of the rights that are
|
||||||
|
specifically granted under this License. You may not convey a covered
|
||||||
|
work if you are a party to an arrangement with a third party that is
|
||||||
|
in the business of distributing software, under which you make payment
|
||||||
|
to the third party based on the extent of your activity of conveying
|
||||||
|
the work, and under which the third party grants, to any of the
|
||||||
|
parties who would receive the covered work from you, a discriminatory
|
||||||
|
patent license (a) in connection with copies of the covered work
|
||||||
|
conveyed by you (or copies made from those copies), or (b) primarily
|
||||||
|
for and in connection with specific products or compilations that
|
||||||
|
contain the covered work, unless you entered into that arrangement,
|
||||||
|
or that patent license was granted, prior to 28 March 2007.
|
||||||
|
|
||||||
|
Nothing in this License shall be construed as excluding or limiting
|
||||||
|
any implied license or other defenses to infringement that may
|
||||||
|
otherwise be available to you under applicable patent law.
|
||||||
|
|
||||||
|
12. No Surrender of Others' Freedom.
|
||||||
|
|
||||||
|
If conditions are imposed on you (whether by court order, agreement or
|
||||||
|
otherwise) that contradict the conditions of this License, they do not
|
||||||
|
excuse you from the conditions of this License. If you cannot
|
||||||
|
distribute so as to satisfy simultaneously your obligations under this
|
||||||
|
License and any other pertinent obligations, then as a consequence you
|
||||||
|
may not distribute the Program at all. For example, if a patent
|
||||||
|
license would not permit royalty-free redistribution of the Program by
|
||||||
|
all those who receive copies directly or indirectly through you, then
|
||||||
|
the only way you could satisfy both it and this License would be to
|
||||||
|
refrain entirely from distribution of the Program.
|
||||||
|
|
||||||
|
If any portion of this section is held invalid or unenforceable under
|
||||||
|
any particular circumstance, the balance of the section is intended to
|
||||||
|
apply and the section as a whole is intended to apply in other
|
||||||
|
circumstances.
|
||||||
|
|
||||||
|
It is not the purpose of this section to induce you to infringe any
|
||||||
|
patents or other property right claims or to contest validity of any
|
||||||
|
such claims; this section has the sole purpose of protecting the
|
||||||
|
integrity of the free software distribution system, which is
|
||||||
|
implemented by public license practices. Many people have made
|
||||||
|
generous contributions to the wide range of software distributed
|
||||||
|
through that system in reliance on consistent application of that
|
||||||
|
system; it is up to the author/donor to decide if he or she is willing
|
||||||
|
to distribute software through any other system and a licensee cannot
|
||||||
|
impose that choice.
|
||||||
|
|
||||||
|
This section is intended to make thoroughly clear what is believed to
|
||||||
|
be a consequence of the rest of this License.
|
||||||
|
|
||||||
|
8. If the distribution and/or use of the Program is restricted in
|
||||||
|
certain countries either by patents or by copyrighted interfaces, the
|
||||||
|
original copyright holder who places the Program under this License
|
||||||
|
may add an explicit geographical distribution limitation excluding
|
||||||
|
those countries, so that distribution is permitted only in or among
|
||||||
|
countries not thus excluded. In such case, this License incorporates
|
||||||
|
the limitation as if written in the body of this License.
|
||||||
|
|
||||||
|
9. The Free Software Foundation may publish revised and/or new versions
|
||||||
|
of the General Public License from time to time. Such new versions will
|
||||||
|
be similar in spirit to the present version, but may differ in detail to
|
||||||
|
address new problems or concerns.
|
||||||
|
|
||||||
|
Each version is given a distinguishing version number. If the Program
|
||||||
|
specifies a version number of this License which applies to it and "any
|
||||||
|
later version", you have the option of following the terms and conditions
|
||||||
|
either of that version or of any later version published by the Free
|
||||||
|
Software Foundation. If the Program does not specify a version number of
|
||||||
|
this License, you may choose any version ever published by the Free Software
|
||||||
|
Foundation.
|
||||||
|
|
||||||
|
10. If you wish to incorporate parts of the Program into other free
|
||||||
|
programs whose distribution conditions are different, write to the author
|
||||||
|
to ask for permission. For software which is copyrighted by the Free
|
||||||
|
Software Foundation, write to the Free Software Foundation; we sometimes
|
||||||
|
make exceptions for this. Our decision will be guided by the two goals
|
||||||
|
of preserving the free status of all derivatives of our free software and
|
||||||
|
of promoting the sharing and reuse of software generally.
|
||||||
|
|
||||||
|
NO WARRANTY
|
||||||
|
|
||||||
|
11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY
|
||||||
|
FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN
|
||||||
|
OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES
|
||||||
|
PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED
|
||||||
|
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
|
||||||
|
MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS
|
||||||
|
TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE
|
||||||
|
PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING,
|
||||||
|
REPAIR OR CORRECTION.
|
||||||
|
|
||||||
|
12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
|
||||||
|
WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
|
||||||
|
REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES,
|
||||||
|
INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING
|
||||||
|
OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED
|
||||||
|
TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY
|
||||||
|
YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER
|
||||||
|
PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGES.
|
||||||
|
|
||||||
|
END OF TERMS AND CONDITIONS
|
||||||
|
|
||||||
|
How to Apply These Terms to Your New Programs
|
||||||
|
|
||||||
|
If you develop a new program, and you want it to be of the greatest
|
||||||
|
possible use to the public, the best way to achieve this is to make it
|
||||||
|
free software which everyone can redistribute and change under these terms.
|
||||||
|
|
||||||
|
To do so, attach the following notices to the program. It is safest
|
||||||
|
to attach them to the start of each source file to most effectively
|
||||||
|
state the exclusion of warranty; and each file should have at least
|
||||||
|
the "copyright" line and a pointer to where the full notice is found.
|
||||||
|
|
||||||
|
<one line to give the program's name and a brief idea of what it does.>
|
||||||
|
Copyright (C) <year> <name of author>
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program 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, write to the Free Software
|
||||||
|
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
|
|
||||||
|
Also add information on how to contact you by electronic and paper mail.
|
||||||
|
|
||||||
|
If the program does terminal interaction, make it output a short
|
||||||
|
notice like this when it starts in an interactive mode:
|
||||||
|
|
||||||
|
<program> Copyright (C) <year> <name of author>
|
||||||
|
This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'.
|
||||||
|
This is free software, and you are welcome to redistribute it
|
||||||
|
under certain conditions; type `show c' for details.
|
||||||
|
|
||||||
|
The hypothetical commands `show w' and `show c' should show the appropriate
|
||||||
|
parts of the General Public License. Of course, the commands you use may
|
||||||
|
be called something other than `show w' and `show c'; they could even be
|
||||||
|
mouse-clicks or menu items--whatever suits your program.
|
||||||
|
|
||||||
|
You should also get your employer (if you work as a programmer) or your
|
||||||
|
school, if any, to sign a "copyright disclaimer" for the program, if
|
||||||
|
necessary. Here is a sample; alter the names:
|
||||||
|
|
||||||
|
Yoyodyne, Inc., hereby disclaims all copyright interest in the program
|
||||||
|
`Gnomovision' (which makes passes at compilers) written by James Hacker.
|
||||||
|
|
||||||
|
<signature of Ty Coon>, 1 April 1989
|
||||||
|
Ty Coon, President of Vice
|
||||||
|
|
||||||
|
This General Public License does not permit incorporating your program into
|
||||||
|
proprietary programs. If your program is a subroutine library, you may
|
||||||
|
consider it more useful to permit linking proprietary applications with the
|
||||||
|
library. If this is what you want to do, use the GNU Library General
|
||||||
|
Public License instead of this License.
|
24
LICENSES/ISC
Normal file
24
LICENSES/ISC
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
Valid-License-Identifier: ISC
|
||||||
|
SPDX-URL: https://spdx.org/licenses/ISC.html
|
||||||
|
Usage-Guide:
|
||||||
|
To use the ISC License put the following SPDX tag/value pair into a
|
||||||
|
comment according to the placement guidelines in the licensing rules
|
||||||
|
documentation:
|
||||||
|
SPDX-License-Identifier: ISC
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
ISC License
|
||||||
|
|
||||||
|
Copyright (c) <year> <copyright holders>
|
||||||
|
|
||||||
|
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.
|
25
LICENSES/Linux-syscall-note
Normal file
25
LICENSES/Linux-syscall-note
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
SPDX-Exception-Identifier: Linux-syscall-note
|
||||||
|
SPDX-URL: https://spdx.org/licenses/Linux-syscall-note.html
|
||||||
|
SPDX-Licenses: GPL-2.0-only, GPL-2.0, GPL-2.0-or-later, GPL-2.0+, GPL-1.0-or-later, GPL-1.0+, LGPL-2.0, LGPL-2.0+, LGPL-2.1, LGPL-2.1+
|
||||||
|
Usage-Guide:
|
||||||
|
This exception is used together with one of the above SPDX-Licenses
|
||||||
|
to mark user space API (uapi) header files so they can be included
|
||||||
|
into non GPL compliant user space application code.
|
||||||
|
To use this exception add it with the keyword WITH to one of the
|
||||||
|
identifiers in the SPDX-Licenses tag:
|
||||||
|
SPDX-License-Identifier: <SPDX-License> WITH Linux-syscall-note
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
NOTE! This copyright does *not* cover user programs that use kernel
|
||||||
|
services by normal system calls - this is merely considered normal use
|
||||||
|
of the kernel, and does *not* fall under the heading of "derived work".
|
||||||
|
Also note that the GPL below is copyrighted by the Free Software
|
||||||
|
Foundation, but the instance of code that it refers to (the Linux
|
||||||
|
kernel) is copyrighted by me and others who actually wrote it.
|
||||||
|
|
||||||
|
Also note that the only valid version of the GPL as far as the kernel
|
||||||
|
is concerned is _this_ particular version of the license (ie v2, not
|
||||||
|
v2.2 or v3.x or whatever), unless explicitly otherwise stated.
|
||||||
|
|
||||||
|
Linus Torvalds
|
||||||
|
|
30
LICENSES/MIT
Normal file
30
LICENSES/MIT
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
Valid-License-Identifier: MIT
|
||||||
|
SPDX-URL: https://spdx.org/licenses/MIT.html
|
||||||
|
Usage-Guide:
|
||||||
|
To use the MIT License put the following SPDX tag/value pair into a
|
||||||
|
comment according to the placement guidelines in the licensing rules
|
||||||
|
documentation:
|
||||||
|
SPDX-License-Identifier: MIT
|
||||||
|
License-Text:
|
||||||
|
|
||||||
|
MIT License
|
||||||
|
|
||||||
|
Copyright (c) <year> <copyright holders>
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a
|
||||||
|
copy of this software and associated documentation files (the "Software"),
|
||||||
|
to deal in the Software without restriction, including without limitation
|
||||||
|
the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
||||||
|
and/or sell copies of the Software, and to permit persons to whom the
|
||||||
|
Software is furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
||||||
|
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
||||||
|
DEALINGS IN THE SOFTWARE.
|
@ -43,5 +43,5 @@ endef
|
|||||||
|
|
||||||
# 1: package name
|
# 1: package name
|
||||||
define GetABISuffix
|
define GetABISuffix
|
||||||
$(if $(filter-out kmod-%,$(1)),$(if $(Package/$(1)/abiversion),$(if $(filter %0 %1 %2 %3 %4 %5 %6 %7 %8 %9,$(1)),-)$(Package/$(1)/abiversion)))
|
$(if $(filter-out kmod-%,$(1)),$(foreach v,$(wildcard $(STAGING_DIR)/pkginfo/$(1).version),$(shell cat $(v))))
|
||||||
endef
|
endef
|
||||||
|
@ -6,9 +6,9 @@ ifdef CONFIG_TESTING_KERNEL
|
|||||||
KERNEL_PATCHVER:=$(KERNEL_TESTING_PATCHVER)
|
KERNEL_PATCHVER:=$(KERNEL_TESTING_PATCHVER)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
LINUX_VERSION-5.4 = .96
|
LINUX_VERSION-5.4 = .98
|
||||||
|
|
||||||
LINUX_KERNEL_HASH-5.4.96 = f728de695ec5eb17efa15acaecc48fcd7a6c4a912b51704ed137cccf93f9f5e0
|
LINUX_KERNEL_HASH-5.4.98 = 83a248d6fbe388f133769d736f36b754767abc9d66f1c034b537ad778fbd46b1
|
||||||
|
|
||||||
remove_uri_prefix=$(subst git://,,$(subst http://,,$(subst https://,,$(1))))
|
remove_uri_prefix=$(subst git://,,$(subst http://,,$(subst https://,,$(1))))
|
||||||
sanitize_uri=$(call qstrip,$(subst @,_,$(subst :,_,$(subst .,_,$(subst -,_,$(subst /,_,$(1)))))))
|
sanitize_uri=$(call qstrip,$(subst @,_,$(subst :,_,$(subst .,_,$(subst -,_,$(subst /,_,$(1)))))))
|
||||||
|
@ -21,8 +21,7 @@ $(if $(MENU),Menu: $(MENU)
|
|||||||
)$(if $(DEFAULT),Default: $(DEFAULT)
|
)$(if $(DEFAULT),Default: $(DEFAULT)
|
||||||
)$(if $(findstring $(PREREQ_CHECK),1),Prereq-Check: 1
|
)$(if $(findstring $(PREREQ_CHECK),1),Prereq-Check: 1
|
||||||
)Version: $(VERSION)
|
)Version: $(VERSION)
|
||||||
$(if $(ABI_VERSION),ABIVersion: $(ABI_VERSION)
|
Depends: $(call PKG_FIXUP_DEPENDS,$(1),$(DEPENDS))
|
||||||
)Depends: $(call PKG_FIXUP_DEPENDS,$(1),$(DEPENDS))
|
|
||||||
Conflicts: $(CONFLICTS)
|
Conflicts: $(CONFLICTS)
|
||||||
Menu-Depends: $(MDEPENDS)
|
Menu-Depends: $(MDEPENDS)
|
||||||
Provides: $(PROVIDES)
|
Provides: $(PROVIDES)
|
||||||
|
@ -99,7 +99,7 @@ _endef=endef
|
|||||||
|
|
||||||
ifeq ($(DUMP),)
|
ifeq ($(DUMP),)
|
||||||
define BuildTarget/ipkg
|
define BuildTarget/ipkg
|
||||||
ABIV_$(1):=$(call GetABISuffix,$(1))
|
ABIV_$(1):=$(if $(filter-out kmod-%,$(1)),$(ABI_VERSION))
|
||||||
PDIR_$(1):=$(call FeedPackageDir,$(1))
|
PDIR_$(1):=$(call FeedPackageDir,$(1))
|
||||||
IPKG_$(1):=$$(PDIR_$(1))/$(1)$$(ABIV_$(1))_$(VERSION)_$(PKGARCH).ipk
|
IPKG_$(1):=$$(PDIR_$(1))/$(1)$$(ABIV_$(1))_$(VERSION)_$(PKGARCH).ipk
|
||||||
IDIR_$(1):=$(PKG_BUILD_DIR)/ipkg-$(PKGARCH)/$(1)
|
IDIR_$(1):=$(PKG_BUILD_DIR)/ipkg-$(PKGARCH)/$(1)
|
||||||
@ -152,11 +152,17 @@ ifeq ($(DUMP),)
|
|||||||
mkdir -p $(PKG_BUILD_DIR)/.pkgdir/$(1)
|
mkdir -p $(PKG_BUILD_DIR)/.pkgdir/$(1)
|
||||||
$(call Package/$(1)/install,$(PKG_BUILD_DIR)/.pkgdir/$(1))
|
$(call Package/$(1)/install,$(PKG_BUILD_DIR)/.pkgdir/$(1))
|
||||||
$(call Package/$(1)/install_lib,$(PKG_BUILD_DIR)/.pkgdir/$(1))
|
$(call Package/$(1)/install_lib,$(PKG_BUILD_DIR)/.pkgdir/$(1))
|
||||||
|
$(if $(PKG_ABI_VERSION),$(SET_ABI_VERSION) "$(PKG_ABI_VERSION)" "$(PKG_BUILD_DIR)/.pkgdir/$(1)" "$(STAGING_DIR)/packages/$(STAGING_FILES_LIST)")
|
||||||
touch $$@
|
touch $$@
|
||||||
|
|
||||||
$(STAGING_DIR_ROOT)/stamp/.$(1)_installed: $(PKG_BUILD_DIR)/.pkgdir/$(1).installed
|
$(STAGING_DIR_ROOT)/stamp/.$(1)_installed: $(PKG_BUILD_DIR)/.pkgdir/$(1).installed
|
||||||
mkdir -p $(STAGING_DIR_ROOT)/stamp
|
mkdir -p $(STAGING_DIR_ROOT)/stamp
|
||||||
$(if $(ABI_VERSION),echo '$(ABI_VERSION)' | cmp -s - $(PKG_INFO_DIR)/$(1).version || echo '$(ABI_VERSION)' > $(PKG_INFO_DIR)/$(1).version)
|
$(if $(ABI_VERSION),echo '$(ABI_VERSION)' | cmp -s - $(PKG_INFO_DIR)/$(1).version || \
|
||||||
|
echo '$(ABI_VERSION)' > $(PKG_INFO_DIR)/$(1).version \
|
||||||
|
$(foreach pkg,$(filter-out $(1),$(PROVIDES)),; \
|
||||||
|
cp $(PKG_INFO_DIR)/$(1).version $(PKG_INFO_DIR)/$(pkg).version \
|
||||||
|
) \
|
||||||
|
)
|
||||||
$(call locked,$(CP) $(PKG_BUILD_DIR)/.pkgdir/$(1)/. $(STAGING_DIR_ROOT)/,root-copy)
|
$(call locked,$(CP) $(PKG_BUILD_DIR)/.pkgdir/$(1)/. $(STAGING_DIR_ROOT)/,root-copy)
|
||||||
touch $$@
|
touch $$@
|
||||||
|
|
||||||
@ -191,11 +197,15 @@ $(_endef)
|
|||||||
$$(IPKG_$(1)) : export DESCRIPTION=$$(Package/$(1)/description)
|
$$(IPKG_$(1)) : export DESCRIPTION=$$(Package/$(1)/description)
|
||||||
$$(IPKG_$(1)) : export PATH=$$(TARGET_PATH_PKG)
|
$$(IPKG_$(1)) : export PATH=$$(TARGET_PATH_PKG)
|
||||||
$$(IPKG_$(1)) : export PKG_SOURCE_DATE_EPOCH:=$(PKG_SOURCE_DATE_EPOCH)
|
$$(IPKG_$(1)) : export PKG_SOURCE_DATE_EPOCH:=$(PKG_SOURCE_DATE_EPOCH)
|
||||||
|
ifdef Build/InstallDev
|
||||||
|
$$(IPKG_$(1)): $(STAMP_INSTALLED)
|
||||||
|
endif
|
||||||
$(PKG_INFO_DIR)/$(1).provides $$(IPKG_$(1)): $(STAMP_BUILT) $(INCLUDE_DIR)/package-ipkg.mk
|
$(PKG_INFO_DIR)/$(1).provides $$(IPKG_$(1)): $(STAMP_BUILT) $(INCLUDE_DIR)/package-ipkg.mk
|
||||||
@rm -rf $$(IDIR_$(1)); \
|
@rm -rf $$(IDIR_$(1)); \
|
||||||
$$(call remove_ipkg_files,$(1),$$(call opkg_package_files,$(call gen_ipkg_wildcard,$(1))))
|
$$(call remove_ipkg_files,$(1),$$(call opkg_package_files,$(call gen_ipkg_wildcard,$(1))))
|
||||||
mkdir -p $(PACKAGE_DIR) $$(IDIR_$(1))/CONTROL $(PKG_INFO_DIR)
|
mkdir -p $(PACKAGE_DIR) $$(IDIR_$(1))/CONTROL $(PKG_INFO_DIR)
|
||||||
$(call Package/$(1)/install,$$(IDIR_$(1)))
|
$(call Package/$(1)/install,$$(IDIR_$(1)))
|
||||||
|
$(if $(PKG_ABI_VERSION),$(SET_ABI_VERSION) "$(PKG_ABI_VERSION)" "$$(IDIR_$(1))" "$(STAGING_DIR)/packages/$(STAGING_FILES_LIST)")
|
||||||
$(if $(Package/$(1)/install-overlay),mkdir -p $(PACKAGE_DIR) $$(IDIR_$(1))/rootfs-overlay)
|
$(if $(Package/$(1)/install-overlay),mkdir -p $(PACKAGE_DIR) $$(IDIR_$(1))/rootfs-overlay)
|
||||||
$(call Package/$(1)/install-overlay,$$(IDIR_$(1))/rootfs-overlay)
|
$(call Package/$(1)/install-overlay,$$(IDIR_$(1))/rootfs-overlay)
|
||||||
-find $$(IDIR_$(1)) -name 'CVS' -o -name '.svn' -o -name '.#*' -o -name '*~'| $(XARGS) rm -rf
|
-find $$(IDIR_$(1)) -name 'CVS' -o -name '.svn' -o -name '.#*' -o -name '*~'| $(XARGS) rm -rf
|
||||||
|
@ -73,7 +73,7 @@ find_library_dependencies = \
|
|||||||
$(Package/$(dep3)/depends) $(dep3) \
|
$(Package/$(dep3)/depends) $(dep3) \
|
||||||
)), \
|
)), \
|
||||||
$(Package/$(dep4)/depends) $(dep4) \
|
$(Package/$(dep4)/depends) $(dep4) \
|
||||||
)), \
|
)) \
|
||||||
))
|
))
|
||||||
|
|
||||||
|
|
||||||
@ -178,6 +178,7 @@ Build/Exports=$(Build/Exports/Default)
|
|||||||
define Build/CoreTargets
|
define Build/CoreTargets
|
||||||
STAMP_PREPARED:=$$(STAMP_PREPARED)
|
STAMP_PREPARED:=$$(STAMP_PREPARED)
|
||||||
STAMP_CONFIGURED:=$$(STAMP_CONFIGURED)
|
STAMP_CONFIGURED:=$$(STAMP_CONFIGURED)
|
||||||
|
PKG_ABI_VERSION:=$$(PKG_ABI_VERSION)
|
||||||
|
|
||||||
$(if $(QUILT),$(Build/Quilt))
|
$(if $(QUILT),$(Build/Quilt))
|
||||||
$(call Build/Autoclean)
|
$(call Build/Autoclean)
|
||||||
@ -236,6 +237,7 @@ define Build/CoreTargets
|
|||||||
"$(STAGING_DIR)/packages/$(STAGING_FILES_LIST)" \
|
"$(STAGING_DIR)/packages/$(STAGING_FILES_LIST)" \
|
||||||
"$(STAGING_DIR)"; \
|
"$(STAGING_DIR)"; \
|
||||||
fi
|
fi
|
||||||
|
$(if $(PKG_ABI_VERSION),$(SET_ABI_VERSION) "$(PKG_ABI_VERSION)" $(TMP_DIR)/stage-$(PKG_DIR_NAME))
|
||||||
if [ -d $(TMP_DIR)/stage-$(PKG_DIR_NAME) ]; then \
|
if [ -d $(TMP_DIR)/stage-$(PKG_DIR_NAME) ]; then \
|
||||||
(cd $(TMP_DIR)/stage-$(PKG_DIR_NAME); find ./ > $(TMP_DIR)/stage-$(PKG_DIR_NAME).files); \
|
(cd $(TMP_DIR)/stage-$(PKG_DIR_NAME); find ./ > $(TMP_DIR)/stage-$(PKG_DIR_NAME).files); \
|
||||||
$(call locked, \
|
$(call locked, \
|
||||||
|
@ -74,7 +74,7 @@ define Build/Compile/Trusted-Firmware-A
|
|||||||
CROSS_COMPILE=$(TARGET_CROSS) \
|
CROSS_COMPILE=$(TARGET_CROSS) \
|
||||||
OPENSSL_DIR=$(STAGING_DIR_HOST) \
|
OPENSSL_DIR=$(STAGING_DIR_HOST) \
|
||||||
PLAT=$(PLAT) \
|
PLAT=$(PLAT) \
|
||||||
BUILD_STRING="OpenWRT v$(PKG_VERSION)-$(PKG_RELEASE) ($(VARIANT))" \
|
BUILD_STRING="OpenWrt v$(PKG_VERSION)-$(PKG_RELEASE) ($(VARIANT))" \
|
||||||
$(TFA_MAKE_FLAGS)
|
$(TFA_MAKE_FLAGS)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ system_config() {
|
|||||||
ln -sf "/usr/share/zoneinfo/$zonename" /tmp/localtime && rm -f /tmp/TZ
|
ln -sf "/usr/share/zoneinfo/$zonename" /tmp/localtime && rm -f /tmp/TZ
|
||||||
|
|
||||||
# apply timezone to kernel
|
# apply timezone to kernel
|
||||||
busybox date -k
|
hwclock -u --systz
|
||||||
}
|
}
|
||||||
|
|
||||||
reload_service() {
|
reload_service() {
|
||||||
|
@ -40,7 +40,9 @@ define Package/arm-trusted-firmware-mt7622/Default
|
|||||||
SECTION:=boot
|
SECTION:=boot
|
||||||
CATEGORY:=Boot Loaders
|
CATEGORY:=Boot Loaders
|
||||||
TITLE:=ARM Trusted Firmware for MT7622
|
TITLE:=ARM Trusted Firmware for MT7622
|
||||||
DEPENDS:=@TARGET_mediatek_mt7622
|
DEPENDS:=@TARGET_mediatek_mt7622 @BROKEN
|
||||||
|
# wait until bromimage gets replace by static build
|
||||||
|
# libcrypto.so.1.1: version `OPENSSL_1_1_1' not found (required by tools/mediatek/bromimage/bromimage)
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Package/arm-trusted-firmware-mt7622-nor
|
define Package/arm-trusted-firmware-mt7622-nor
|
||||||
|
@ -29,39 +29,26 @@ define Package/arm-trusted-firmware-tools
|
|||||||
BUILDONLY:=1
|
BUILDONLY:=1
|
||||||
endef
|
endef
|
||||||
|
|
||||||
HOST_CFLAGS += -Wall -Werror -pedantic -std=c99
|
|
||||||
define Host/Compile
|
define Host/Compile
|
||||||
$(MAKE) -C \
|
|
||||||
$(HOST_BUILD_DIR)/tools/cert_create \
|
|
||||||
CFLAGS="$(HOST_CFLAGS)" \
|
|
||||||
LDFLAGS="$(HOST_LDFLAGS)"
|
|
||||||
$(MAKE) -C \
|
|
||||||
$(HOST_BUILD_DIR)/tools/encrypt_fw \
|
|
||||||
CFLAGS="$(HOST_CFLAGS)" \
|
|
||||||
LDFLAGS="$(HOST_LDFLAGS)"
|
|
||||||
$(MAKE) -C \
|
$(MAKE) -C \
|
||||||
$(HOST_BUILD_DIR)/tools/fiptool \
|
$(HOST_BUILD_DIR)/tools/fiptool \
|
||||||
CFLAGS="$(HOST_CFLAGS)" \
|
CPPFLAGS="$(HOST_CFLAGS)" \
|
||||||
LDFLAGS="$(HOST_LDFLAGS)"
|
LDFLAGS="$(HOST_LDFLAGS)"
|
||||||
$(MAKE) -C \
|
$(MAKE) -C \
|
||||||
$(HOST_BUILD_DIR)/tools/sptool \
|
$(HOST_BUILD_DIR)/tools/sptool \
|
||||||
CFLAGS="$(HOST_CFLAGS)" \
|
CPPFLAGS="$(HOST_CFLAGS)" \
|
||||||
LDFLAGS="$(HOST_LDFLAGS)"
|
LDFLAGS="$(HOST_LDFLAGS)"
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Host/Install
|
define Host/Install
|
||||||
$(INSTALL_DIR) $(STAGING_DIR_HOST)/bin/
|
$(INSTALL_DIR) $(STAGING_DIR_HOST)/bin/
|
||||||
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/fiptool/fiptool $(STAGING_DIR_HOST)/bin/
|
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/fiptool/fiptool $(STAGING_DIR_HOST)/bin/
|
||||||
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/cert_create/cert_create $(STAGING_DIR_HOST)/bin/
|
|
||||||
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/encrypt_fw/encrypt_fw $(STAGING_DIR_HOST)/bin/
|
|
||||||
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/sptool/sptool $(STAGING_DIR_HOST)/bin/
|
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/sptool/sptool $(STAGING_DIR_HOST)/bin/
|
||||||
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/sptool/sp_mk_generator.py $(STAGING_DIR_HOST)/bin/
|
$(INSTALL_BIN) $(HOST_BUILD_DIR)/tools/sptool/sp_mk_generator.py $(STAGING_DIR_HOST)/bin/
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Host/Clean
|
define Host/Clean
|
||||||
rm -f $(STAGING_DIR_HOST)/bin/fiptool
|
rm -f $(STAGING_DIR_HOST)/bin/fiptool
|
||||||
rm -f $(STAGING_DIR_HOST)/bin/cert_create
|
|
||||||
rm -f $(STAGING_DIR_HOST)/bin/encrypt_fw
|
|
||||||
rm -f $(STAGING_DIR_HOST)/bin/sptool
|
rm -f $(STAGING_DIR_HOST)/bin/sptool
|
||||||
rm -f $(STAGING_DIR_HOST)/bin/sp_mk_generator.py
|
rm -f $(STAGING_DIR_HOST)/bin/sp_mk_generator.py
|
||||||
endef
|
endef
|
||||||
|
@ -0,0 +1,11 @@
|
|||||||
|
--- a/tools/fiptool/Makefile
|
||||||
|
+++ b/tools/fiptool/Makefile
|
||||||
|
@@ -38,7 +38,7 @@
|
||||||
|
|
||||||
|
${PROJECT}: ${OBJECTS} Makefile
|
||||||
|
@echo " HOSTLD $@"
|
||||||
|
- ${Q}${HOSTCC} ${OBJECTS} -o $@ ${LDLIBS}
|
||||||
|
+ ${Q}${HOSTCC} ${OBJECTS} -o $@ ${LDLIBS} $(LDFLAGS)
|
||||||
|
@${ECHO_BLANK_LINE}
|
||||||
|
@echo "Built $@ successfully"
|
||||||
|
@${ECHO_BLANK_LINE}
|
24
package/kernel/ath10k-ct/patches/300-mac80211-5.10.patch
Normal file
24
package/kernel/ath10k-ct/patches/300-mac80211-5.10.patch
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
--- a/ath10k-5.8/wmi.c
|
||||||
|
+++ b/ath10k-5.8/wmi.c
|
||||||
|
@@ -4254,7 +4254,7 @@ void ath10k_wmi_event_host_swba(struct a
|
||||||
|
* actual channel switch is done
|
||||||
|
*/
|
||||||
|
if (arvif->vif->csa_active &&
|
||||||
|
- ieee80211_csa_is_complete(arvif->vif)) {
|
||||||
|
+ ieee80211_beacon_cntdwn_is_complete(arvif->vif)) {
|
||||||
|
ieee80211_csa_finish(arvif->vif);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
--- a/ath10k-5.8/mac.c
|
||||||
|
+++ b/ath10k-5.8/mac.c
|
||||||
|
@@ -2295,8 +2295,8 @@ static void ath10k_mac_vif_ap_csa_count_
|
||||||
|
if (!arvif->is_up)
|
||||||
|
return;
|
||||||
|
|
||||||
|
- if (!ieee80211_csa_is_complete(vif)) {
|
||||||
|
- ieee80211_csa_update_counter(vif);
|
||||||
|
+ if (!ieee80211_beacon_cntdwn_is_complete(vif)) {
|
||||||
|
+ ieee80211_beacon_update_cntdwn(vif);
|
||||||
|
|
||||||
|
ret = ath10k_mac_setup_bcn_tmpl(arvif);
|
||||||
|
if (ret)
|
@ -8,7 +8,7 @@ include $(TOPDIR)/rules.mk
|
|||||||
include $(INCLUDE_DIR)/kernel.mk
|
include $(INCLUDE_DIR)/kernel.mk
|
||||||
|
|
||||||
PKG_NAME:=ltq-ptm
|
PKG_NAME:=ltq-ptm
|
||||||
PKG_RELEASE:=2
|
PKG_RELEASE:=3
|
||||||
|
|
||||||
PKG_MAINTAINER:=John Crispin <john@phrozen.org>
|
PKG_MAINTAINER:=John Crispin <john@phrozen.org>
|
||||||
PKG_LICENSE:=GPL-2.0+
|
PKG_LICENSE:=GPL-2.0+
|
||||||
|
@ -79,7 +79,18 @@ struct wan_tx_mib_table {
|
|||||||
|
|
||||||
#if defined(__BIG_ENDIAN)
|
#if defined(__BIG_ENDIAN)
|
||||||
|
|
||||||
struct fw_ver_id {
|
struct fw_ver_id_new { // @2000
|
||||||
|
/* 0 - 3h */
|
||||||
|
unsigned int family :4;
|
||||||
|
unsigned int package :4;
|
||||||
|
unsigned int major :8;
|
||||||
|
unsigned int middle :8;
|
||||||
|
unsigned int minor :8;
|
||||||
|
/* 4 - 7h */
|
||||||
|
unsigned int features :32;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct fw_ver_id { // @2001
|
||||||
unsigned int family :4;
|
unsigned int family :4;
|
||||||
unsigned int fwtype :4;
|
unsigned int fwtype :4;
|
||||||
unsigned int interface :4;
|
unsigned int interface :4;
|
||||||
|
@ -31,6 +31,7 @@
|
|||||||
/*
|
/*
|
||||||
* Host-PPE Communication Data Address Mapping
|
* Host-PPE Communication Data Address Mapping
|
||||||
*/
|
*/
|
||||||
|
#define FW_VER_ID_NEW ((volatile struct fw_ver_id_new *) SB_BUFFER(0x2000))
|
||||||
#define FW_VER_ID ((volatile struct fw_ver_id *) SB_BUFFER(0x2001))
|
#define FW_VER_ID ((volatile struct fw_ver_id *) SB_BUFFER(0x2001))
|
||||||
#define CFG_STD_DATA_LEN ((volatile struct cfg_std_data_len *) SB_BUFFER(0x2011))
|
#define CFG_STD_DATA_LEN ((volatile struct cfg_std_data_len *) SB_BUFFER(0x2011))
|
||||||
#define TX_QOS_CFG ((volatile struct tx_qos_cfg *) SB_BUFFER(0x2012))
|
#define TX_QOS_CFG ((volatile struct tx_qos_cfg *) SB_BUFFER(0x2012))
|
||||||
|
@ -3,40 +3,38 @@
|
|||||||
|
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
|
** FILE NAME : ppa_datapath_fw_vr9_e1.h
|
||||||
|
** PROJECT : PPA
|
||||||
|
** PLATFORM : VR9
|
||||||
|
** MODULES : E1
|
||||||
**
|
**
|
||||||
** FILE NAME : ifxmips_ptm_fw_vr9.h
|
** DATE : 01/08/2014
|
||||||
** PROJECT : UEIP
|
** AUTHOR : Lantiq PPE FW Team
|
||||||
** MODULES : PTM (VDSL)
|
** DESCRIPTION : VR9 E1 PPE Firmware Binary
|
||||||
**
|
** COPYRIGHT : Copyright (c) 2014
|
||||||
** DATE : 22 OCT 2007
|
** Lantiq Deutschland GmbH
|
||||||
** AUTHOR : Xu Liang
|
|
||||||
** DESCRIPTION : PTM Driver (PP32 Firmware)
|
|
||||||
** COPYRIGHT : Copyright (c) 2006
|
|
||||||
** Infineon Technologies AG
|
|
||||||
** Am Campeon 1-12, 85579 Neubiberg, Germany
|
|
||||||
**
|
**
|
||||||
** This program is free software; you can redistribute it and/or modify
|
** This program is free software; you can redistribute it and/or modify
|
||||||
** it under the terms of the GNU General Public License as published by
|
** it under the terms of the GNU General Public License as published by
|
||||||
** the Free Software Foundation; either version 2 of the License, or
|
** the Free Software Foundation; either version 2 of the License, or
|
||||||
** (at your option) any later version.
|
** (at your option) any later version.
|
||||||
**
|
**
|
||||||
|
** FW VERSION [31:0] : 0x73021000
|
||||||
|
** FW FEATURE [31:0] : 0xB0000000
|
||||||
|
** MERCURIAL TAG : PTM_FW_PPA_2.16_Pre_Rel_04@default@ptm_fw
|
||||||
|
**
|
||||||
** HISTORY
|
** HISTORY
|
||||||
** $Date $Author $Comment
|
** $Date $Author $Comment
|
||||||
** 22 OCT 2007 Xu Liang Initiate Version, v00.01
|
** 01/08/2014 Lantiq PPE FW Team VR9 E1 PPE Firmware Binary
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
#define PTM_FW_VER_MAJOR 0
|
|
||||||
#define PTM_FW_VER_MINOR 30
|
|
||||||
|
|
||||||
|
|
||||||
static unsigned int firmware_binary_code[] = {
|
static unsigned int firmware_binary_code[] = {
|
||||||
0x80000980, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x80000980, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x8000ffe0, 0x00000000, 0x00000000, 0x00000000,
|
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x8000ffe0, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0xc1c20002, 0xd9cc00f8, 0xc0006950, 0xcbc000f8, 0xc0004024, 0xc8c000f8, 0xc0006950, 0x5bfc0002,
|
0xc1c20002, 0xd9cc00f8, 0xc0006950, 0xcbc000f8, 0xc0004024, 0xc8c000f8, 0xc0006950, 0x5bfc0002,
|
||||||
0xcfc000f8, 0xa4c252a2, 0x00000000, 0x00000000, 0x800007a0, 0x00000000, 0x00000000, 0x00000000,
|
0xa9446c0a, 0xcfc000f8, 0x00000000, 0xa4c26a1a, 0x00000000, 0x00000000, 0x80000790, 0x00000000,
|
||||||
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x94000001, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
@ -69,199 +67,272 @@ static unsigned int firmware_binary_code[] = {
|
|||||||
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0xc0e1fffe, 0x58cdfffe, 0xc1e1fffa, 0x59ddfffe, 0x94000001, 0x00000000, 0x00000000, 0x00000000,
|
0xc0e1fffe, 0x58cdfffe, 0xc1e1fffa, 0x59ddfffe, 0x94000001, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0xc0e1fffe, 0x58cdfffe, 0xc1e1fffa, 0x59ddfffe, 0x900009a1, 0x00000000, 0x00000000, 0x00000000,
|
0xc0e1fffe, 0x58cdfffe, 0xc1e1fffa, 0x59ddfffe, 0x900009a1, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0x90cc0941, 0x00000000, 0x00000000, 0x00000000, 0xc3e0e2a2, 0x5bfc003c, 0xc0004002, 0xcfc000f8,
|
0x90cc0941, 0x00000000, 0x00000000, 0x00000000, 0xc0004010, 0xd14000f8, 0xc000400c, 0xc8c000f8,
|
||||||
0xc3c00000, 0xc0004024, 0xcbc20078, 0x00000000, 0x00000000, 0xc1c00000, 0xd9c400f9, 0xdbc40078,
|
0xc1c1fffe, 0xd9d7e700, 0x45cce000, 0xc1c00002, 0xd9d40704, 0xc3e0e604, 0x5bfc2000, 0xc0004000,
|
||||||
0xc1c00006, 0xd9c400f9, 0xc3c0fc10, 0xc0006952, 0xcfc000f8, 0xc3c00000, 0xc3400000, 0xc3000040,
|
0xcfc000f8, 0xc3e16000, 0x5bfc0000, 0xc0004002, 0xcfc000f8, 0xc0008fde, 0xc1c00000, 0xcdc000f8,
|
||||||
0xc2c00080, 0x6ff8a000, 0x5bb87d00, 0x5838001c, 0xcf4000f8, 0x5838001e, 0xcec000f8, 0x58380020,
|
0xc0007e22, 0xc9c000f8, 0x00000000, 0x00000000, 0x5ddc0000, 0x84000022, 0xc0008fde, 0xc1c00002,
|
||||||
0xcf4000f8, 0x58380022, 0xcf0000f8, 0x5bfc0002, 0x5ebc0004, 0x8400ffa0, 0x00000000, 0xc1e1fffe,
|
0xcdc000f8, 0xc3c00000, 0xc0004024, 0xcbc20078, 0x00000000, 0x00000000, 0xc1c00000, 0xd9c400f9,
|
||||||
0x59ddfffa, 0x141c0000, 0xc1c00000, 0xc000691c, 0xcdc000f8, 0xab64002a, 0xc3c00000, 0xab66001a,
|
0xdbc40078, 0xc1c00006, 0xd9c400f9, 0xc000403c, 0xcfc000f8, 0xc3c0fc10, 0xc0006952, 0xcfc000f8,
|
||||||
0xc3c00002, 0x80001130, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x6ff8a000, 0x5bb87d00, 0x58380004,
|
0xc3c00000, 0xc3400000, 0xc3000040, 0xc2c00080, 0x6ff8a000, 0x5bb87d00, 0x5838001c, 0xcf4000f8,
|
||||||
0xcb4000f8, 0xc2800000, 0x58380000, 0xca820008, 0xc000e824, 0xc3000000, 0xcb3c0070, 0x6f5c8000,
|
0x5838001e, 0xcec000f8, 0x58380020, 0xcf4000f8, 0x58380022, 0xcf0000f8, 0x5bfc0002, 0x5ebc0004,
|
||||||
0x41f4e000, 0x431d8000, 0x5b304000, 0xc000e828, 0xc1c00000, 0xc9fc0070, 0x00000000, 0xc0004000,
|
0x8400ffa0, 0x00000000, 0xc1e1fffe, 0x59ddfffa, 0x141c0000, 0xc0004010, 0xd14000f8, 0xc000400c,
|
||||||
0x41f4e000, 0x401c0000, 0xcac000f8, 0x5de80004, 0x84000880, 0xa6c607ea, 0x00000000, 0x6fe42000,
|
0xc8c000f8, 0xc1c1fffe, 0xd9d7e700, 0x45cce000, 0xc1c00002, 0xd9d40704, 0xc1c00000, 0xc000691c,
|
||||||
0xc6e4a000, 0x6e60a000, 0x5a207b00, 0xc1800000, 0x58200000, 0xc9800000, 0xc2800000, 0xc6e80010,
|
0xcdc000f8, 0xab64002a, 0xc3c00000, 0xab66001a, 0xc3c00002, 0x80001248, 0xc1c00002, 0xc000691c,
|
||||||
0x5dd80000, 0x8400003a, 0x5de80008, 0xc6a82012, 0xc1c00004, 0x45e8e000, 0x88000030, 0x80000558,
|
0xcdc000f8, 0x6ff8a000, 0x5bb87d00, 0x58380004, 0xcb4000f8, 0xc2800000, 0x58380000, 0xca820008,
|
||||||
0x5de80004, 0xc6a8010a, 0x5de80008, 0x84000538, 0x58380000, 0xc1c00002, 0xcdc00000, 0x58200000,
|
0xc000e824, 0xc3000000, 0xcb3c0070, 0x6f5c8000, 0x41f4e000, 0x431d8000, 0x5b304000, 0xc000e828,
|
||||||
0xc1c00002, 0xcdc00000, 0x5de80002, 0xcdc00002, 0xc000ea14, 0xc1e20000, 0xcdfe3100, 0xc000fb60,
|
0xc1c00000, 0xc9fc0070, 0x00000000, 0xc0004000, 0x41f4e000, 0x401c0000, 0xcac000f8, 0x5de80004,
|
||||||
0xc1c00002, 0xcdfc0000, 0xc0006940, 0xc9c000f8, 0x403c0000, 0x00000000, 0x59dc0002, 0xcdc000f8,
|
0x84000988, 0xa6c608f2, 0x00000000, 0x6fe42000, 0xc6e4a000, 0x6e60a000, 0x5a207b00, 0xc1800000,
|
||||||
0xc1c00004, 0x45e8e000, 0x880000fa, 0x58200020, 0xc9c000f8, 0xc0c00018, 0xc1000000, 0xa5c0002a,
|
0x58200000, 0xc9800000, 0xc2800000, 0xc6e80010, 0x5dd80000, 0x8400003a, 0x5de80008, 0xc6a82012,
|
||||||
0xc1400080, 0x5de80000, 0xc6ccf930, 0xc54c1932, 0x5de80000, 0xc1c0000a, 0xc5cc1230, 0xc5cc3202,
|
0xc1c00004, 0x45e8e000, 0x88000030, 0x80000650, 0x5de80004, 0xc6a8010a, 0x5de80008, 0x84000630,
|
||||||
0x58200022, 0xc9c000f8, 0xc74c0b30, 0xc7cc0008, 0xc5cc0528, 0xc1800000, 0xc6982000, 0xc1c00000,
|
0x58380000, 0xc1c00002, 0xcdc00000, 0x58200000, 0xc1c00002, 0xcdc00000, 0x5de80002, 0xcdc00002,
|
||||||
0xc69c0000, 0x71d8e000, 0xc5cc0400, 0x98404c78, 0xc5d00000, 0x7d80e000, 0xc5d00100, 0x5dd80002,
|
0xc000ea14, 0xc1e20000, 0xcdfe3100, 0xc000fb60, 0xc1c00002, 0xcdfc0000, 0xc0006940, 0xc9c000f8,
|
||||||
0x84000388, 0xc1c00000, 0xc6ddc030, 0x59dc0006, 0xc5ec0e30, 0xc0c00018, 0xc1000004, 0x59dc0002,
|
0x403c0000, 0x00000000, 0x59dc0002, 0xcdc000f8, 0xc1c00004, 0x45e8e000, 0x880000fa, 0x58200020,
|
||||||
0xc5cc1230, 0xc74c0b30, 0xc7cc0008, 0xc0000088, 0x441ce000, 0xc5cc1930, 0xa6cc02b0, 0xc1c80002,
|
0xc9c000f8, 0xc0c00018, 0xc1000000, 0xa5c0002a, 0xc1400080, 0x5de80000, 0xc6ccf930, 0xc54c1932,
|
||||||
0x70dc6000, 0xc1400000, 0xc6d5c030, 0x5d540002, 0x6d5c4010, 0x431c0000, 0xc88000f8, 0xc1c00000,
|
0x5de80000, 0xc1c0000a, 0xc5cc1230, 0xc5cc3202, 0x58200022, 0xc9c000f8, 0xc74c0b30, 0xc7cc0008,
|
||||||
0xc55c0008, 0xc0000006, 0x441ce000, 0x6ddc6000, 0x689c4010, 0xc1c001fe, 0x749c4000, 0x59540002,
|
0xc5cc0528, 0xc1800000, 0xc6982000, 0xc1c00000, 0xc69c0000, 0x71d8e000, 0xc5cc0400, 0x98406308,
|
||||||
0xc1c000fe, 0x749c4000, 0x5c880020, 0xc48c1930, 0x4148c000, 0x59980002, 0x5dd80088, 0x8800002a,
|
0xc5d00000, 0x7d80e000, 0xc5d00100, 0x5dd80002, 0x84000480, 0xc1c00000, 0xc6ddc030, 0x59dc0006,
|
||||||
0x58200000, 0xc1c00000, 0xcdc00000, 0x800000c8, 0xc1400000, 0x6d9c4010, 0x431c0000, 0xc94000f8,
|
0xc5ec0e30, 0xc0c00018, 0xc1000004, 0x59dc0002, 0xc5cc1230, 0xc74c0b30, 0xc7cc0008, 0xc0000088,
|
||||||
0xc1c00000, 0xc59c0008, 0xc0000006, 0x441ce000, 0x6ddc6000, 0x695ca010, 0xc1c001fe, 0x755ca000,
|
0x441ce000, 0xc5cc1930, 0xa6cc03a8, 0x583cfac0, 0xc94000f8, 0xc1c80002, 0x70dc6000, 0xa55000c2,
|
||||||
0x00000000, 0x00000000, 0x5dd40000, 0x84000018, 0x59980002, 0x8000ff48, 0x59980002, 0xc0800002,
|
0x58380024, 0xc94000f8, 0x00000000, 0x00000000, 0x59540002, 0x58380024, 0xcd4000f8, 0xc0c00010,
|
||||||
0x5dd400a0, 0xc4902100, 0xc4ac2602, 0x4588c002, 0xdbc800f9, 0xda4800f8, 0xda1000f9, 0x90404391,
|
0x98406308, 0xc74c0b30, 0xc7cc0008, 0xc1000004, 0x58200000, 0xc1c00000, 0xcdc00000, 0x58380026,
|
||||||
0x58200020, 0xc9c000f8, 0x58200022, 0xc94000f8, 0x5ddc0002, 0xc1c00000, 0xc5cc1932, 0xc6ddc030,
|
0xc94000f8, 0x00000000, 0x00000000, 0x59540002, 0x58380026, 0xcd4000f8, 0x800002c0, 0xc1400000,
|
||||||
0x59dc0002, 0x98404c78, 0xc5cc1230, 0xc54c0528, 0xc4d08000, 0xa5020072, 0xc1c00002, 0xc5d00100,
|
0xc6d5c030, 0x5d540002, 0x6d5c4010, 0x431c0000, 0xc88000f8, 0xc1c00000, 0xc55c0008, 0xc0000006,
|
||||||
0xc5ac0e30, 0xa6ccfdc2, 0xc1c00000, 0xc5cc0400, 0xc1c00086, 0x45d8e000, 0xc5cc1930, 0x8000ff28,
|
0x441ce000, 0x6ddc6000, 0x689c4010, 0xc1c001fe, 0x749c4000, 0x59540002, 0xc1c000fe, 0x749c4000,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0x80000070, 0xdbc800f9, 0xda4800f8, 0xda1000f9, 0x90404391,
|
0x5c880020, 0xc48c1930, 0x5dc80002, 0x8800fee2, 0xc1c0007c, 0x45c8e000, 0x8800feca, 0x4148c000,
|
||||||
0x58200022, 0xc98000f8, 0x58200020, 0xc9c000f8, 0x00000000, 0x98404c78, 0x5ddc0002, 0xc58c0528,
|
0x59980002, 0x5dd80088, 0x8800002a, 0x58200000, 0xc1c00000, 0xcdc00000, 0x800000c8, 0xc1400000,
|
||||||
0xc5cc1932, 0x80000200, 0xc1400000, 0xc000403e, 0xc9400000, 0xc1800000, 0x58200000, 0xc9800000,
|
0x6d9c4010, 0x431c0000, 0xc94000f8, 0xc1c00000, 0xc59c0008, 0xc0000006, 0x441ce000, 0x6ddc6000,
|
||||||
0x5dd40002, 0x84000020, 0x5dd80002, 0x84000010, 0x80000110, 0x5de80006, 0x84000088, 0x58380000,
|
0x695ca010, 0xc1c001fe, 0x755ca000, 0x00000000, 0x00000000, 0x5dd40000, 0x84000018, 0x59980002,
|
||||||
0xc1c00002, 0xcdc00000, 0xc000ea14, 0xc1e20000, 0xcdfe3100, 0xc000fb60, 0xc1c20002, 0xcdfc2100,
|
0x8000ff48, 0x59980002, 0xc0800002, 0x5dd400a0, 0xc4902100, 0xc4ac2602, 0x4588c002, 0xdbc800f9,
|
||||||
0xc0006944, 0xc9c000f8, 0x403c0000, 0x00000000, 0x59dc0002, 0xcdc000f8, 0x800000f0, 0x5de8000a,
|
0xda4800f8, 0xda1000f9, 0x90405849, 0x58200020, 0xc9c000f8, 0x58200022, 0xc94000f8, 0x5ddc0002,
|
||||||
0x84000070, 0x58380000, 0xc1c00000, 0xcdc00000, 0xc000ea14, 0xc1e20002, 0xcdfe3100, 0xc000fb60,
|
0xc1c00000, 0xc5cc1932, 0xc6ddc030, 0x59dc0002, 0x98406308, 0xc5cc1230, 0xc54c0528, 0xc4d08000,
|
||||||
0xc1c20002, 0xcdfc2100, 0xc000facc, 0xc1c00002, 0xcdfc0000, 0x80000078, 0xa6ca0040, 0xc000facc,
|
0xa5020072, 0xc1c00002, 0xc5d00100, 0xc5ac0e30, 0xa6ccfd9a, 0xc1c00000, 0xc5cc0400, 0xc1c00086,
|
||||||
0xc1ca0002, 0xcdfca500, 0xc000fb64, 0xc1c60002, 0xcdfc6300, 0x80000038, 0xc000facc, 0xc1c80002,
|
0x45d8e000, 0xc5cc1930, 0x8000ff28, 0x00000000, 0x00000000, 0x00000000, 0x80000070, 0xdbc800f9,
|
||||||
0xcdfc8400, 0xc000fb64, 0xc1c40002, 0xcdfc4200, 0xc0c00010, 0x98404c78, 0xc7cc0008, 0xc74c0b30,
|
0xda4800f8, 0xda1000f9, 0x90405849, 0x58200022, 0xc98000f8, 0x58200020, 0xc9c000f8, 0x00000000,
|
||||||
0xc1000004, 0x80000808, 0xc1c00002, 0x58380008, 0xcdc000f8, 0x58380000, 0xc1e00006, 0xcdc21008,
|
0x98406308, 0x5ddc0002, 0xc58c0528, 0xc5cc1932, 0x80000210, 0xc1400000, 0xc000403e, 0xc9400000,
|
||||||
0xc000facc, 0xc1c80002, 0xcdfc8400, 0xc000fb64, 0xc1c40002, 0xcdfc4200, 0xc0c00010, 0x98404c78,
|
0xc1800000, 0x58200000, 0xc9800000, 0x5dd40002, 0x84000020, 0x5dd80002, 0x84000010, 0x80000120,
|
||||||
0xc7cc0008, 0xc74c0b30, 0xc1000004, 0x80000778, 0x5de80006, 0x84000170, 0xa6c60032, 0x00000000,
|
0x5de80006, 0x84000088, 0x58380000, 0xc1c00002, 0xcdc00000, 0xc000ea14, 0xc1e20000, 0xcdfe3100,
|
||||||
0x58380000, 0xc1e00004, 0xcdc21008, 0x8000f760, 0x58380008, 0xca8000f8, 0xc2400000, 0x58380002,
|
0xc000fb60, 0xc1c20002, 0xcdfc2100, 0xc0006944, 0xc9c000f8, 0x403c0000, 0x00000000, 0x59dc0002,
|
||||||
0xca420078, 0x00000000, 0x5aa80002, 0x58380008, 0xce8000f8, 0x46a4e000, 0x8800008a, 0x58380000,
|
0xcdc000f8, 0x80000100, 0x5de8000a, 0x84000080, 0x58380000, 0xc1c00000, 0xcdc00000, 0xc000ea14,
|
||||||
0xc1e00002, 0xcdc21008, 0x58380000, 0xc1c00000, 0xcdc00000, 0xc000facc, 0xc1c20002, 0xcdfc2100,
|
0xc1c00000, 0xdd5c5100, 0x7dc0e000, 0xcdfe3100, 0xc000fb60, 0xc1c20002, 0xcdfc2100, 0xc000facc,
|
||||||
0xc1e1e1a2, 0xc000ea1c, 0xcdfc00f8, 0xc000ea14, 0xc1e20002, 0xcdfe3100, 0x80000038, 0xc000facc,
|
0xc1c00002, 0xcdfc0000, 0x80000078, 0xa6ca0040, 0xc000facc, 0xc1ca0002, 0xcdfca500, 0xc000fb64,
|
||||||
0xc1c80002, 0xcdfc8400, 0xc000fb64, 0xc1c40002, 0xcdfc4200, 0xc0c00010, 0x98404c78, 0xc7cc0008,
|
0xc1c60002, 0xcdfc6300, 0x80000038, 0xc000facc, 0xc1c80002, 0xcdfc8400, 0xc000fb64, 0xc1c40002,
|
||||||
0xc74c0b30, 0xc1000004, 0x80000600, 0x5de80002, 0x84000150, 0xa6c6004a, 0x00000000, 0x58380000,
|
0xcdfc4200, 0xc0c00010, 0x98406308, 0xc7cc0008, 0xc74c0b30, 0xc1000004, 0x80000818, 0xc1c00002,
|
||||||
0xc1e00004, 0xcdc21008, 0xc1f8001e, 0xc000ea1c, 0xcdfc00f8, 0x8000f5d0, 0x58380008, 0xca8000f8,
|
0x58380008, 0xcdc000f8, 0x58380000, 0xc1e00006, 0xcdc21008, 0xc000facc, 0xc1c80002, 0xcdfc8400,
|
||||||
0xc2400000, 0x58380002, 0xca400078, 0xc000facc, 0xc1c20002, 0xcdfc2100, 0x5aa80002, 0x58380008,
|
0xc000fb64, 0xc1c40002, 0xcdfc4200, 0xc0c00010, 0x98406308, 0xc7cc0008, 0xc74c0b30, 0xc1000004,
|
||||||
0xce8000f8, 0x46a4e000, 0x88000072, 0x58380000, 0xc1e00000, 0xcdc21008, 0xc1c00000, 0x58380006,
|
0x80000788, 0x5de80006, 0x84000180, 0xa6c60032, 0x00000000, 0x58380000, 0xc1e00004, 0xcdc21008,
|
||||||
0xcdc000f8, 0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc000e820, 0xc1c00000, 0xcdfc0000, 0x80000300,
|
0x8000f658, 0x58380008, 0xca8000f8, 0xc2400000, 0x58380002, 0xca420078, 0x00000000, 0x5aa80002,
|
||||||
0xc0c00010, 0x98404c78, 0xc7cc0008, 0xc74c0b30, 0xc1000004, 0x800004a8, 0x5838001c, 0xca8000f8,
|
0x58380008, 0xce8000f8, 0x46a4e000, 0x8800009a, 0x58380000, 0xc1e00002, 0xcdc21008, 0x58380000,
|
||||||
0x5838001e, 0xca4000f8, 0x5aa80002, 0x5838001c, 0xce8000f8, 0x4668e000, 0x88000098, 0x58380022,
|
0xc1c00000, 0xcdc00000, 0xc000facc, 0xc1c20002, 0xcdfc2100, 0xc1e1e1a2, 0xc000ea1c, 0xcdfc00f8,
|
||||||
0xca4000f8, 0x58380020, 0xca0000f8, 0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc000e810, 0xce7c0030,
|
0xc000ea14, 0xc1c00000, 0xdd5c5100, 0x7dc0e000, 0xcdfe3100, 0x80000038, 0xc000facc, 0xc1c80002,
|
||||||
0xc2800000, 0x5838001c, 0xce8000f8, 0x5a200002, 0x58380020, 0xce0000f8, 0xc000e82c, 0xc1dc0002,
|
0xcdfc8400, 0xc000fb64, 0xc1c40002, 0xcdfc4200, 0xc0c00010, 0x98406308, 0xc7cc0008, 0xc74c0b30,
|
||||||
0xcdfdce00, 0x58380006, 0xc8c000f8, 0x5830001c, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001,
|
0xc1000004, 0x80000600, 0x5de80002, 0x84000150, 0xa6c6004a, 0x00000000, 0x58380000, 0xc1e00004,
|
||||||
0x5dcc0006, 0x88000028, 0x58cc0002, 0x58380006, 0xccc000f8, 0x80000250, 0x5838000a, 0xc8c000f9,
|
0xcdc21008, 0xc1f8001e, 0xc000ea1c, 0xcdfc00f8, 0x8000f4b8, 0x58380008, 0xca8000f8, 0xc2400000,
|
||||||
0xc90000f9, 0xc1400000, 0xc9400001, 0x74e86000, 0x75248000, 0x7560a000, 0x58380010, 0xca8000f9,
|
0x58380002, 0xca400078, 0xc000facc, 0xc1c20002, 0xcdfc2100, 0x5aa80002, 0x58380008, 0xce8000f8,
|
||||||
0xca4000f9, 0xc2000000, 0xca000001, 0x98404de8, 0x74e86000, 0x75248000, 0x7560a000, 0x5dc800a0,
|
0x46a4e000, 0x88000072, 0x58380000, 0xc1e00000, 0xcdc21008, 0xc1c00000, 0x58380006, 0xcdc000f8,
|
||||||
0x840001ba, 0x58380016, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x98404de8, 0x74e86000,
|
0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc000e820, 0xc1c00000, 0xcdfc0000, 0x80000300, 0xc0c00010,
|
||||||
0x75248000, 0x7560a000, 0x5dc800a0, 0x84000162, 0x58380000, 0xc1e00004, 0xcdc21008, 0x5838001c,
|
0x98406308, 0xc7cc0008, 0xc74c0b30, 0xc1000004, 0x800004a8, 0x5838001c, 0xca8000f8, 0x5838001e,
|
||||||
0xc1c00000, 0xcdc000f8, 0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc1f8001e, 0xc000ea1c, 0xcdfc00f8,
|
0xca4000f8, 0x5aa80002, 0x5838001c, 0xce8000f8, 0x4668e000, 0x88000098, 0x58380022, 0xca4000f8,
|
||||||
0xc000e820, 0xc1c00002, 0xcdfc0000, 0xc1c00082, 0x45c8e000, 0xc000e810, 0xcdfc0030, 0xc2400000,
|
0x58380020, 0xca0000f8, 0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc000e810, 0xce7c0030, 0xc2800000,
|
||||||
0xc000e82c, 0xca7c0038, 0xc000e83c, 0xc2800000, 0xcabc0038, 0xc0c00010, 0x98404c78, 0xc7cc0008,
|
0x5838001c, 0xce8000f8, 0x5a200002, 0x58380020, 0xce0000f8, 0xc000e82c, 0xc1dc0002, 0xcdfdce00,
|
||||||
0xc74c0b30, 0xc1000004, 0x5b740002, 0x4674e000, 0xc1c00000, 0xc5f400fe, 0x5ea80002, 0x8400ffb0,
|
0x58380006, 0xc8c000f8, 0x5830001c, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x5dcc0006,
|
||||||
0xc000e83c, 0xc1c00000, 0xcdfc0038, 0xc000e82c, 0xc1dc0002, 0xcdfdce00, 0x80000178, 0x58380010,
|
0x88000028, 0x58cc0002, 0x58380006, 0xccc000f8, 0x80000250, 0x5838000a, 0xc8c000f9, 0xc90000f9,
|
||||||
0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x58380016, 0xce8000f9, 0xce4000f9, 0xce000001,
|
0xc1400000, 0xc9400001, 0x74e86000, 0x75248000, 0x7560a000, 0x58380010, 0xca8000f9, 0xca4000f9,
|
||||||
0x5838000a, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x58380010, 0xce8000f9, 0xce4000f9,
|
0xc2000000, 0xca000001, 0x984064d8, 0x74e86000, 0x75248000, 0x7560a000, 0x5dc800a0, 0x840001ba,
|
||||||
0xce000001, 0x5830001c, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x5838000a, 0xce8000f9,
|
0x58380016, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x984064d8, 0x74e86000, 0x75248000,
|
||||||
0xce4000f9, 0xce000001, 0xc000facc, 0xc1c20002, 0xcdfc2100, 0xc0c00010, 0x98404c78, 0xc7cc0008,
|
0x7560a000, 0x5dc800a0, 0x84000162, 0x58380000, 0xc1e00004, 0xcdc21008, 0x5838001c, 0xc1c00000,
|
||||||
0xc74c0b30, 0xc1000004, 0xc000e83c, 0xc1d00002, 0xcdfd0800, 0xc0c00000, 0xc000e82c, 0xc8fc0038,
|
0xcdc000f8, 0xc000e82c, 0xc1c00000, 0xcdfdce00, 0xc1f8001e, 0xc000ea1c, 0xcdfc00f8, 0xc000e820,
|
||||||
0x5b740002, 0x00000000, 0x44f4e000, 0xc1c00000, 0xc5f400fe, 0x58380004, 0xcf4000f8, 0x98404ec0,
|
0xc1c00002, 0xcdfc0000, 0xc1c00082, 0x45c8e000, 0xc000e810, 0xcdfc0030, 0xc2400000, 0xc000e82c,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0xc0006914, 0xcbc000f8, 0xc2800000, 0xc2400000, 0x5bfc4b00,
|
0xca7c0038, 0xc000e83c, 0xc2800000, 0xcabc0038, 0xc0c00010, 0x98406308, 0xc7cc0008, 0xc74c0b30,
|
||||||
0xc7c000f8, 0xcb0000f8, 0x58000002, 0xcac000f8, 0xc0004026, 0xca800078, 0xc0004026, 0xca420078,
|
0xc1000004, 0x5b740002, 0x4674e000, 0xc1c00000, 0xc5f400fe, 0x5ea80002, 0x8400ffb0, 0xc000e83c,
|
||||||
0xc3400000, 0xc7366018, 0xa73e0172, 0x00000000, 0xc777e300, 0xc000694c, 0xc9c000f8, 0x00000000,
|
0xc1c00000, 0xcdfc0038, 0xc000e82c, 0xc1dc0002, 0xcdfdce00, 0x80000178, 0x58380010, 0xca8000f9,
|
||||||
0x00000000, 0x59dc0002, 0xcdc000f8, 0x6f5c6000, 0x58dcb640, 0x580c0000, 0xc90000f8, 0x580c0002,
|
0xca4000f9, 0xc2000000, 0xca000001, 0x58380016, 0xce8000f9, 0xce4000f9, 0xce000001, 0x5838000a,
|
||||||
0xc94000f8, 0x59100002, 0x580c0000, 0xcd0000f8, 0xc1c00000, 0xc71c0078, 0x415ca000, 0x580c0002,
|
0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x58380010, 0xce8000f9, 0xce4000f9, 0xce000001,
|
||||||
0xcd4000f8, 0x98402008, 0x5834fc10, 0xc8c000f8, 0xc1000000, 0x5dc80000, 0x84000070, 0x6f402000,
|
0x5830001c, 0xca8000f9, 0xca4000f9, 0xc2000000, 0xca000001, 0x5838000a, 0xce8000f9, 0xce4000f9,
|
||||||
0x58005fe0, 0xc3800000, 0x58000000, 0xcb800078, 0xc1c00000, 0x58000002, 0xc9c00078, 0x984022c0,
|
0xce000001, 0xc000facc, 0xc1c20002, 0xcdfc2100, 0xc0c00010, 0x98406308, 0xc7cc0008, 0xc74c0b30,
|
||||||
0x00000000, 0x439dc000, 0x00000000, 0x80000028, 0x98402098, 0xc48c00f8, 0x00000000, 0x00000000,
|
0xc1000004, 0xc000e83c, 0xc1d00002, 0xcdfd0800, 0xc0c00000, 0xc000e82c, 0xc8fc0038, 0x5b740002,
|
||||||
0xc0006916, 0xcbc000f8, 0xc3400000, 0x00000000, 0x5bfc7a00, 0xc7c000f8, 0xcb0000f8, 0x58000002,
|
0x00000000, 0x44f4e000, 0xc1c00000, 0xc5f400fe, 0x58380004, 0xcf4000f8, 0x984065b0, 0x00000000,
|
||||||
0xcac000f8, 0xc7366018, 0xa73e0900, 0x00000000, 0xc777e300, 0xc000694e, 0xc9c000f8, 0x00000000,
|
0x00000000, 0x00000000, 0xc000400c, 0xcbc000f8, 0xc000400e, 0xcb8000f8, 0xc0007d00, 0xcac000f8,
|
||||||
0x00000000, 0x59dc0002, 0xcdc000f8, 0x6f5c6000, 0x58dcb640, 0x580c0000, 0xc90000f8, 0x580c0002,
|
0x73f8e000, 0x8400034a, 0x58000040, 0xca8000f8, 0xc0006960, 0x4b000058, 0xc1e00002, 0x7dc0e000,
|
||||||
0xc94000f8, 0x59100002, 0x580c0000, 0xcd0000f8, 0xc1c00000, 0xc71c0078, 0x415ca000, 0x580c0002,
|
0x76dd6000, 0x769d4000, 0xc2620002, 0x5a640002, 0xc3400000, 0xc2000006, 0x46e4e000, 0xc634000a,
|
||||||
0xcd4000f8, 0x98402008, 0x5834fc10, 0xc8c000f8, 0xc1000000, 0x5dc80000, 0x84000070, 0x6f402000,
|
0x46a4e000, 0xc634020a, 0xc000fb80, 0xcac000f8, 0xc000fba0, 0xca8000f8, 0xc2400000, 0xc2000000,
|
||||||
0x58005fe0, 0xc3800000, 0x58000000, 0xcb800078, 0xc1c00000, 0x58000002, 0xc9c00078, 0x984025d0,
|
0xc6e40000, 0xc6e40100, 0xc6a40200, 0xc6a40300, 0xc6e02000, 0xc6e02100, 0xc6a02200, 0xc6a02300,
|
||||||
0x00000000, 0x439dc000, 0x00000000, 0x800007b8, 0x984021c0, 0xc48c00f8, 0x00000000, 0x00000000,
|
0x7765a000, 0x7761a000, 0xc6740818, 0x7b716000, 0x84000232, 0xc0006960, 0xcf4000f8, 0xc0800000,
|
||||||
0x80000790, 0xc7100078, 0xc0800000, 0x6f402000, 0x58005fe0, 0xc1400000, 0x58000000, 0xc9420038,
|
0xc1c1fffe, 0x45fce000, 0x88000022, 0xa9420018, 0x00000000, 0xc0800008, 0x58fc0008, 0x59380008,
|
||||||
0x4690e000, 0x88000030, 0x454ca000, 0x9c400000, 0x4564e000, 0xc1c00004, 0xc5c800fe, 0x9c400000,
|
0xc1c1fffe, 0x45fce000, 0x88000018, 0x58fc0020, 0x59380020, 0x776d4000, 0x840000ca, 0x6e950010,
|
||||||
0x454ce000, 0xc1c00002, 0xc5c800fe, 0xc0006914, 0xc90000f8, 0xc1400000, 0xc0004022, 0xc9400078,
|
0x5dd40000, 0x84000052, 0xc000f41a, 0xcfc000f8, 0xc1c00000, 0xc7dc4050, 0x581cc000, 0x5dfdfffe,
|
||||||
0x583c0000, 0xc1fc0000, 0xcdc3de00, 0x583c0000, 0xcd400078, 0x583c0000, 0xc1fe0002, 0xcdc3ff00,
|
0xc7c000fe, 0x6948a000, 0xcd4000f8, 0xc1c001fe, 0x769d4000, 0x84000052, 0xc000f41a, 0xccc000f8,
|
||||||
0x59100004, 0xc1c00100, 0x45d0e000, 0xc1c00000, 0xc5d000fe, 0xc0006914, 0xcd0000f8, 0x6f546000,
|
0xc1c00000, 0xc4dc4050, 0x581cc000, 0x5dcdfffe, 0xc4c000fe, 0x6a894000, 0xce8000f8, 0x7f41a000,
|
||||||
0x5954b640, 0x5dcc0002, 0x84000038, 0x5814000c, 0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002,
|
0x776d2000, 0x840000ca, 0x6e550010, 0x5dd40000, 0x84000052, 0xc000f41a, 0xcf8000f8, 0xc1c00000,
|
||||||
0xcdc000f8, 0x5814000e, 0xc9c000f8, 0x00000000, 0x9c400000, 0x59dc0002, 0xcdc000f8, 0x00000000,
|
0xc79c4050, 0x581cc000, 0x5df9fffe, 0xc78000fe, 0x6948a000, 0xcd4000f8, 0xc1c001fe, 0x765d2000,
|
||||||
0xc0006916, 0xc90000f8, 0x583c0000, 0xc1fc0000, 0xcdc3de00, 0x583c0000, 0xc1fe0000, 0xcdc3ff00,
|
0x84000052, 0xc000f41a, 0xcd0000f8, 0xc1c00000, 0xc51c4050, 0x581cc000, 0x5dd1fffe, 0xc50000fe,
|
||||||
0x59100004, 0xc1c00100, 0x45d0e000, 0xc1c00000, 0xc5d000fe, 0xc0006916, 0xcd0000f8, 0x6f546000,
|
0x6a492000, 0xce4000f8, 0xa9440180, 0xc000a340, 0xcbc000f8, 0xa9420168, 0xc000a34a, 0xcb8000f8,
|
||||||
0x5954b640, 0x5dcc0002, 0x84000038, 0x58140008, 0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002,
|
0xc000f414, 0xcb4000f8, 0x5dfc0002, 0x84000048, 0xc000a346, 0x984063f0, 0xc8c000f9, 0xc90000f8,
|
||||||
0xcdc000f8, 0x5814000a, 0xc9c000f8, 0x00000000, 0x9c400000, 0x59dc0002, 0xcdc000f8, 0x00000000,
|
0xc3c00004, 0xc000a340, 0xcfc000f8, 0x80000058, 0x5dfc0004, 0x84000048, 0xc1c40002, 0x75f4e000,
|
||||||
0x58380002, 0xc90000f8, 0x5c000002, 0xc8c000f8, 0xa53e0178, 0xc0006918, 0xca0000f8, 0x00000000,
|
0x84000032, 0xc000f414, 0xcdc000f8, 0xc3c00006, 0xc000a340, 0xcfc000f8, 0x5df80002, 0x84000048,
|
||||||
0x00000000, 0x5a205d00, 0xc60000f8, 0xc94000f8, 0x58000002, 0xc98000f8, 0xa57e006a, 0xc1c00000,
|
0xc000a350, 0x98406308, 0xc8c000f9, 0xc90000f8, 0xc3800004, 0xc000a34a, 0xcf8000f8, 0x80000058,
|
||||||
0xc0c00004, 0xc71c0078, 0xc46000f8, 0x98402098, 0x45e8e000, 0xc1c00002, 0xc5cc00fe, 0x9e000000,
|
0x5df80004, 0x84000048, 0xc1c20002, 0x75f4e000, 0x84000032, 0xc000f414, 0xcdc000f8, 0xc3800006,
|
||||||
0xc1e00002, 0xc000e408, 0xcdc21000, 0xc55c00f8, 0xc4d400f8, 0xc5cc00f8, 0xc59c00f8, 0xc51800f8,
|
0xc000a34a, 0xcf8000f8, 0xa9440ca2, 0xc0008fde, 0xc9c000f8, 0x00000000, 0xc0007e3e, 0xcdc000f8,
|
||||||
0xc5d000f8, 0xc1c00000, 0xc5d41f00, 0xc5d3ff00, 0x58200002, 0xcd8000f8, 0x5c000002, 0xcd4000f8,
|
0xc0006914, 0xcbc000f8, 0xc2800000, 0xc2400000, 0x5bfc4b00, 0xc7c000f8, 0xcb0000f8, 0x58000002,
|
||||||
0x5e205d00, 0x5a200004, 0xc1c00100, 0x45e0e000, 0xc1c00000, 0xc5e000fe, 0xc0006918, 0xce0000f8,
|
0xcac000f8, 0xc0004026, 0xca800078, 0xc0004026, 0xca420078, 0xc3400000, 0xc7366018, 0xa73e01da,
|
||||||
0xc1e00002, 0xc000e408, 0xcdc21000, 0xc6dc00f8, 0xc52c00f8, 0xc5d000f8, 0xc71c00f8, 0xc4f000f8,
|
0x00000000, 0x00000000, 0xc0007e20, 0xc9c000f8, 0x00000000, 0x00000000, 0xa5c20040, 0x00000000,
|
||||||
0xc5cc00f8, 0xc0004022, 0xcb000078, 0xc1c00002, 0xc5cc1f00, 0xc5f01f00, 0xc5f3fe00, 0x58380002,
|
0x00000000, 0x00000000, 0x984027d8, 0x5c3c4b00, 0x6c002010, 0x5800a100, 0xc777e300, 0xc000694c,
|
||||||
0xcd0000f8, 0x5c000002, 0xccc000f8, 0x6f402000, 0x58005fe0, 0xc1c00000, 0xc9c20138, 0xc2000000,
|
0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002, 0xcdc000f8, 0x6f5c6000, 0x58dcb640, 0x580c0000,
|
||||||
0x58000002, 0xca000078, 0x00000000, 0x00000000, 0x5a200004, 0x45e0e000, 0xc1c00000, 0xc5e000fe,
|
0xc90000f8, 0x580c0002, 0xc94000f8, 0x59100002, 0x580c0000, 0xcd0000f8, 0xc1c00000, 0xc71c0078,
|
||||||
0xce000078, 0x5e3c4b00, 0x5a200004, 0xc1c00100, 0x45e0e000, 0xc1c00000, 0xc5e000fe, 0xc0006914,
|
0x415ca000, 0x580c0002, 0xcd4000f8, 0x98402828, 0x5834fc10, 0xc8c000f8, 0xc1000000, 0x5dc80000,
|
||||||
0xce0000f8, 0xc1c00002, 0x69f4e000, 0xc5dc0838, 0xd9f000f8, 0x583c0002, 0xcec000f8, 0x5c000002,
|
0x84000070, 0x6f402000, 0x58005fe0, 0xc3800000, 0x58000000, 0xcb800078, 0xc1c00000, 0x58000002,
|
||||||
0xcf0000f8, 0x9c400000, 0x58380002, 0xc90000f8, 0x5c000002, 0xc8c000f8, 0xc6dc00f8, 0xc52c00f8,
|
0xc9c00078, 0x98402b10, 0x00000000, 0x439dc000, 0x00000000, 0x80000028, 0x984028b8, 0xc48c00f8,
|
||||||
0xc5d000f8, 0xc71c00f8, 0xc4f000f8, 0xc5cc00f8, 0xc1c00002, 0xc5cc1f00, 0xc1c00000, 0xc5f01f00,
|
0x00000000, 0x00000000, 0xc0006916, 0xcbc000f8, 0xc3400000, 0x00000000, 0x5bfc7a00, 0xc7c000f8,
|
||||||
|
0xcb0000f8, 0x58000002, 0xcac000f8, 0xc7366018, 0xa73e0998, 0x00000000, 0xc777e300, 0xc000694e,
|
||||||
|
0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002, 0xcdc000f8, 0x6f5c6000, 0x58dcb640, 0x580c0000,
|
||||||
|
0xc90000f8, 0x580c0002, 0xc94000f8, 0x59100002, 0x580c0000, 0xcd0000f8, 0xc1c00000, 0xc71c0078,
|
||||||
|
0x415ca000, 0x580c0002, 0xcd4000f8, 0x98402828, 0x5834fc10, 0xc8c000f8, 0xc1000000, 0x5dc80000,
|
||||||
|
0x84000070, 0x6f402000, 0x58005fe0, 0xc3800000, 0x58000000, 0xcb800078, 0xc1c00000, 0x58000002,
|
||||||
|
0xc9c00078, 0x98402e38, 0x00000000, 0x439dc000, 0x00000000, 0x80000850, 0x984029f8, 0xc48c00f8,
|
||||||
|
0x00000000, 0x00000000, 0x80000828, 0xc8c000f8, 0x00000000, 0x00000000, 0xa4feffe8, 0xc1c00000,
|
||||||
|
0xcdc000f8, 0x9c400000, 0xc3400000, 0xc1d00002, 0xc4f40018, 0xc7100078, 0xc0800000, 0x6f402000,
|
||||||
|
0x58005fe0, 0xc1400000, 0x58000000, 0xc9420038, 0x4690e000, 0x88000030, 0x454ca000, 0x9c400000,
|
||||||
|
0x4564e000, 0xc1c00004, 0xc5c800fe, 0x9c400000, 0x454ce000, 0xc1c00002, 0xc5c800fe, 0xc0006914,
|
||||||
|
0xc90000f8, 0xc1400000, 0xc0004022, 0xc9400078, 0x583c0000, 0xc1fc0000, 0xcdc3de00, 0x583c0000,
|
||||||
|
0xcd400078, 0x583c0000, 0xc1fe0002, 0xcdc3ff00, 0x59100004, 0xc1c00100, 0x45d0e000, 0xc1c00000,
|
||||||
|
0xc5d000fe, 0xc0006914, 0xcd0000f8, 0x6f546000, 0x5954b640, 0x5dcc0002, 0x84000038, 0x5814000c,
|
||||||
|
0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002, 0xcdc000f8, 0xc1c00002, 0xc000691c, 0xcdc000f8,
|
||||||
|
0x5814000e, 0xc9c000f8, 0x00000000, 0x9c400000, 0x59dc0002, 0xcdc000f8, 0x00000000, 0xc0006916,
|
||||||
|
0xc90000f8, 0x583c0000, 0xc1fc0000, 0xcdc3de00, 0x583c0000, 0xc1fe0000, 0xcdc3ff00, 0x59100004,
|
||||||
|
0xc1c00100, 0x45d0e000, 0xc1c00000, 0xc5d000fe, 0xc0006916, 0xcd0000f8, 0x6f546000, 0x5954b640,
|
||||||
|
0x5dcc0002, 0x84000038, 0x58140008, 0xc9c000f8, 0x00000000, 0x00000000, 0x59dc0002, 0xcdc000f8,
|
||||||
|
0xc1c00002, 0xc000691c, 0xcdc000f8, 0x5814000a, 0xc9c000f8, 0x00000000, 0x9c400000, 0x59dc0002,
|
||||||
|
0xcdc000f8, 0x00000000, 0xc78000f8, 0xc8c000f8, 0x58000002, 0xc90000f8, 0xa4e00178, 0xc0006918,
|
||||||
|
0xca0000f8, 0x00000000, 0x00000000, 0x5a205d00, 0xc60000f8, 0xc94000f8, 0x58000002, 0xc98000f8,
|
||||||
|
0xa57e006a, 0xc1c00000, 0xc0c00004, 0xc71c0078, 0xc46000f8, 0x984028b8, 0x45e8e000, 0xc1c00002,
|
||||||
|
0xc5cc00fe, 0x9e000000, 0xc1e00002, 0xc000e408, 0xcdc21000, 0xc55c00f8, 0xc4d400f8, 0xc5cc00f8,
|
||||||
|
0xc59c00f8, 0xc51800f8, 0xc5d000f8, 0xc1c00000, 0xc5d41f00, 0xc5cff000, 0x58200002, 0xcd8000f8,
|
||||||
|
0x5c000002, 0xcd4000f8, 0x5e205d00, 0x5a200004, 0xc1c00080, 0x45e0e000, 0xc1c00000, 0xc5e000fe,
|
||||||
|
0xc0006918, 0xce0000f8, 0xc1e00002, 0xc000e408, 0xcdc21000, 0xc6dc00f8, 0xc52c00f8, 0xc5d000f8,
|
||||||
|
0xc71c00f8, 0xc4f000f8, 0xc5cc00f8, 0xc0004022, 0xcb000078, 0xc1c00002, 0xc5cc1f00, 0xc5f01f00,
|
||||||
0xc5f3fe00, 0x58380002, 0xcd0000f8, 0x5c000002, 0xccc000f8, 0x6f402000, 0x58005fe0, 0xc1c00000,
|
0xc5f3fe00, 0x58380002, 0xcd0000f8, 0x5c000002, 0xccc000f8, 0x6f402000, 0x58005fe0, 0xc1c00000,
|
||||||
0xc9c20138, 0xc2000000, 0x58000002, 0xca000078, 0x00000000, 0x00000000, 0x5a200004, 0x45e0e000,
|
0xc9c20138, 0xc2000000, 0x58000002, 0xca000078, 0x00000000, 0x00000000, 0x5a200004, 0x45e0e000,
|
||||||
0xc1c00000, 0xc5e000fe, 0xce000078, 0x5e3c7a00, 0x5a200004, 0xc1c00100, 0x45e0e000, 0xc1c00000,
|
0xc1c00000, 0xc5e000fe, 0xce000078, 0x5e3c4b00, 0x5a200004, 0xc1c00100, 0x45e0e000, 0xc1c00000,
|
||||||
0xc5e000fe, 0xc0006916, 0xce0000f8, 0xc1c00002, 0x69f4e000, 0xc5dc0838, 0xd9f000f8, 0x583c0002,
|
0xc5e000fe, 0xc0006914, 0xce0000f8, 0xc1c00002, 0x69f4e000, 0xc5dc0838, 0xd9f000f8, 0x583c0002,
|
||||||
0xcec000f8, 0x5c000002, 0xcf0000f8, 0xc1e20002, 0xc000e408, 0xcdc23100, 0x9c400000, 0x00000000,
|
0xcec000f8, 0x5c000002, 0xcf0000f8, 0x9c400000, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x58380002,
|
||||||
0x00000000, 0x00000000, 0xc3c00000, 0x6ff8a000, 0x5bb87d80, 0x583cfb50, 0xc2800000, 0xca80c030,
|
0xc90000f8, 0x5c000002, 0xc8c000f8, 0xc6dc00f8, 0xc52c00f8, 0xc5d000f8, 0xc71c00f8, 0xc4f000f8,
|
||||||
0xc2400000, 0x58380000, 0xca400078, 0x58380006, 0xca0000f8, 0x583cea28, 0xc9c000f8, 0xc0c00000,
|
0xc5cc00f8, 0xc1c00002, 0xc5cc1f00, 0xc1c00000, 0xc5f01f00, 0xc5f3fe00, 0x58380002, 0xcd0000f8,
|
||||||
0x00000000, 0xc5cc0038, 0x420c8000, 0x4268a000, 0x4514e000, 0x880000aa, 0x58380004, 0xca4000f8,
|
0x5c000002, 0xccc000f8, 0x6f402000, 0x58005fe0, 0xc1c00000, 0xc9c20138, 0xc2000000, 0x58000002,
|
||||||
0xc000ea28, 0x6e1d2000, 0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0xc0006948, 0xc9c000f8,
|
0xca000078, 0x00000000, 0x00000000, 0x5a200004, 0x45e0e000, 0xc1c00000, 0xc5e000fe, 0xce000078,
|
||||||
0x403c0000, 0x00000000, 0x41e0e000, 0xcdc000f8, 0x46612000, 0x58380004, 0xce4000f8, 0x58380006,
|
0x5e3c7a00, 0x5a200004, 0xc1c00100, 0x45e0e000, 0xc1c00000, 0xc5e000fe, 0xc0006916, 0xce0000f8,
|
||||||
0xc1c00000, 0xcdc000f8, 0x58380004, 0xca4000f8, 0x583cea28, 0xc9c000f8, 0xc0c00000, 0x00000000,
|
0xc1c00002, 0x69f4e000, 0xc5dc0838, 0xd9f000f8, 0x583c0002, 0xcec000f8, 0x5c000002, 0xcf0000f8,
|
||||||
0xc5cc0038, 0xc1400000, 0x58380000, 0xc9420078, 0x424d0000, 0x00000000, 0x42948000, 0x4520e000,
|
0xc1e20002, 0xc000e408, 0xcdc23100, 0x9c400000, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0xc0007e3e,
|
||||||
0x8800163a, 0xc000fa40, 0xc9bc00f8, 0x6ff42000, 0xc3000000, 0xc5b4e000, 0xc2c07c00, 0x6f5ca000,
|
0xc9c000f8, 0x00000000, 0x00000000, 0x5ddc0002, 0xcdc000f8, 0x8800f398, 0xc0004010, 0xc9c000f8,
|
||||||
0x42dd6000, 0x582c0022, 0xc98000f8, 0x00000000, 0x00000000, 0x5dd80000, 0x840003c2, 0x582c0026,
|
0xc0007e24, 0xc8c000f8, 0xa5c200e2, 0x00000000, 0xc0007e22, 0xc9c000f8, 0x00000000, 0x00000000,
|
||||||
0xca8000f8, 0x5838000a, 0xc98000f8, 0xc000ea10, 0xc2400000, 0xca7c0070, 0x6d9c8000, 0x41d8e000,
|
0x5ddc0000, 0x840000aa, 0xc000f41a, 0xcdc000f8, 0x580ca100, 0xc90000f8, 0x580cc100, 0x00000000,
|
||||||
0x425d2000, 0x5a644000, 0x582c002e, 0xc98000f8, 0x582c0030, 0xc94000f8, 0x00000000, 0x00000000,
|
0xa53e0070, 0x00000000, 0xcd0000f8, 0xc1c00000, 0x580ca100, 0xcdc000f8, 0x58cc0002, 0xc1c00080,
|
||||||
0x4194e000, 0xd9f800f8, 0x5ddc0080, 0x880000a2, 0x00000000, 0xa7400018, 0xc180001e, 0xc180015e,
|
0x45cce000, 0xc1c00000, 0xc5cc00fe, 0xc0007e24, 0xccc000f8, 0x8000ff78, 0xc3c00000, 0x6ff8a000,
|
||||||
0xc1400000, 0x6d5c4010, 0x425c0000, 0xc1c00006, 0x755c8000, 0x5dd00000, 0xcd80183a, 0x5dd00002,
|
0x5bb87d80, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x583cfb50, 0xc2800000, 0xca80c030, 0xc2400000,
|
||||||
0xcd80103a, 0x5dd00004, 0xcd80083a, 0x5dd00006, 0xcd80003a, 0x5b300008, 0x80000278, 0x58240002,
|
0x58380000, 0xca400078, 0x58380006, 0xca0000f8, 0x583cea28, 0xc9c000f8, 0xc0c00000, 0x00000000,
|
||||||
0xc1800000, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
0xc5cc0038, 0x420c8000, 0x4268a000, 0x4514e000, 0x8800012a, 0x58380004, 0xca4000f8, 0x5de00080,
|
||||||
|
0x8800007a, 0xc000ea28, 0xc1d2007e, 0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x5de0007e,
|
||||||
|
0xc000ea28, 0x6ddd2000, 0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x80000038, 0xc000ea28,
|
||||||
|
0x6e1d2000, 0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x583c6948, 0xc9c000f8, 0x00000000,
|
||||||
|
0x00000000, 0x41e0e000, 0xcdc000f8, 0x46612000, 0x58380004, 0xce4000f8, 0x58380006, 0xc1c00000,
|
||||||
|
0xcdc000f8, 0x58380004, 0xca4000f8, 0x583cea28, 0xc9c000f8, 0xc0c00000, 0x00000000, 0xc5cc0038,
|
||||||
|
0xc1400000, 0x58380000, 0xc9420078, 0x424d0000, 0x00000000, 0x42948000, 0x4520e000, 0x880020ba,
|
||||||
|
0xc000fa40, 0xc9bc00f8, 0x6ff42000, 0xc3000000, 0xc5b4e000, 0xc2c07c00, 0x6f5ca000, 0x42dd6000,
|
||||||
|
0x582c0022, 0xc98000f8, 0x00000000, 0x00000000, 0x5dd80000, 0x840003d2, 0x582c0026, 0xca8000f8,
|
||||||
|
0x5838000a, 0xc98000f8, 0xc000ea10, 0xc2400000, 0xca7c0070, 0x6d9c8000, 0x41d8e000, 0x425d2000,
|
||||||
|
0x5a644000, 0x582c0032, 0xc9c000f8, 0x582c002e, 0xc98000f8, 0x582c0030, 0xc94000f8, 0x00000000,
|
||||||
|
0x41d8e000, 0x41d4e000, 0xd9f800f8, 0x5ddc0080, 0x880000a2, 0x00000000, 0xa7400018, 0xc180001e,
|
||||||
|
0xc180015e, 0xc1400000, 0x6d5c4010, 0x425c0000, 0xc1c00006, 0x755c8000, 0x5dd00000, 0xcd80183a,
|
||||||
|
0x5dd00002, 0xcd80103a, 0x5dd00004, 0xcd80083a, 0x5dd00006, 0xcd80003a, 0x5b300008, 0x80000278,
|
||||||
|
0x58240002, 0xc1800000, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
||||||
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
||||||
0xcd8000f9, 0xa7400018, 0xc18001e0, 0xc18001ea, 0xc1400000, 0x6d5c4010, 0x425c0000, 0xc90000f8,
|
0xcd8000f9, 0xcd8000f9, 0xa7400018, 0xc18001e0, 0xc18001ea, 0xc1400000, 0x6d5c4010, 0x425c0000,
|
||||||
0xc1c00000, 0xc55c0308, 0x691c8008, 0xc5901838, 0x691c8018, 0xcd0000f8, 0x6d5c4010, 0x425c0000,
|
0xc90000f8, 0xc1c00000, 0xc55c0308, 0x691c8008, 0xc5901838, 0x691c8018, 0xcd0000f8, 0x6d5c4010,
|
||||||
0xc1c00006, 0x755c8000, 0x5dd00000, 0xcd80183a, 0x5dd00002, 0xcd80103a, 0x5dd00004, 0xcd80083a,
|
0x425c0000, 0xc1c00006, 0x755c8000, 0x5dd00000, 0xcd80183a, 0x5dd00002, 0xcd80103a, 0x5dd00004,
|
||||||
0x5dd00006, 0xcd80003a, 0x5b300008, 0xdf9400f8, 0xc1008fe0, 0x6d5c4010, 0x411c0000, 0xc98000f8,
|
0xcd80083a, 0x5dd00006, 0xcd80003a, 0x5b300008, 0xdf9400f8, 0xc1008fe0, 0x6d5c4010, 0x411c0000,
|
||||||
0xc1c00000, 0xc55c0308, 0x699cc000, 0x6d9b0010, 0x6f1c4010, 0x425c0000, 0xc94000f8, 0xc1c00000,
|
0xc98000f8, 0xc1c00000, 0xc55c0308, 0x699cc000, 0x6d9b0010, 0x6f1c4010, 0x425c0000, 0xc94000f8,
|
||||||
0xc71c0308, 0x695ca008, 0xc5941838, 0x695ca018, 0xcd4000f8, 0x6f1c4010, 0x425c0000, 0xc1c00006,
|
0xc1c00000, 0xc71c0308, 0x695ca008, 0xc5941838, 0x695ca018, 0xcd4000f8, 0x6f1c4010, 0x425c0000,
|
||||||
0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004, 0xcd80083a, 0x5dd40006,
|
0xc1c00006, 0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004, 0xcd80083a,
|
||||||
0xcd80003a, 0x5b300002, 0x582c0022, 0xc1c00000, 0xcdc000f8, 0x80000e18, 0xdb8800f9, 0xdb4800f8,
|
0x5dd40006, 0xcd80003a, 0x5b300002, 0x582c0022, 0xc1c00000, 0xcdc000f8, 0x80001610, 0x00000000,
|
||||||
0xc2400000, 0xdf240038, 0xc0004024, 0xcb8000f8, 0x00000000, 0xc3400000, 0xc7b50038, 0xc2800000,
|
0xa9440328, 0xc000e444, 0xc90000f8, 0xc0006956, 0xc8c000f8, 0xc000e442, 0xcd0000f8, 0x70d06000,
|
||||||
0xc7a88018, 0xc000fa40, 0xc8fc00f8, 0xc2800000, 0x582c0004, 0xca800038, 0xa4ce0042, 0x58ec0040,
|
0xc0006956, 0xccc000f8, 0xc1c00002, 0x69f4e000, 0xc0006960, 0xc88000f8, 0x74dc6000, 0x84001b0a,
|
||||||
0xc1c00000, 0x580c0004, 0xc9c00038, 0x00000000, 0x00000000, 0x729d4000, 0x7e412000, 0x76692000,
|
0x749c4000, 0x80000008, 0xc000401a, 0xc9c000f8, 0x00000000, 0xc000f41a, 0xcdc000f8, 0xc0c00000,
|
||||||
0xc0400000, 0xc7840008, 0xc000a0ae, 0x5de40000, 0x84000070, 0xc0c00000, 0xc8c000f8, 0x5dc40000,
|
0xc0004054, 0xc8c00078, 0xc0006958, 0xc93400f8, 0x6f5ca000, 0x40dc6000, 0x40d06000, 0xc4c000f8,
|
||||||
0xdcb800fb, 0xdcb400fa, 0x84000ffa, 0x5dcc0000, 0xdcb800fb, 0xdcb400fa, 0x84000fda, 0xc0c00000,
|
0xc94000f8, 0x00000000, 0x00000000, 0xa57e01a0, 0xc0004054, 0xc9820078, 0x6d1c2010, 0x59100004,
|
||||||
0xccc000f8, 0x800001b8, 0xc0c00002, 0xccc000f8, 0xc65000f8, 0x61010028, 0x5dc40000, 0x84000018,
|
0x419cc000, 0x6f5c8000, 0x419cc000, 0xc1c00040, 0x45d0e000, 0xc1c00000, 0xc5d000fe, 0xc0006958,
|
||||||
0x62410008, 0x800002e8, 0x6e144000, 0x59544d08, 0xc0400000, 0x58140004, 0xc84000b8, 0xa78200d0,
|
0xcd3400f8, 0x5dc80000, 0x8400016a, 0x580c0002, 0xc90000f8, 0x582c0032, 0xc1c00000, 0xcdc000f8,
|
||||||
0xc0800000, 0xc1c00000, 0x6e1c2000, 0x59dc5fe0, 0x581c0002, 0xc8820078, 0x581c0000, 0xc9c00078,
|
0x582c002a, 0xccc000f8, 0x582c0034, 0xcd4000f8, 0x582c0036, 0xcd0000f8, 0xa9460042, 0xc58000f8,
|
||||||
0xc1800000, 0x58140006, 0xc9800078, 0x409ce000, 0xc0800000, 0x581c0000, 0xc8800078, 0x00000000,
|
0xc90000f8, 0x582c0032, 0xc1c00004, 0xcdc000f8, 0x582c0038, 0xcd0000f8, 0xc1c00000, 0xc55e6018,
|
||||||
0x00000000, 0x40b44000, 0x4588e000, 0x88000030, 0xc1c00002, 0x69e0e000, 0x7dc0e000, 0x765d2000,
|
0x582c002c, 0xcdc000f8, 0x582c003a, 0xc8c000f8, 0x582c003c, 0xc9c000f8, 0xc1800000, 0xc5580078,
|
||||||
0x80000038, 0xa7800030, 0x5dc40000, 0x84000022, 0xc1ee0002, 0x75c4e000, 0xc4cc2002, 0x61010028,
|
0x58cc0002, 0x41d8e000, 0x582c003a, 0xccc000f8, 0x582c003c, 0xcdc000f8, 0x80000070, 0xc0006956,
|
||||||
0xa60afed0, 0x00000000, 0x5de40000, 0xdcb800fb, 0xdcb400fa, 0x84000e22, 0x5dcc0000, 0x840000ba,
|
0xc8c000f8, 0xc1c00002, 0x69f4e000, 0x7dc0e000, 0x74dc6000, 0xccc000f8, 0x80001890, 0xc4c000f8,
|
||||||
0xa78000b0, 0x62810028, 0x840000a2, 0x6e0c4000, 0x58cc4d08, 0xc1000000, 0x580c0004, 0xc90000b8,
|
0xc1c00000, 0xc5d41f00, 0xcd4000f8, 0x80001868, 0x80000b48, 0xdb8800f9, 0xdb4800f8, 0xdb1000f9,
|
||||||
0x580c0000, 0xc98000b8, 0x7d00a000, 0xc1f00002, 0x5ddc0002, 0x755ca000, 0x59540002, 0xc1ee0002,
|
0xc2400000, 0xdf240038, 0xc0004024, 0xcb8000f8, 0xdcb400f8, 0x6f404000, 0x58004d48, 0x58000006,
|
||||||
0x75d0e000, 0xc5d400fa, 0x45948000, 0x580c0004, 0xcd0000b8, 0x8000ff60, 0x5de40000, 0xdcb800fb,
|
0xcb000078, 0xc3400000, 0xc7b50038, 0xc2800000, 0xc7a88018, 0xc000fa40, 0xc8fc00f8, 0xc2800000,
|
||||||
0xdcb400fa, 0x84000d42, 0x62410008, 0xa7800098, 0x00000000, 0xc0c00000, 0xc65000f8, 0x6100a028,
|
0x582c0004, 0xca800038, 0xa4ce0042, 0x58ec0040, 0xc1c00000, 0x580c0004, 0xc9c00038, 0x00000000,
|
||||||
0x6d584000, 0x59984d08, 0xc0400000, 0x58180004, 0xc84000b8, 0x00000000, 0x00000000, 0xa46e002a,
|
0x00000000, 0x729d4000, 0x7e412000, 0x76692000, 0xc0400000, 0xc7840008, 0xc000a0ae, 0x5de40000,
|
||||||
0x44c4e000, 0x88000018, 0xc56000f8, 0xc44c00f8, 0x6100a028, 0xa54aff98, 0x6e184000, 0x59984d08,
|
0x84000060, 0xc0c00000, 0xc8c000f8, 0x5dc40000, 0xdcb800fb, 0xdcb400fa, 0xdd3000fb, 0x8400170a,
|
||||||
0xc0400000, 0xc0800000, 0x6e1c2000, 0x59dc5fe0, 0x581c0002, 0xc8420078, 0x581c0000, 0xc8800078,
|
0x80000360, 0xc0c00000, 0xccc000f8, 0x80000348, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0xc0c00002,
|
||||||
0xc1400000, 0x58180006, 0xc9400078, 0x40484000, 0xc0c00000, 0x58080000, 0xc8c00078, 0x00000000,
|
0xccc000f8, 0xc65000f8, 0x61010028, 0x5dc40000, 0x84000018, 0x62410008, 0x800005a0, 0xc0007e26,
|
||||||
0xa7820038, 0x40f42000, 0x5dd5fffe, 0x84000022, 0x4544a000, 0x58180006, 0xcd400078, 0xa7800088,
|
0xc94000f8, 0xc0400000, 0x00000000, 0x6140c028, 0x00000000, 0x00000000, 0x8400009a, 0xcd4000f8,
|
||||||
0xc0400000, 0x58180000, 0xc84000b8, 0xc1000000, 0x58180004, 0xc90000b8, 0x5dc40000, 0x8400004a,
|
0x6d804000, 0x5800b7c0, 0x58000000, 0x484000b8, 0x00000000, 0x00000000, 0x58000004, 0xcc4000b8,
|
||||||
0xc1ee0002, 0x5ddc0002, 0x445ce000, 0x8400002a, 0x450c8000, 0x45348000, 0x58180004, 0xcd0000b8,
|
0x5dc40000, 0x8400ff70, 0xc0007e28, 0xc84000f8, 0xc1c00002, 0x69d8e000, 0x705c2000, 0xcc4000f8,
|
||||||
0x6e106000, 0x5910b640, 0x58100006, 0xc98000f8, 0x58100004, 0xc94000f8, 0x418cc000, 0x58100006,
|
0x8000ff38, 0xc2000000, 0xc0c00000, 0x580c7e2a, 0xc90000f8, 0x00000000, 0x00000000, 0xc50400f8,
|
||||||
0xcd8000f8, 0x59540002, 0x58100004, 0xcd4000f8, 0x6e242000, 0x5a645fe0, 0xc0c00000, 0x58240002,
|
0x75248000, 0x61010028, 0x58205fb0, 0xc9c000f8, 0x00000000, 0xc1800000, 0x581c0006, 0xc9800078,
|
||||||
0xc8c20078, 0xc1000000, 0x58240000, 0xc9020038, 0x582c002a, 0xcc8000f8, 0x582c002c, 0xce0000f8,
|
0xa7820108, 0xc0800000, 0xc1c00000, 0x6e1c2000, 0x59dc5fe0, 0x581c0002, 0xc8820078, 0x581c0000,
|
||||||
0x6d102000, 0x58cc0004, 0x450ce000, 0xc1c00000, 0xc5cc00fe, 0x58240002, 0x6cde0000, 0xcdc21078,
|
0xc9c00078, 0x00000000, 0x00000000, 0x409ce000, 0xc0800000, 0x581c0000, 0xc8800078, 0x00000000,
|
||||||
0xc0e00002, 0x68e06000, 0xd8f000f8, 0xdcb800f9, 0xdcb400f8, 0xc0006910, 0xc8c000f9, 0xc90000f8,
|
0x00000000, 0x40b44000, 0x4588e000, 0x88000070, 0xc0007e3c, 0xc9c000f8, 0x00000000, 0x00000000,
|
||||||
|
0xa5c00028, 0x00000000, 0x7c40e000, 0x765d2000, 0x80000068, 0xc1c00002, 0x69e0e000, 0x7dc0e000,
|
||||||
|
0x765d2000, 0xc0007e3c, 0xc9c000f8, 0x61010028, 0x8400002a, 0x00000000, 0xa5c0fed2, 0x00000000,
|
||||||
|
0x8000fe90, 0x58cc0002, 0x5dcc0012, 0x8800fe42, 0x5de40000, 0xdcb800fb, 0xdcb400fa, 0xdd3000fb,
|
||||||
|
0x840013c2, 0x80000018, 0x5dcc0000, 0x8400018a, 0xa7800180, 0xc2000000, 0xc0400000, 0x58047e2a,
|
||||||
|
0xc88000f8, 0xc0007e28, 0xc9c000f8, 0x00000000, 0x00000000, 0x74a44000, 0x75c8e000, 0x45c8e000,
|
||||||
|
0x84000108, 0x74a84000, 0x60810028, 0x840000f2, 0x6e0c4000, 0x58ccb7c0, 0xc1000000, 0x580c0004,
|
||||||
|
0xc90000b8, 0xc1800000, 0x580c0000, 0xc98000b8, 0x7d00a000, 0xc1f00002, 0x5ddc0002, 0x755ca000,
|
||||||
|
0x59540002, 0xc1ee0002, 0x75d0e000, 0xc5d400fa, 0x45948000, 0x580c0004, 0xcd0000b8, 0x5dd00000,
|
||||||
|
0x8400ff52, 0xc0007e28, 0xc90000f8, 0xc1c00002, 0x69e0e000, 0x7dc0e000, 0x751c8000, 0xcd0000f8,
|
||||||
|
0x8000ff10, 0x58440002, 0x5dc40012, 0x8800fea2, 0x5de40000, 0xdcb800fb, 0xdcb400fa, 0xdd3000fb,
|
||||||
|
0x84001202, 0x62410008, 0xa7800100, 0x00000000, 0xa7820068, 0x00000000, 0xa7860058, 0xc0004022,
|
||||||
|
0xc0c00000, 0xc8c00078, 0x00000000, 0x00000000, 0x470ce000, 0xdcb800fd, 0xdcb400fc, 0xdd3000fd,
|
||||||
|
0x88001182, 0xc0c00000, 0xc65000f8, 0x6100a028, 0x6d584000, 0x5998b7c0, 0xc0400000, 0x58180004,
|
||||||
|
0xc84000b8, 0x00000000, 0x00000000, 0xa46e002a, 0x44c4e000, 0x88000018, 0xc56000f8, 0xc44c00f8,
|
||||||
|
0x6100a028, 0xa54aff98, 0x6e184000, 0x5998b7c0, 0xc0400000, 0xc0800000, 0x6e1c2000, 0x59dc5fe0,
|
||||||
|
0x581c0002, 0xc8420078, 0x581c0000, 0xc8800078, 0x58205fb0, 0xc9c000f8, 0x00000000, 0xc1400000,
|
||||||
|
0x581c0006, 0xc9400078, 0x40484000, 0xc0c00000, 0x58080000, 0xc8c00078, 0x00000000, 0xa78200c0,
|
||||||
|
0x40f42000, 0x4704e000, 0xdcb800fd, 0xdcb400fc, 0xdd3000fd, 0x8800101a, 0x5dd5fffe, 0x84000042,
|
||||||
|
0x4544a000, 0x58205fb0, 0xc9c000f8, 0x00000000, 0x00000000, 0x581c0006, 0xcd400078, 0x5df1fffe,
|
||||||
|
0x8400003a, 0x47058000, 0xdcb400f8, 0x6f404000, 0x58004d48, 0x58000006, 0xcf000078, 0xa78000d0,
|
||||||
|
0xc0400000, 0x58180000, 0xc84000b8, 0xc1000000, 0x58180004, 0xc90000b8, 0x5dc40000, 0x84000092,
|
||||||
|
0xc1ee0002, 0x5ddc0002, 0x445ce000, 0x84000072, 0x450c8000, 0x45348000, 0x58180004, 0xcd0000b8,
|
||||||
|
0x5dd00000, 0x84000012, 0xa52e0038, 0xc0007e28, 0xc84000f8, 0xc1c00002, 0x69e0e000, 0x705c2000,
|
||||||
|
0xcc4000f8, 0x6e106000, 0x5910b640, 0x58100006, 0xc98000f8, 0x58100004, 0xc94000f8, 0x418cc000,
|
||||||
|
0x58100006, 0xcd8000f8, 0x59540002, 0x58100004, 0xcd4000f8, 0x6e242000, 0x5a645fe0, 0xc0c00000,
|
||||||
|
0x58240002, 0xc8c20078, 0xc1000000, 0x58240000, 0xc9020038, 0x582c002a, 0xcc8000f8, 0x582c002c,
|
||||||
|
0xce0000f8, 0xc48000f8, 0xc94000f8, 0x58080002, 0xc98000f8, 0x582c0034, 0xcd4000f8, 0x582c0036,
|
||||||
|
0xcd8000f8, 0x582c0038, 0xc1c00000, 0xcdc000f8, 0x582c0032, 0xc1c00000, 0xcdc000f8, 0x6d102000,
|
||||||
|
0x58cc0004, 0x450ce000, 0xc1c00000, 0xc5cc00fe, 0x58240002, 0x6cde0000, 0xcdc21078, 0xc0e00002,
|
||||||
|
0x68e06000, 0xd8f000f8, 0xdcb800f9, 0xdcb400f8, 0xdd3000f9, 0xc0006910, 0xc8c000f9, 0xc90000f8,
|
||||||
0xc1c00000, 0xc1400040, 0x60c04000, 0x7494e000, 0x8400007a, 0xc1400080, 0x61004000, 0x58880040,
|
0xc1c00000, 0xc1400040, 0x60c04000, 0x7494e000, 0x8400007a, 0xc1400080, 0x61004000, 0x58880040,
|
||||||
0x7494e000, 0x84000052, 0x00000000, 0xab6c0002, 0x00000000, 0x00000000, 0x984047e8, 0xc0006902,
|
0x7494e000, 0x84000052, 0x00000000, 0xab6c0002, 0x00000000, 0x00000000, 0x98405d98, 0xc0006902,
|
||||||
0xc8c000f8, 0xc3c00000, 0x8000ff58, 0xc0006910, 0xc1c00000, 0xc49ca000, 0x401c0000, 0xc8c000f8,
|
0xc8c000f8, 0xc3c00000, 0x8000ff58, 0xc0006910, 0xc1c00000, 0xc49ca000, 0x401c0000, 0xc8c000f8,
|
||||||
0xc1000002, 0xc1400000, 0xc4940020, 0x6914e000, 0x70dc6000, 0xccc000f8, 0x582c0020, 0xcc8000f8,
|
0xc1000002, 0xc1400000, 0xc4940020, 0x6914e000, 0x70dc6000, 0xccc000f8, 0x582c0020, 0xcc8000f8,
|
||||||
0xc1c00002, 0x582c0022, 0xcdc000f8, 0xc2409c00, 0x6c9c6000, 0x425d2000, 0xc2807600, 0x6c9c6000,
|
0xc1c00002, 0x582c0022, 0xcdc000f8, 0xc2409c00, 0x6c9c6000, 0x425d2000, 0xc2807600, 0x6c9c6000,
|
||||||
0x429d4000, 0x582c002c, 0xc98000f8, 0x582c0026, 0xce8000f8, 0x582c0028, 0xce4000f8, 0x58240008,
|
0x429d4000, 0x582c002c, 0xc98000f8, 0x582c0026, 0xce8000f8, 0x582c0028, 0xce4000f8, 0x58240008,
|
||||||
0xcd8000f8, 0x5838000a, 0xc98000f8, 0xc000ea10, 0xc2000000, 0xca3c0070, 0x6d9c8000, 0x41d8e000,
|
0xcd8000f8, 0x5838000a, 0xc98000f8, 0xc000ea10, 0xc2000000, 0xca3c0070, 0x6d9c8000, 0x41d8e000,
|
||||||
0x421d0000, 0x5a204000, 0x582c002a, 0xc98000f8, 0xc1400000, 0xc1000000, 0x58180000, 0xc942e020,
|
0x421d0000, 0x5a204000, 0x582c002a, 0xc98000f8, 0xc1400000, 0xc1000000, 0xc58000f8, 0xc9c000f8,
|
||||||
0x58180002, 0xc90000e0, 0x5828000e, 0xcd8000f8, 0x58280002, 0xc1c00000, 0xcdc00078, 0x41148000,
|
0x5824000a, 0xcd8000f8, 0x5824000c, 0xcdc000f8, 0x59ac0034, 0x58180000, 0xc942e020, 0x58180002,
|
||||||
0x58280004, 0xcd0000e0, 0x58a40000, 0x586c0008, 0xc44000f8, 0xc8c000f9, 0xc90000f9, 0xc94000f8,
|
0xc90000e0, 0xc000401e, 0xc98000f8, 0x58280002, 0xc1c00000, 0xcdc00078, 0x41148000, 0xc1400000,
|
||||||
0xc48000f8, 0xccc000f9, 0xcd0000f9, 0xcd4000f9, 0x5df00000, 0x84000138, 0x58200000, 0xc1800000,
|
0xc5941078, 0x7d40a000, 0x75148000, 0xc1400000, 0xc5961078, 0x71148000, 0x58280004, 0xcd0000e0,
|
||||||
|
0x58a40000, 0x586c0008, 0xc44000f8, 0xc8c000f9, 0xc90000f9, 0xc94000f8, 0xc48000f8, 0xccc000f9,
|
||||||
|
0xcd0000f9, 0xcd4000f9, 0x5df00000, 0x84000138, 0x58200000, 0xc1800000, 0xcd8000f9, 0xcd8000f9,
|
||||||
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
||||||
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9,
|
0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xcd8000f9, 0xc18001ea,
|
||||||
0xcd8000f9, 0xc18001ea, 0xc1c00002, 0x75f4e000, 0xc1c001e0, 0xc5d800fa, 0xc1400000, 0x6d5c4010,
|
0xc1c00002, 0x75f4e000, 0xc1c001e0, 0xc5d800fa, 0xc1400000, 0x6d5c4010, 0x421c0000, 0xc1c00006,
|
||||||
0x421c0000, 0xc1c00006, 0x755c8000, 0x5dd00000, 0xcd80183a, 0x5dd00002, 0xcd80103a, 0x5dd00004,
|
0x755c8000, 0x5dd00000, 0xcd80183a, 0x5dd00002, 0xcd80103a, 0x5dd00004, 0xcd80083a, 0x5dd00006,
|
||||||
0xcd80083a, 0x5dd00006, 0xcd80003a, 0x5b300008, 0xc000fa40, 0xc93c00f8, 0xc1400000, 0x582c0002,
|
0xcd80003a, 0x5b300008, 0xc000fa40, 0xc93c00f8, 0xc1400000, 0x582c0002, 0xc9428018, 0xc0400000,
|
||||||
0xc9428018, 0xc0400000, 0xc0800080, 0x44944000, 0xc45800f8, 0xc1c00200, 0x75d0e000, 0xc49c00f8,
|
0xc0800080, 0x44944000, 0xc45800f8, 0xc1c00200, 0x75d0e000, 0xc49c00f8, 0xc5d800fa, 0x582c0030,
|
||||||
0xc5d800fa, 0x582c0030, 0xcd4000f8, 0xd97800f8, 0x5828000e, 0xc9c000f8, 0xc0c00000, 0x582c0002,
|
0xcd4000f8, 0xd97800f8, 0x59ec0034, 0xc0c00000, 0x582c0002, 0xc8c10038, 0xc1000000, 0x581c0000,
|
||||||
0xc8c10038, 0xc1000000, 0x581c0000, 0xc9000078, 0x00000000, 0x00000000, 0xc50800f8, 0x4518e000,
|
0xc9000078, 0x00000000, 0x00000000, 0xc50800f8, 0x4518e000, 0xc59c00f8, 0xc5c800fc, 0xc4d400f8,
|
||||||
0xc59c00f8, 0xc5c800fc, 0xc4d400f8, 0x44c8e000, 0xc49c00f8, 0xc5d400fc, 0x582c002e, 0xcd4000f8,
|
0x44c8e000, 0xc49c00f8, 0xc5d400fc, 0x582c002e, 0xcd4000f8, 0x582c0032, 0xc88000f8, 0xdf9000f8,
|
||||||
0xdf9000f8, 0x4150e000, 0xd9f800f8, 0x41f0e000, 0x5ddc0086, 0x88000082, 0xc18000a0, 0x6f1c4010,
|
0x4150e000, 0x41c8e000, 0xd9f800f8, 0x41f0e000, 0x5ddc0086, 0x88000082, 0xc18000a0, 0x6f1c4010,
|
||||||
0x421c0000, 0xc1c00006, 0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004,
|
0x421c0000, 0xc1c00006, 0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004,
|
||||||
0xcd80083a, 0x5dd40006, 0xcd80003a, 0x5b300002, 0x80000158, 0x00000000, 0x00000000, 0x00000000,
|
0xcd80083a, 0x5dd40006, 0xcd80003a, 0x5b300002, 0x80000158, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0xdf9400f8, 0xc1008fe0, 0x6d5c4010, 0x411c0000, 0xc98000f8, 0xc1c00000, 0xc55c0308, 0x699cc000,
|
0xdf9400f8, 0xc1008fe0, 0x6d5c4010, 0x411c0000, 0xc98000f8, 0xc1c00000, 0xc55c0308, 0x699cc000,
|
||||||
@ -269,109 +340,136 @@ static unsigned int firmware_binary_code[] = {
|
|||||||
0xcd80103a, 0x5dcc0004, 0xcd80083a, 0x5dcc0006, 0xcd80003a, 0x5b300002, 0xc18000a0, 0x6f1c4010,
|
0xcd80103a, 0x5dcc0004, 0xcd80083a, 0x5dcc0006, 0xcd80003a, 0x5b300002, 0xc18000a0, 0x6f1c4010,
|
||||||
0x421c0000, 0xc1c00006, 0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004,
|
0x421c0000, 0xc1c00006, 0x771ca000, 0x5dd40000, 0xcd80183a, 0x5dd40002, 0xcd80103a, 0x5dd40004,
|
||||||
0xcd80083a, 0x5dd40006, 0xcd80003a, 0x5b300002, 0x582c0022, 0xc1c00000, 0xcdc000f8, 0x00000000,
|
0xcd80083a, 0x5dd40006, 0xcd80003a, 0x5b300002, 0x582c0022, 0xc1c00000, 0xcdc000f8, 0x00000000,
|
||||||
0x00000000, 0x5df00088, 0x880002f8, 0x582c0020, 0xc98000f8, 0xc2800000, 0xc2400000, 0xc5a80528,
|
0x5df00088, 0x88000578, 0x582c0032, 0xca0000f8, 0x582c0038, 0xc8c000f8, 0x5de00000, 0x8400004a,
|
||||||
0x582c002e, 0xc98000f8, 0xc1000088, 0x45308000, 0xc51400f8, 0x4590e000, 0xc59c00f8, 0xc5d400fc,
|
0x582c0020, 0xc98000f8, 0x98405130, 0xc2840002, 0xc5a80528, 0xc2400000, 0x5df00088, 0x88000508,
|
||||||
0xc5681930, 0x5838000a, 0xc90000f8, 0xc7281230, 0xc7e80008, 0xc5280b30, 0xd93800f8, 0xc1c00002,
|
0x582c0020, 0xc98000f8, 0xc2800000, 0xc2400000, 0xc5a80528, 0x582c002e, 0xc98000f8, 0xc1000088,
|
||||||
0xc5e80400, 0x4594e000, 0x8400001a, 0xc1c00000, 0xc5e80400, 0x5dd80000, 0x8400002a, 0xc1c00002,
|
0x45308000, 0xc51400f8, 0x4590e000, 0xc59c00f8, 0xc5d400fc, 0xc5681930, 0x5838000a, 0xc90000f8,
|
||||||
0xc5e80300, 0xc1c00002, 0xc5e80200, 0x582c0022, 0xc94000f8, 0xc7640e08, 0x00000000, 0x5d540002,
|
0xc7281230, 0xc7e80008, 0xc5280b30, 0xd93800f8, 0xc1c00002, 0xc5e80400, 0x4594e000, 0x8400001a,
|
||||||
0x8400001a, 0xc1c00002, 0xc5e40d00, 0xc0c00000, 0xc68f2030, 0x430c8000, 0xc5241838, 0xc0800088,
|
0xc1c00000, 0xc5e80400, 0x5dd80000, 0x8400002a, 0xc1c00002, 0xc5e80300, 0xc1c00002, 0xc5e80200,
|
||||||
0x44904000, 0xc1c00000, 0xc5c800fc, 0x582c0030, 0xc94000f8, 0xc0400000, 0x582c0002, 0xc8420018,
|
0x582c0022, 0xc94000f8, 0xc7640e08, 0x00000000, 0x5d540002, 0x8400001a, 0xc1c00002, 0xc5e40d00,
|
||||||
0xc49000f8, 0x4548e000, 0xc55c00f8, 0xc5d000fc, 0xc5241418, 0x44546000, 0xc4e41018, 0x4550a000,
|
0xc0c00000, 0xc68f2030, 0x430c8000, 0xc5241838, 0xc0800088, 0x44904000, 0xc1c00000, 0xc5c800fc,
|
||||||
0x582c0030, 0xcd4000f8, 0xc0c00000, 0xc68f2030, 0x458cc000, 0x582c002e, 0xcd8000f8, 0x43118000,
|
0x582c0030, 0xc94000f8, 0xc0400000, 0x582c0002, 0xc8420018, 0xc49000f8, 0x4548e000, 0xc55c00f8,
|
||||||
0x430d8000, 0xdf9800f8, 0xc000ea10, 0xc1400000, 0xc97c0070, 0x6d9c8000, 0x41d8e000, 0x415ca000,
|
0xc5d000fc, 0xc5241418, 0x44546000, 0xc4e41018, 0x4550a000, 0x582c0030, 0xcd4000f8, 0xc0c00000,
|
||||||
0x59544000, 0x00000000, 0xc1000000, 0xc0000000, 0xc9140038, 0x00000000, 0x00000000, 0x59100002,
|
0xc68f2030, 0x458cc000, 0x582c002e, 0xcd8000f8, 0x43118000, 0x430d8000, 0xdf9800f8, 0xc000ea10,
|
||||||
0xcd140038, 0x98404d30, 0xc68c00f8, 0xc65000f8, 0x00000000, 0x5df00088, 0x8800ef02, 0x00000000,
|
0xc1400000, 0xc97c0070, 0x6d9c8000, 0x41d8e000, 0x415ca000, 0x59544000, 0x00000000, 0xc1000000,
|
||||||
0x80000008, 0x5df00000, 0x840000ba, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x5838000a, 0xc94000f8,
|
0xc0000000, 0xc9140038, 0x00000000, 0x00000000, 0x59100002, 0xcd140038, 0x984063f0, 0xc68c00f8,
|
||||||
0xc1000000, 0xc000ea14, 0xc93c0038, 0x59540002, 0x00000000, 0x4514e000, 0xc1c00000, 0xc5d400fe,
|
0xc65000f8, 0x00000000, 0x5df00088, 0x8800e6a2, 0x00000000, 0x80000218, 0xd87800f8, 0xc1000088,
|
||||||
0x5838000a, 0xcd4000f8, 0x58380004, 0xc94000f8, 0x00000000, 0x00000000, 0x59540002, 0x58380004,
|
0x45308000, 0xc51400f8, 0x4610e000, 0xc61c00f8, 0xc5d400fc, 0xc5681930, 0x46150000, 0x582c0032,
|
||||||
0xcd4000f8, 0x5df00000, 0x84000058, 0xa7400020, 0x00000000, 0x6ff42000, 0x8000ea00, 0x5bfc0002,
|
0xce0000f8, 0xc56000f8, 0x5838000a, 0xc94000f8, 0xc7281230, 0xc7e80008, 0xc5680b30, 0xc000ea10,
|
||||||
0x5dfc0002, 0x8400e812, 0x00000000, 0x00000000, 0x00000000, 0xab6c0052, 0x984047e8, 0xc0006902,
|
0xc1000000, 0xc93c0070, 0x6d5c8000, 0x41d4e000, 0x411c8000, 0x59104000, 0x6f1c4010, 0x411c0000,
|
||||||
0xc8c000f8, 0xc3c00000, 0xab6c002a, 0x984047e8, 0xc0006902, 0xc8c000f8, 0xc3c00000, 0xc0004032,
|
0xc94000f8, 0xc1c00000, 0xc71c0308, 0x695ca008, 0xc4d71838, 0x695ca018, 0xcd4000f8, 0x5b300002,
|
||||||
0xcbc000f8, 0xc0004038, 0xcb8000f8, 0xc000691a, 0xcb0000f8, 0xc000403a, 0xcb4000f8, 0xc72c00f8,
|
0x5e200002, 0x84000062, 0x6ccd0000, 0x6f1c4010, 0x411c0000, 0xc94000f8, 0xc1c00000, 0xc71c0308,
|
||||||
0xa7800058, 0xc2800000, 0x00000000, 0x984041b8, 0xc0c07c80, 0xc0007c00, 0x00000000, 0x98404220,
|
0x695ca008, 0xc4d71838, 0x695ca018, 0xcd4000f8, 0x5b300002, 0x6ccd0000, 0x582c0038, 0xccc000f8,
|
||||||
0xc0006952, 0xc80000f8, 0xc1000000, 0xa7900058, 0xc2800002, 0x00000000, 0x984041b8, 0xc0c07c80,
|
0xc1400000, 0xc0000000, 0xc9500038, 0x00000000, 0x00000000, 0x59540002, 0xcd500038, 0xdfa000f8,
|
||||||
0xc0007c00, 0x00000000, 0x98404220, 0xc0006952, 0xc80000f8, 0xc1000000, 0x472ce000, 0x8400023a,
|
0x984063f0, 0xc68c00f8, 0xc65000f8, 0x00000000, 0x9e000000, 0x00000000, 0x00000000, 0x00000000,
|
||||||
0xc0c00000, 0xc78e0020, 0xc1c00002, 0x69cc8000, 0xc78f0020, 0x69cce000, 0x711c8000, 0xc000f41a,
|
0x5df00000, 0x840000ba, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x5838000a, 0xc94000f8, 0xc1000000,
|
||||||
0xcfc000f8, 0xc1c00000, 0xc7dc4050, 0x581cc000, 0xcb0000f8, 0x00000000, 0x00000000, 0x76d16000,
|
0xc000ea14, 0xc93c0038, 0x59540002, 0x00000000, 0x4514e000, 0xc1c00000, 0xc5d400fe, 0x5838000a,
|
||||||
0x7d008000, 0x77118000, 0x732d8000, 0xcf0000f8, 0xc000691a, 0xcec000f8, 0x80000180, 0x5ea80000,
|
0xcd4000f8, 0x58380004, 0xc94000f8, 0x00000000, 0x00000000, 0x59540002, 0x58380004, 0xcd4000f8,
|
||||||
0xc40c00fa, 0xc2400000, 0x580c0004, 0xca400038, 0x58cc0040, 0xc1c00000, 0x580c0004, 0xc9c00038,
|
0x5df00000, 0x84000058, 0xa7400020, 0x00000000, 0x6ff42000, 0x8000df80, 0x5bfc0002, 0x5dfc0002,
|
||||||
0x9c400000, 0x00000000, 0x00000000, 0x725d2000, 0x62406028, 0x84000032, 0xc9cc00f8, 0x00000000,
|
0x8400dcfa, 0x00000000, 0x00000000, 0x00000000, 0xab6c0052, 0x98405d98, 0xc0006902, 0xc8c000f8,
|
||||||
0x00000000, 0x411c8000, 0x8000ffd0, 0xc1400000, 0xc7970020, 0x6f4e0010, 0x5de80000, 0xc74c00fa,
|
0xc3c00000, 0xab6c002a, 0x98405d98, 0xc0006902, 0xc8c000f8, 0xc3c00000, 0xc0004032, 0xcbc000f8,
|
||||||
0xc7960022, 0xc1c00000, 0xc4dd0038, 0x45d0e000, 0x88000048, 0xc1c00000, 0xc4dc0038, 0x451ce000,
|
0xc0004038, 0xcb8000f8, 0xc000691a, 0xcb0000f8, 0xc000403a, 0xcb4000f8, 0xc72c00f8, 0xa7800058,
|
||||||
0x88000050, 0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0xc1c00002, 0x9c400000, 0x69d4e000,
|
0xc2800000, 0x00000000, 0x98405670, 0xc0c07c80, 0xc0007c00, 0x00000000, 0x984056d8, 0xc0006952,
|
||||||
0x7dc0e000, 0x76dd6000, 0x9c400000, 0xc1c00002, 0x69d4e000, 0x72dd6000, 0xc0004028, 0xcbc000f8,
|
0xc80000f8, 0xc1000000, 0xa7900058, 0xc2800002, 0x00000000, 0x98405670, 0xc0c07c80, 0xc0007c00,
|
||||||
0xc000691c, 0xcb8000f8, 0xa7c0c780, 0x00000000, 0x5df80000, 0x8400c768, 0xc1c00002, 0xc000e070,
|
0x00000000, 0x984056d8, 0xc0006952, 0xc80000f8, 0xc1000000, 0x472ce000, 0x8400023a, 0xc0c00000,
|
||||||
0xcdc00000, 0x8000c748, 0xdcbc00f9, 0xdcb800f8, 0xdd3400f9, 0xc2400040, 0xc000690c, 0xc8c000f9,
|
0xc78e0020, 0xc1c00002, 0x69cc8000, 0xc78f0020, 0x69cce000, 0x711c8000, 0xc000f41a, 0xcfc000f8,
|
||||||
0xc90000f8, 0xc1c00000, 0x60c18000, 0x7724e000, 0x84000052, 0x61018000, 0x7724e000, 0x84000032,
|
0xc1c00000, 0xc7dc4050, 0x581cc000, 0xcb0000f8, 0x00000000, 0x00000000, 0x76d16000, 0x7d008000,
|
||||||
0x98404ec0, 0x00000000, 0x00000000, 0x00000000, 0x8000ff90, 0x5b300040, 0xc2c09400, 0x6f1c6000,
|
0x77118000, 0x732d8000, 0xcf0000f8, 0xc000691a, 0xcec000f8, 0x80000180, 0x5ea80000, 0xc40c00fa,
|
||||||
0x42dd6000, 0xc2809800, 0x429d4000, 0x58340022, 0xcf0000f8, 0x582c0008, 0xcf8000f8, 0xc000690c,
|
0xc2400000, 0x580c0004, 0xca400038, 0x58cc0040, 0xc1c00000, 0x580c0004, 0xc9c00038, 0x9c400000,
|
||||||
0xc1c00000, 0xc71ca000, 0x401c0000, 0xc8c000f8, 0xc2000002, 0x6a30e000, 0x70dc6000, 0xccc000f8,
|
0x00000000, 0x00000000, 0x725d2000, 0x62406028, 0x84000032, 0xc9cc00f8, 0x00000000, 0x00000000,
|
||||||
0x58340008, 0xc8c000f9, 0xc90000f9, 0xc94000f9, 0x582c0000, 0xccc000f9, 0xcd0000f9, 0xcd4000f9,
|
0x411c8000, 0x8000ffd0, 0xc1400000, 0xc7970020, 0x6f4e0010, 0x5de80000, 0xc74c00fa, 0xc7960022,
|
||||||
0x58340010, 0xc9c000f9, 0xc8c000f9, 0xc90000f9, 0xc94000f9, 0xc98000f9, 0xc84000f9, 0xc88000f9,
|
0xc1c00000, 0xc4dd0038, 0x45d0e000, 0x88000048, 0xc1c00000, 0xc4dc0038, 0x451ce000, 0x88000050,
|
||||||
0x58280000, 0xcdc000f9, 0xccc000f9, 0xcd0000f9, 0xcd4000f9, 0xcd8000f9, 0xcc4000f9, 0xcc8000f9,
|
0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0xc1c00002, 0x9c400000, 0x69d4e000, 0x7dc0e000,
|
||||||
0xc1c00000, 0x5828000e, 0xc9c3e000, 0x00000000, 0x00000000, 0x5ddc0002, 0x840001ba, 0xc0006908,
|
0x76dd6000, 0x9c400000, 0xc1c00002, 0x69d4e000, 0x72dd6000, 0xc0004028, 0xcbc000f8, 0xc000691c,
|
||||||
0xc8c000f8, 0xc0004c00, 0xc1000000, 0x400c0000, 0x58000000, 0xc903e000, 0x00000000, 0x00000000,
|
0xcb8000f8, 0xa7c0b3a0, 0x00000000, 0x5df80000, 0x8400b388, 0xc1c00002, 0xc000e070, 0xcdc00000,
|
||||||
0x5dd00002, 0x840000e8, 0xc1000000, 0x58000002, 0xc90000e0, 0xc1c00000, 0xc0004022, 0xc9c20008,
|
0x8000b368, 0xdcbc00f9, 0xdcb800f8, 0xdd3400f9, 0xc2400040, 0xc000401e, 0xd08000f8, 0xc000690c,
|
||||||
0x5828000e, 0xcd0000e0, 0x411ce000, 0x58280004, 0xcdc000e0, 0x5828000e, 0xc1fe0002, 0xcdc3ff00,
|
0xc8c000f9, 0xc90000f8, 0xc1c00000, 0x60c18000, 0x7724e000, 0x84000052, 0x61018000, 0x7724e000,
|
||||||
0x5828000e, 0xc1fc0000, 0xcdc3de00, 0x58340020, 0xc1c00000, 0xcdc000f8, 0x58cc0004, 0xc1c00100,
|
0x84000032, 0x984065b0, 0x00000000, 0x00000000, 0x00000000, 0x8000ff90, 0x5b300040, 0xc2c09400,
|
||||||
0x45cce000, 0xc1c00000, 0xc5cc00fe, 0xc0006908, 0xccc000f8, 0x800000f8, 0xc0c0b600, 0x6f9c6000,
|
0x6f1c6000, 0x42dd6000, 0xc2809800, 0x429d4000, 0x58340022, 0xcf0000f8, 0x582c0008, 0xcf8000f8,
|
||||||
0x40dc6000, 0x580c0004, 0xc90000f8, 0x5828000e, 0xc1fc0002, 0xcdc3de00, 0x58340020, 0xc1c00002,
|
0xc000690c, 0xc1c00000, 0xc71ca000, 0x401c0000, 0xc8c000f8, 0xc2000002, 0x6a30e000, 0x70dc6000,
|
||||||
0xcdc000f8, 0x59100002, 0x580c0004, 0xcd0000f8, 0x80000080, 0xc0c00000, 0xc0004022, 0xc8c20008,
|
0xccc000f8, 0x58340008, 0xc8c000f9, 0xc90000f9, 0xc94000f9, 0x582c0000, 0xccc000f9, 0xcd0000f9,
|
||||||
0xc1000000, 0x5828000e, 0xc90000e0, 0x5828000e, 0xc1fc0000, 0xcdc3de00, 0x58340020, 0xc1c00000,
|
0xcd4000f9, 0x58340010, 0xc9c000f9, 0xc8c000f9, 0xc90000f9, 0xc94000f9, 0xc98000f9, 0xc84000f9,
|
||||||
0xcdc000f8, 0x410ce000, 0x58280004, 0xcdc000e0, 0x94000000, 0xc1c00002, 0xc000691c, 0xcdc000f8,
|
0xc88000f9, 0x58280000, 0xcdc000f9, 0xccc000f9, 0xcd0000f9, 0xcd4000f9, 0xcd8000f9, 0xcc4000f9,
|
||||||
0xd87800f8, 0xc3800000, 0x580c7400, 0xca4000f9, 0xca0000f8, 0xc3400000, 0xc67c0008, 0xc639c008,
|
0xcc8000f9, 0xc1c00000, 0x5828000e, 0xc9c3e000, 0x00000000, 0x00000000, 0x5ddc0002, 0x8400026a,
|
||||||
0xc674a028, 0xc0c00000, 0xc64d6030, 0xc000ea10, 0xc3000000, 0xcb3c0070, 0x6cdc8000, 0x41cce000,
|
0xc000401a, 0xc9c000f8, 0x00000000, 0xc000f41a, 0xcdc000f8, 0xc000691e, 0xc88000f8, 0xc0006908,
|
||||||
0x431d8000, 0x5b304000, 0x6faca000, 0x5aec7c00, 0xc0c00000, 0xc0000000, 0xc8f00038, 0x6f686000,
|
0xc8c000f8, 0xc1804c00, 0xc1000100, 0xa9440028, 0xc0004056, 0xc9800078, 0x6d102010, 0x00000000,
|
||||||
0x5aa89c00, 0x5ccc0002, 0xccf00038, 0xc1000000, 0xc6128018, 0x5dd00000, 0x840000f2, 0xc1800000,
|
0x6d1c2010, 0x5ddc0004, 0x449ce000, 0x88000150, 0x418c0000, 0x58000000, 0xc943e000, 0x58cc0004,
|
||||||
0xc0800000, 0xc61a0018, 0xc60b0038, 0xc1c40002, 0x419cc000, 0x6d9c4010, 0x429c0000, 0xc94000f8,
|
0x450ce000, 0xc1c00000, 0xc5cc00fe, 0xa5400110, 0xc1000000, 0x58000002, 0xc90000e0, 0xc1c00000,
|
||||||
0xc1c00000, 0xc59c0308, 0x695ca000, 0x6d570010, 0x59980002, 0x6c9c4010, 0x431c0000, 0xc1c00006,
|
0xc0004022, 0xc9c20008, 0x5828000e, 0xcd0000e0, 0x411ce000, 0xc1400000, 0xdc941078, 0x7d40a000,
|
||||||
0x749c2000, 0x5dc40000, 0xcd40183a, 0x5dc40002, 0xcd40103a, 0x5dc40004, 0xcd40083a, 0x5dc40006,
|
0x75d4e000, 0xc1400000, 0xdc961078, 0x71d4e000, 0x58280004, 0xcdc000e0, 0x5828000e, 0xc1fe0002,
|
||||||
0xcd40003a, 0x58880002, 0x5d100002, 0x8400ff50, 0xa61a00a0, 0x582c002a, 0xc90000f8, 0xc0000000,
|
0xcdc3ff00, 0x5828000e, 0xc1fc0000, 0xcdc3de00, 0x58340020, 0xc1c00000, 0xcdc000f8, 0xc0006908,
|
||||||
0xc1c00000, 0xcdd3ff00, 0xc1000002, 0x58280008, 0xc94000f8, 0x5df40040, 0xc0006912, 0x44100004,
|
0xccc000f8, 0x58880002, 0xc000691e, 0xcc8000f8, 0x80000130, 0xc0c0b600, 0x6f9c6000, 0x40dc6000,
|
||||||
0xc98000f8, 0x6934e000, 0x7dc0e000, 0x759cc000, 0xcd8000f8, 0xc1b00002, 0x6994c000, 0xd9b000f8,
|
0x580c0004, 0xc90000f8, 0x5828000e, 0xc1fc0002, 0xcdc3de00, 0x58340020, 0xc1c00002, 0xcdc000f8,
|
||||||
0x5ccc0000, 0x84000160, 0x6fcca000, 0x58cc7d80, 0x580c0006, 0xc90000f8, 0xc1400000, 0xc615a000,
|
0x59100002, 0x580c0004, 0xcd0000f8, 0x800000b8, 0xc0c00000, 0xc0004022, 0xc8c20008, 0xc1000000,
|
||||||
0x59100002, 0x580c0006, 0xcd0000f8, 0xc1c00000, 0x7d40a000, 0xc55c0000, 0x582c0024, 0xcdc000f8,
|
0x5828000e, 0xc90000e0, 0x5828000e, 0xc1fc0000, 0xcdc3de00, 0x58340020, 0xc1c00000, 0xcdc000f8,
|
||||||
0xa61a00e8, 0x7f80e000, 0xc5f80000, 0x6faca000, 0x5aec7c00, 0x582c0024, 0xc94000f8, 0x580c0004,
|
0x410ce000, 0xc1400000, 0xdc941078, 0x7d40a000, 0x75d4e000, 0xc1400000, 0xdc961078, 0x71d4e000,
|
||||||
0xc98000f8, 0x5dd40002, 0x8400009a, 0xc000ea28, 0x6d1d2000, 0xcdfd2928, 0xc000ea28, 0xc1d00002,
|
0x58280004, 0xcdc000e0, 0x94000000, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0xd87800f8, 0xc3800000,
|
||||||
0xcdfd0800, 0xc0006948, 0xc9c000f8, 0x403c0000, 0x00000000, 0x41d0e000, 0xcdc000f8, 0x4590c000,
|
0x580c7400, 0xca4000f9, 0xca0000f8, 0xc3400000, 0xc3c00000, 0xc67c0008, 0x5dfc0004, 0x88000480,
|
||||||
0x580c0004, 0xcd8000f8, 0x580c0006, 0xc1c00000, 0xcdc000f8, 0xc0006902, 0xc8c000f8, 0x00000000,
|
0xc639c008, 0xc674a028, 0xc0c00000, 0xc64d6030, 0xc000ea10, 0xc3000000, 0xcb3c0070, 0x6cdc8000,
|
||||||
0x00000000, 0x58cc0004, 0xc1c00200, 0x45cce000, 0xc1c00000, 0xc5cc00fe, 0xccc000f8, 0xc000f01e,
|
0x41cce000, 0x431d8000, 0x5b304000, 0x6faca000, 0x5aec7c00, 0xc0c00000, 0xc0000000, 0xc8f00038,
|
||||||
0xc1d00002, 0xcdc10800, 0xdf8400f8, 0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0xc0006904,
|
0x6f686000, 0x5aa89c00, 0x5ccc0002, 0xccf00038, 0xc1000000, 0xc6128018, 0x5dd00000, 0x840000f2,
|
||||||
0xc94000f8, 0xab68008a, 0x00000000, 0x58147200, 0xccc000f9, 0xcd0000f9, 0xc000f016, 0xc1d00002,
|
0xc1800000, 0xc0800000, 0xc61a0018, 0xc60b0038, 0xc1c40002, 0x419cc000, 0x6d9c4010, 0x429c0000,
|
||||||
|
0xc94000f8, 0xc1c00000, 0xc59c0308, 0x695ca000, 0x6d570010, 0x59980002, 0x6c9c4010, 0x431c0000,
|
||||||
|
0xc1c00006, 0x749c2000, 0x5dc40000, 0xcd40183a, 0x5dc40002, 0xcd40103a, 0x5dc40004, 0xcd40083a,
|
||||||
|
0x5dc40006, 0xcd40003a, 0x58880002, 0x5d100002, 0x8400ff50, 0xa61a00e8, 0xc000401a, 0xc9c000f8,
|
||||||
|
0x00000000, 0xc000f41a, 0xcdc000f8, 0x5828000a, 0xc90000f8, 0x5828000c, 0xc94000f8, 0xc0000000,
|
||||||
|
0xc1c00000, 0xc5d41f00, 0xcd5000f8, 0xc1000002, 0x58280008, 0xc94000f8, 0x5df40040, 0xc0006912,
|
||||||
|
0x44100004, 0xc98000f8, 0x6934e000, 0x7dc0e000, 0x759cc000, 0xcd8000f8, 0xa9440022, 0xc1b00002,
|
||||||
|
0x6994c000, 0xd9b000f8, 0x5ccc0000, 0x840001e0, 0x6fcca000, 0x58cc7d80, 0x580c0006, 0xc90000f8,
|
||||||
|
0xc1400000, 0xc615a000, 0x59100002, 0x580c0006, 0xcd0000f8, 0xc1c00000, 0x7d40a000, 0xc55c0000,
|
||||||
|
0x582c0024, 0xcdc000f8, 0xa61a0168, 0x7f80e000, 0xc5f80000, 0x6faca000, 0x5aec7c00, 0x582c0024,
|
||||||
|
0xc94000f8, 0x580c0004, 0xc98000f8, 0x5dd40002, 0x8400011a, 0x5dd00080, 0x8800007a, 0xc000ea28,
|
||||||
|
0xc1d2007e, 0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x5dd0007e, 0xc000ea28, 0x6ddd2000,
|
||||||
|
0xcdfd2928, 0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x80000038, 0xc000ea28, 0x6d1d2000, 0xcdfd2928,
|
||||||
|
0xc000ea28, 0xc1d00002, 0xcdfd0800, 0x583c6948, 0xc9c000f8, 0x00000000, 0x00000000, 0x41d0e000,
|
||||||
|
0xcdc000f8, 0x4590c000, 0x580c0004, 0xcd8000f8, 0x580c0006, 0xc1c00000, 0xcdc000f8, 0xc0006902,
|
||||||
|
0xc8c000f8, 0x00000000, 0x00000000, 0x58cc0004, 0xc1c00200, 0x45cce000, 0xc1c00000, 0xc5cc00fe,
|
||||||
|
0xccc000f8, 0xc000f01e, 0xc1d00002, 0xcdc10800, 0xdf8400f8, 0x9c400000, 0x00000000, 0x00000000,
|
||||||
|
0x00000000, 0xc0006904, 0xc94000f8, 0xc000fe08, 0x49c00040, 0x00000000, 0x00000000, 0x5ddc0100,
|
||||||
|
0x8800ffd8, 0xab68008a, 0x00000000, 0x58147200, 0xccc000f9, 0xcd0000f9, 0xc000f016, 0xc1d00002,
|
||||||
0xcdc10800, 0x59540004, 0xc1c00200, 0x45d4e000, 0xc1c00000, 0xc5d400fe, 0x9c400000, 0xc0006904,
|
0xcdc10800, 0x59540004, 0xc1c00200, 0x45d4e000, 0xc1c00000, 0xc5d400fe, 0x9c400000, 0xc0006904,
|
||||||
0xcd4000f8, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x8000ff60, 0xc0006906, 0xc94000f8,
|
0xcd4000f8, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x8000ff30, 0xc0006906, 0xc94000f8,
|
||||||
0xab6a008a, 0x00000000, 0x58147400, 0xccc000f9, 0xcd0000f9, 0xc000f404, 0xc1d00002, 0xcdc10800,
|
0xc000fe0a, 0x49c00040, 0x00000000, 0x00000000, 0x5ddc0100, 0x8800ffd8, 0xab6a008a, 0x00000000,
|
||||||
0x59540004, 0xc1c00200, 0x45d4e000, 0xc1c00000, 0xc5d400fe, 0x9c400000, 0xc0006906, 0xcd4000f8,
|
0x58147400, 0xccc000f9, 0xcd0000f9, 0xc000f404, 0xc1d00002, 0xcdc10800, 0x59540004, 0xc1c00200,
|
||||||
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x8000ff60, 0xc08000a0, 0x74d0c000, 0x84000090,
|
0x45d4e000, 0xc1c00000, 0xc5d400fe, 0x9c400000, 0xc0006906, 0xcd4000f8, 0x00000000, 0x00000000,
|
||||||
0x78d0c000, 0x8400006a, 0x61800018, 0x6180e008, 0x441cc000, 0x84000060, 0x5d940000, 0x84000050,
|
0x00000000, 0x00000000, 0x8000ff30, 0xc08000a0, 0x74d0c000, 0x84000090, 0x78d0c000, 0x8400006a,
|
||||||
0x60c04008, 0xa48a0040, 0x9c400000, 0x61004008, 0x58880040, 0x00000000, 0xa5400018, 0x00000000,
|
0x61800018, 0x6180e008, 0x441cc000, 0x84000060, 0x5d940000, 0x84000050, 0x60c04008, 0xa48a0040,
|
||||||
0xc0800080, 0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000,
|
0x9c400000, 0x61004008, 0x58880040, 0x00000000, 0xa5400018, 0x00000000, 0xc0800080, 0x9c400000,
|
||||||
0xc000f412, 0xc9c000f8, 0xc1800000, 0xc0800000, 0xa5c004e8, 0xc5d82028, 0x6d886000, 0x59089800,
|
0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0x00000000, 0xc000f412, 0xc9c000f8,
|
||||||
0x5810000e, 0xc9c3c000, 0x59489400, 0xd9b800f8, 0xa5c0044a, 0x58140008, 0xc98000f8, 0xc0c07b00,
|
0xc1800000, 0xc0800000, 0xa5c00580, 0xc5d82028, 0xc1c00002, 0xc000691c, 0xcdc000f8, 0x6d886000,
|
||||||
0xc0800000, 0x6d9ca000, 0x40dc6000, 0xd9b800f8, 0x580c0002, 0xc8808000, 0x00000000, 0x00000000,
|
0x59089800, 0x5810000e, 0xc9c3c000, 0x59489400, 0xd9b800f8, 0xa5c004ca, 0x58140008, 0xc98000f8,
|
||||||
0xa480004a, 0x580c0004, 0xc98000f8, 0x58140002, 0xc88000f8, 0x00000000, 0x00000000, 0x4498e000,
|
0xc0c07b00, 0xc0800000, 0x6d9ca000, 0x40dc6000, 0xd9b800f8, 0x580c0002, 0xc8808000, 0x00000000,
|
||||||
0x84000110, 0xc1c00000, 0x580c0002, 0xc9c04000, 0x00000000, 0x00000000, 0xa5c0004a, 0x580c0006,
|
0x00000000, 0xa480004a, 0x580c0004, 0xc98000f8, 0x58140002, 0xc88000f8, 0x00000000, 0x00000000,
|
||||||
0xc98000f8, 0x58140004, 0xc88000f8, 0x00000000, 0x00000000, 0x4498e000, 0x840000a0, 0xc0800000,
|
0x4498e000, 0x84000110, 0xc1c00000, 0x580c0002, 0xc9c04000, 0x00000000, 0x00000000, 0xa5c0004a,
|
||||||
0x58100002, 0xc8800078, 0x580c001e, 0xc94000f8, 0xc1800000, 0x580c0002, 0xc9810038, 0x40944000,
|
0x580c0006, 0xc98000f8, 0x58140004, 0xc88000f8, 0x00000000, 0x00000000, 0x4498e000, 0x840000a0,
|
||||||
0xa4be0052, 0xc1400000, 0x4498e000, 0x88000118, 0x580c0002, 0xc940e000, 0x00000000, 0x00000000,
|
0xc0800000, 0x58100002, 0xc8800078, 0x580c001e, 0xc94000f8, 0xc1800000, 0x580c0002, 0xc9810038,
|
||||||
0xa54000ca, 0xc1c00000, 0x00000000, 0x00000000, 0x00000000, 0xdf9400f8, 0x00000000, 0x00000000,
|
0x40944000, 0xa4be0052, 0xc1400000, 0x4498e000, 0x88000118, 0x580c0002, 0xc940e000, 0x00000000,
|
||||||
0xc1800000, 0xc5582000, 0xa5400042, 0xc000fb64, 0xc1c00002, 0xcdd80000, 0xc000facc, 0xc1c40002,
|
0x00000000, 0xa54000ca, 0xc1c00000, 0x00000000, 0x00000000, 0x00000000, 0xdf9400f8, 0x00000000,
|
||||||
0xcdd84200, 0x80000220, 0xc000fb64, 0xc1c20002, 0xcdd82100, 0xc000facc, 0xc1c60002, 0xcdd86300,
|
0x00000000, 0xc1800000, 0xc5582000, 0xa5400042, 0xc000fb64, 0xc1c00002, 0xcdd80000, 0xc000facc,
|
||||||
0x800001e8, 0x580c0002, 0xc9c10038, 0x00000000, 0x00000000, 0x589c0000, 0xc000690a, 0xc94000f8,
|
0xc1c40002, 0xcdd84200, 0x800002a0, 0xc000fb64, 0xc1c20002, 0xcdd82100, 0xc000facc, 0xc1c60002,
|
||||||
0xc1c00000, 0x5810000e, 0xc9c000e0, 0x59944c00, 0x58180000, 0xcc800078, 0x58180002, 0xcdc000e0,
|
0xcdd86300, 0x80000268, 0x580c0002, 0xc9c10038, 0x00000000, 0x00000000, 0x589c0000, 0xc000401a,
|
||||||
0x58180000, 0xc1fa0002, 0xcdc3bd00, 0x58180000, 0xc1f80002, 0xcdc39c00, 0x58180000, 0xc1fe0000,
|
0xc9c000f8, 0x00000000, 0xc000f41a, 0xcdc000f8, 0xc000690a, 0xc94000f8, 0xc0c04c00, 0xc1800100,
|
||||||
0xcdc3ff00, 0x59540004, 0xc1c00100, 0x45d4e000, 0xc1c00000, 0xc5d400fe, 0xc000690a, 0xcd4000f8,
|
0xa9440028, 0xc0004056, 0xc8c00078, 0x6d982010, 0x00000000, 0x40d46000, 0x59540004, 0x4594e000,
|
||||||
0xc000e408, 0xc1c00002, 0xcdc000f8, 0x5810000e, 0xc1fe0000, 0xcdc3ff00, 0xdf9400f8, 0xc1800000,
|
0xc1c00000, 0xc5d400fe, 0xc000690a, 0xcd4000f8, 0xc1400000, 0x5810000e, 0xc94000e0, 0xa9440022,
|
||||||
0x58100002, 0xc9800078, 0x6d486000, 0x5888b600, 0x58080006, 0xc9c000f8, 0x00000000, 0x00000000,
|
0xc1800000, 0xc4c000f8, 0xc98000f8, 0x580c0002, 0xcd4000e0, 0xc4980078, 0xdf9400f8, 0xc1f80006,
|
||||||
0x419cc000, 0x58080006, 0xcd8000f8, 0xc1800000, 0xc5582000, 0xa540002a, 0xc000fb60, 0xc1c40002,
|
0xc5db9c18, 0x00000000, 0xc5581508, 0xc4c000f8, 0xcd8000f8, 0xc000e408, 0xc1c00002, 0xcdc000f8,
|
||||||
0xcdd84200, 0x80000020, 0xc000fb60, 0xc1c60002, 0xcdd86300, 0xdf9400f8, 0xc1800002, 0x00000000,
|
0xc000691e, 0xc98000f8, 0x5810000e, 0xc1fe0000, 0xcdc3ff00, 0x5d980002, 0xc000691e, 0xcd8000f8,
|
||||||
0x00000000, 0x5dd40040, 0xc000690e, 0x44180004, 0xc88000f8, 0x6994e000, 0x7dc0e000, 0x749c4000,
|
0xc1800000, 0x58100002, 0xc9800078, 0x6d486000, 0x5888b600, 0x58080006, 0xc9c000f8, 0x00000000,
|
||||||
0xcc8000f8, 0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0xc3c00000, 0xc4fc8018, 0xc3800000,
|
0x00000000, 0x419cc000, 0x58080006, 0xcd8000f8, 0xc1800000, 0xc5582000, 0xa540002a, 0xc000fb60,
|
||||||
0x6fb44000, 0x5b744d08, 0xc3000000, 0x58340006, 0xcb020038, 0xc2c00000, 0xc2800000, 0x5f300002,
|
0xc1c40002, 0xcdd84200, 0x80000020, 0xc000fb60, 0xc1c60002, 0xcdd86300, 0xdf9400f8, 0xc1800002,
|
||||||
|
0x00000000, 0x00000000, 0x5dd40040, 0xc000690e, 0x44180004, 0xc88000f8, 0x6994e000, 0x7dc0e000,
|
||||||
|
0x749c4000, 0xcc8000f8, 0x9c400000, 0x00000000, 0x00000000, 0x00000000, 0xc000403c, 0xc90000f8,
|
||||||
|
0xc1400000, 0xc4d60078, 0x4550e000, 0x8400003a, 0xcd4000f8, 0xc1c00000, 0xd9c400f9, 0xd9440078,
|
||||||
|
0xc1c00006, 0xd9c400f9, 0xc3c00000, 0xc4fc8018, 0x5bfc0002, 0xc1000000, 0xc140b7b8, 0xc3800000,
|
||||||
|
0x6fb44000, 0x4355a000, 0xc3000000, 0x58340006, 0xcb020038, 0xc2c00000, 0xc2800000, 0x5f300002,
|
||||||
0x84000080, 0x58340006, 0xcac00078, 0x58340002, 0xca800078, 0xc2000000, 0x58340002, 0xca020078,
|
0x84000080, 0x58340006, 0xcac00078, 0x58340002, 0xca800078, 0xc2000000, 0x58340002, 0xca020078,
|
||||||
0x42e92000, 0x00000000, 0x4624e000, 0xc62400fc, 0x58340000, 0xcb030038, 0x58340006, 0xce400078,
|
0x42e92000, 0x00000000, 0x4624e000, 0xc62400fc, 0x58340000, 0xcb030038, 0x58340006, 0xce400078,
|
||||||
0x58340006, 0x6f1e0000, 0xcdc21038, 0x5bb80002, 0x47bce000, 0x8800ff1a, 0x8000b410, 0x00000000,
|
0x58340006, 0x6f1e0000, 0xcdc21038, 0x5bb80002, 0x47bce000, 0x8800ff1a, 0xa500003a, 0x00000000,
|
||||||
0x00000000, 0x00000000,};
|
0xc1000002, 0xc3800000, 0xc3c00008, 0xc1404d48, 0x8000fee0, 0x80009bd8, 0x00000000, 0x00000000,
|
||||||
|
0x00000000, 0xa94e9bb8, 0xc0006954, 0xcbc000f8, 0xc3800000, 0xdd790038, 0x5ffc0002, 0xc7bc00fc,
|
||||||
|
0xc0006954, 0xcfc000f8, 0x88009b70, 0xc0004044, 0xcbc000f8, 0xc0004014, 0xcb8000f8, 0x5dfc0000,
|
||||||
|
0x84009b42, 0x6f9d0010, 0x739da000, 0x6f9e0010, 0x735da000, 0x6f9f0010, 0x735da000, 0xc1c0001e,
|
||||||
|
0x775da000, 0xc000e440, 0xcf4000f8, 0x80009ae8, 0x00000000, 0x00000000, 0x00000000,};
|
||||||
|
|
||||||
static unsigned int firmware_binary_data[] = {
|
static unsigned int firmware_binary_data[] = {
|
||||||
};
|
};
|
||||||
|
@ -306,6 +306,12 @@
|
|||||||
#define DREG_B0_LADR PPE_REG_ADDR(0x0DA8)
|
#define DREG_B0_LADR PPE_REG_ADDR(0x0DA8)
|
||||||
#define DREG_B1_LADR PPE_REG_ADDR(0x0DA9)
|
#define DREG_B1_LADR PPE_REG_ADDR(0x0DA9)
|
||||||
|
|
||||||
|
static inline int
|
||||||
|
ifx_drv_ver(char *buf, char *module, int major, int mid, int minor)
|
||||||
|
{
|
||||||
|
return sprintf(buf, "Lantiq %s driver, version %d.%d.%d, (c) 2001-2013 Lantiq Deutschland GmbH\n",
|
||||||
|
module, major, mid, minor);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#endif // IFXMIPS_PTM_PPE_COMMON_H
|
#endif // IFXMIPS_PTM_PPE_COMMON_H
|
||||||
|
@ -621,12 +621,15 @@ static void do_swap_desc_tasklet(unsigned long arg)
|
|||||||
static inline int ifx_ptm_version(char *buf)
|
static inline int ifx_ptm_version(char *buf)
|
||||||
{
|
{
|
||||||
int len = 0;
|
int len = 0;
|
||||||
unsigned int major, minor;
|
unsigned int major, mid, minor;
|
||||||
|
|
||||||
ifx_ptm_get_fw_ver(&major, &minor);
|
ifx_ptm_get_fw_ver(&major, &mid, &minor);
|
||||||
|
|
||||||
len += sprintf(buf + len, "PTM %d.%d.%d", IFX_PTM_VER_MAJOR, IFX_PTM_VER_MID, IFX_PTM_VER_MINOR);
|
len += ifx_drv_ver(buf + len, "PTM", IFX_PTM_VER_MAJOR, IFX_PTM_VER_MID, IFX_PTM_VER_MINOR);
|
||||||
len += sprintf(buf + len, " PTM (E1) firmware version %d.%d\n", major, minor);
|
if ( mid == ~0 )
|
||||||
|
len += sprintf(buf + len, " PTM (E1) firmware version %u.%u\n", major, minor);
|
||||||
|
else
|
||||||
|
len += sprintf(buf + len, " PTM (E1) firmware version %u.%u.%u\n", major, mid, minor);
|
||||||
|
|
||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
@ -963,7 +966,7 @@ static int ltq_ptm_probe(struct platform_device *pdev)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
int i;
|
int i;
|
||||||
char ver_str[128];
|
char ver_str[256];
|
||||||
struct port_cell_info port_cell = {0};
|
struct port_cell_info port_cell = {0};
|
||||||
|
|
||||||
ret = init_priv_data();
|
ret = init_priv_data();
|
||||||
|
@ -111,7 +111,7 @@ struct ptm_priv_data {
|
|||||||
|
|
||||||
extern unsigned int ifx_ptm_dbg_enable;
|
extern unsigned int ifx_ptm_dbg_enable;
|
||||||
|
|
||||||
extern void ifx_ptm_get_fw_ver(unsigned int *major, unsigned int *minor);
|
extern void ifx_ptm_get_fw_ver(unsigned int *major, unsigned int *mid, unsigned int *minor);
|
||||||
|
|
||||||
extern void ifx_ptm_init_chip(struct platform_device *pdev);
|
extern void ifx_ptm_init_chip(struct platform_device *pdev);
|
||||||
extern void ifx_ptm_uninit_chip(void);
|
extern void ifx_ptm_uninit_chip(void);
|
||||||
|
@ -246,14 +246,22 @@ static inline int pp32_download_code(int pp32, u32 *code_src, unsigned int code_
|
|||||||
* ####################################
|
* ####################################
|
||||||
*/
|
*/
|
||||||
|
|
||||||
extern void ifx_ptm_get_fw_ver(unsigned int *major, unsigned int *minor)
|
void ifx_ptm_get_fw_ver(unsigned int *major, unsigned int *mid, unsigned int *minor)
|
||||||
{
|
{
|
||||||
ASSERT(major != NULL, "pointer is NULL");
|
ASSERT(major != NULL, "pointer is NULL");
|
||||||
ASSERT(minor != NULL, "pointer is NULL");
|
ASSERT(minor != NULL, "pointer is NULL");
|
||||||
|
|
||||||
|
if ( *(volatile unsigned int *)FW_VER_ID_NEW == 0 ) {
|
||||||
*major = FW_VER_ID->major;
|
*major = FW_VER_ID->major;
|
||||||
|
*mid = ~0;
|
||||||
*minor = FW_VER_ID->minor;
|
*minor = FW_VER_ID->minor;
|
||||||
}
|
}
|
||||||
|
else {
|
||||||
|
*major = FW_VER_ID_NEW->major;
|
||||||
|
*mid = FW_VER_ID_NEW->middle;
|
||||||
|
*minor = FW_VER_ID_NEW->minor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ifx_ptm_init_chip(struct platform_device *pdev)
|
void ifx_ptm_init_chip(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
|
@ -10,10 +10,10 @@ include $(INCLUDE_DIR)/kernel.mk
|
|||||||
|
|
||||||
PKG_NAME:=mac80211
|
PKG_NAME:=mac80211
|
||||||
|
|
||||||
PKG_VERSION:=5.8.18-1
|
PKG_VERSION:=5.10-rc6-1
|
||||||
PKG_RELEASE:=5
|
PKG_RELEASE:=1
|
||||||
PKG_SOURCE_URL:=@KERNEL/linux/kernel/projects/backports/stable/v5.8.18/
|
PKG_SOURCE_URL:=@KERNEL/linux/kernel/projects/backports/stable/v5.10-rc6/
|
||||||
PKG_HASH:=f04a8172423c6a945fc7d9844b04f33fda9ae574e552f8f18ee3bdfcfb494563
|
PKG_HASH:=24c1e84dc1e7bb52d4f67ce481c242f29212a4ceb7833af30e3c279a3f710832
|
||||||
|
|
||||||
PKG_SOURCE:=backports-$(PKG_VERSION).tar.xz
|
PKG_SOURCE:=backports-$(PKG_VERSION).tar.xz
|
||||||
PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/backports-$(PKG_VERSION)
|
PKG_BUILD_DIR:=$(KERNEL_BUILD_DIR)/backports-$(PKG_VERSION)
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
void ath10k_thermal_event_temperature(struct ath10k *ar, int temperature);
|
void ath10k_thermal_event_temperature(struct ath10k *ar, int temperature);
|
||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -142,6 +142,7 @@ ATH10K_SNOC=
|
@@ -143,6 +143,7 @@ ATH10K_SNOC=
|
||||||
ATH10K_DEBUG=
|
ATH10K_DEBUG=
|
||||||
ATH10K_DEBUGFS=
|
ATH10K_DEBUGFS=
|
||||||
ATH10K_SPECTRAL=
|
ATH10K_SPECTRAL=
|
||||||
|
@ -29,21 +29,6 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
- npend = ath9k_hw_numtxpending(ah, i);
|
- npend = ath9k_hw_numtxpending(ah, i);
|
||||||
- if (npend)
|
- if (npend)
|
||||||
- break;
|
- break;
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (ah->external_reset &&
|
|
||||||
- (npend || type == ATH9K_RESET_COLD)) {
|
|
||||||
- int reset_err = 0;
|
|
||||||
-
|
|
||||||
- ath_dbg(ath9k_hw_common(ah), RESET,
|
|
||||||
- "reset MAC via external reset\n");
|
|
||||||
-
|
|
||||||
- reset_err = ah->external_reset();
|
|
||||||
- if (reset_err) {
|
|
||||||
- ath_err(ath9k_hw_common(ah),
|
|
||||||
- "External reset failed, err=%d\n",
|
|
||||||
- reset_err);
|
|
||||||
- return false;
|
|
||||||
+ if (type == ATH9K_RESET_COLD)
|
+ if (type == ATH9K_RESET_COLD)
|
||||||
+ return true;
|
+ return true;
|
||||||
+
|
+
|
||||||
@ -59,35 +44,47 @@ Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|||||||
+ for (i = 0; i < AR_NUM_QCU; i++) {
|
+ for (i = 0; i < AR_NUM_QCU; i++) {
|
||||||
+ if (ath9k_hw_numtxpending(ah, i))
|
+ if (ath9k_hw_numtxpending(ah, i))
|
||||||
+ return true;
|
+ return true;
|
||||||
}
|
|
||||||
+ }
|
+ }
|
||||||
+
|
}
|
||||||
|
|
||||||
|
- if (ah->external_reset &&
|
||||||
|
- (npend || type == ATH9K_RESET_COLD)) {
|
||||||
|
- int reset_err = 0;
|
||||||
+ return false;
|
+ return false;
|
||||||
+}
|
+}
|
||||||
+
|
|
||||||
|
- ath_dbg(ath9k_hw_common(ah), RESET,
|
||||||
|
- "reset MAC via external reset\n");
|
||||||
+static bool ath9k_hw_external_reset(struct ath_hw *ah, int type)
|
+static bool ath9k_hw_external_reset(struct ath_hw *ah, int type)
|
||||||
+{
|
+{
|
||||||
+ int err;
|
+ int err;
|
||||||
+
|
|
||||||
|
- reset_err = ah->external_reset();
|
||||||
|
- if (reset_err) {
|
||||||
|
- ath_err(ath9k_hw_common(ah),
|
||||||
|
- "External reset failed, err=%d\n",
|
||||||
|
- reset_err);
|
||||||
|
- return false;
|
||||||
|
- }
|
||||||
+ if (!ah->external_reset || !ath9k_hw_need_external_reset(ah, type))
|
+ if (!ah->external_reset || !ath9k_hw_need_external_reset(ah, type))
|
||||||
+ return true;
|
+ return true;
|
||||||
+
|
|
||||||
+ ath_dbg(ath9k_hw_common(ah), RESET,
|
|
||||||
+ "reset MAC via external reset\n");
|
|
||||||
|
|
||||||
- REG_WRITE(ah, AR_RTC_RESET, 1);
|
- REG_WRITE(ah, AR_RTC_RESET, 1);
|
||||||
|
+ ath_dbg(ath9k_hw_common(ah), RESET,
|
||||||
|
+ "reset MAC via external reset\n");
|
||||||
|
+
|
||||||
+ err = ah->external_reset();
|
+ err = ah->external_reset();
|
||||||
+ if (err) {
|
+ if (err) {
|
||||||
+ ath_err(ath9k_hw_common(ah),
|
+ ath_err(ath9k_hw_common(ah),
|
||||||
+ "External reset failed, err=%d\n", err);
|
+ "External reset failed, err=%d\n", err);
|
||||||
+ return false;
|
+ return false;
|
||||||
}
|
+ }
|
||||||
|
+
|
||||||
+ if (AR_SREV_9550(ah)) {
|
+ if (AR_SREV_9550(ah)) {
|
||||||
+ REG_WRITE(ah, AR_RTC_RESET, 0);
|
+ REG_WRITE(ah, AR_RTC_RESET, 0);
|
||||||
+ udelay(10);
|
+ udelay(10);
|
||||||
+ }
|
}
|
||||||
+
|
|
||||||
+ REG_WRITE(ah, AR_RTC_RESET, 1);
|
+ REG_WRITE(ah, AR_RTC_RESET, 1);
|
||||||
+ udelay(10);
|
+ udelay(10);
|
||||||
+
|
+
|
||||||
|
@ -82,7 +82,7 @@
|
|||||||
help
|
help
|
||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -85,6 +85,7 @@ ADM8211=
|
@@ -86,6 +86,7 @@ ADM8211=
|
||||||
ATH_COMMON=
|
ATH_COMMON=
|
||||||
WLAN_VENDOR_ATH=
|
WLAN_VENDOR_ATH=
|
||||||
ATH_DEBUG=
|
ATH_DEBUG=
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/net/wireless/reg.c
|
--- a/net/wireless/reg.c
|
||||||
+++ b/net/wireless/reg.c
|
+++ b/net/wireless/reg.c
|
||||||
@@ -3045,6 +3045,8 @@ void regulatory_hint_country_ie(struct w
|
@@ -3252,6 +3252,8 @@ void regulatory_hint_country_ie(struct w
|
||||||
enum environment_cap env = ENVIRON_ANY;
|
enum environment_cap env = ENVIRON_ANY;
|
||||||
struct regulatory_request *request = NULL, *lr;
|
struct regulatory_request *request = NULL, *lr;
|
||||||
|
|
||||||
@ -9,7 +9,7 @@
|
|||||||
/* IE len must be evenly divisible by 2 */
|
/* IE len must be evenly divisible by 2 */
|
||||||
if (country_ie_len & 0x01)
|
if (country_ie_len & 0x01)
|
||||||
return;
|
return;
|
||||||
@@ -3296,6 +3298,7 @@ static bool is_wiphy_all_set_reg_flag(en
|
@@ -3503,6 +3505,7 @@ static bool is_wiphy_all_set_reg_flag(en
|
||||||
|
|
||||||
void regulatory_hint_disconnect(void)
|
void regulatory_hint_disconnect(void)
|
||||||
{
|
{
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/ath/ath9k/init.c
|
--- a/drivers/net/wireless/ath/ath9k/init.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
||||||
@@ -831,6 +831,7 @@ static const struct ieee80211_iface_limi
|
@@ -830,6 +830,7 @@ static const struct ieee80211_iface_limi
|
||||||
BIT(NL80211_IFTYPE_AP) },
|
BIT(NL80211_IFTYPE_AP) },
|
||||||
{ .max = 1, .types = BIT(NL80211_IFTYPE_P2P_CLIENT) |
|
{ .max = 1, .types = BIT(NL80211_IFTYPE_P2P_CLIENT) |
|
||||||
BIT(NL80211_IFTYPE_P2P_GO) },
|
BIT(NL80211_IFTYPE_P2P_GO) },
|
||||||
|
@ -11,7 +11,7 @@ drivers/net/wireless/ath/ath5k/debug.c | 86 ++++++++++++++++++++++++++++++++
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath5k/debug.c
|
--- a/drivers/net/wireless/ath/ath5k/debug.c
|
||||||
+++ b/drivers/net/wireless/ath/ath5k/debug.c
|
+++ b/drivers/net/wireless/ath/ath5k/debug.c
|
||||||
@@ -822,6 +822,97 @@ static const struct file_operations fops
|
@@ -803,6 +803,97 @@ static const struct file_operations fops
|
||||||
.llseek = default_llseek,
|
.llseek = default_llseek,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -109,7 +109,7 @@ drivers/net/wireless/ath/ath5k/debug.c | 86 ++++++++++++++++++++++++++++++++
|
|||||||
|
|
||||||
/* debugfs: queues etc */
|
/* debugfs: queues etc */
|
||||||
|
|
||||||
@@ -1016,6 +1107,8 @@ ath5k_debug_init_device(struct ath5k_hw
|
@@ -997,6 +1088,8 @@ ath5k_debug_init_device(struct ath5k_hw
|
||||||
debugfs_create_file("queue", 0600, phydir, ah, &fops_queue);
|
debugfs_create_file("queue", 0600, phydir, ah, &fops_queue);
|
||||||
debugfs_create_bool("32khz_clock", 0600, phydir,
|
debugfs_create_bool("32khz_clock", 0600, phydir,
|
||||||
&ah->ah_use_32khz_clock);
|
&ah->ah_use_32khz_clock);
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: David Bauer <mail@david-bauer.net>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath9k/init.c
|
--- a/drivers/net/wireless/ath/ath9k/init.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
||||||
@@ -928,6 +928,7 @@ static void ath9k_set_hw_capab(struct at
|
@@ -927,6 +927,7 @@ static void ath9k_set_hw_capab(struct at
|
||||||
ieee80211_hw_set(hw, HOST_BROADCAST_PS_BUFFERING);
|
ieee80211_hw_set(hw, HOST_BROADCAST_PS_BUFFERING);
|
||||||
ieee80211_hw_set(hw, SUPPORT_FAST_XMIT);
|
ieee80211_hw_set(hw, SUPPORT_FAST_XMIT);
|
||||||
ieee80211_hw_set(hw, SUPPORTS_CLONED_SKBS);
|
ieee80211_hw_set(hw, SUPPORTS_CLONED_SKBS);
|
||||||
@ -22,7 +22,7 @@ Signed-off-by: David Bauer <mail@david-bauer.net>
|
|||||||
|
|
||||||
if (ath9k_ps_enable)
|
if (ath9k_ps_enable)
|
||||||
ieee80211_hw_set(hw, SUPPORTS_PS);
|
ieee80211_hw_set(hw, SUPPORTS_PS);
|
||||||
@@ -940,9 +941,6 @@ static void ath9k_set_hw_capab(struct at
|
@@ -939,9 +940,6 @@ static void ath9k_set_hw_capab(struct at
|
||||||
IEEE80211_RADIOTAP_MCS_HAVE_STBC;
|
IEEE80211_RADIOTAP_MCS_HAVE_STBC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,7 +103,8 @@
|
|||||||
+ GFP_KERNEL);
|
+ GFP_KERNEL);
|
||||||
+ if (!led)
|
+ if (!led)
|
||||||
+ return -ENOMEM;
|
+ return -ENOMEM;
|
||||||
+
|
|
||||||
|
- ath9k_hw_set_gpio(sc->sc_ah, sc->sc_ah->led_pin, val);
|
||||||
+ led->gpio = gpio = (struct gpio_led *) (led + 1);
|
+ led->gpio = gpio = (struct gpio_led *) (led + 1);
|
||||||
+ _name = (char *) (led->gpio + 1);
|
+ _name = (char *) (led->gpio + 1);
|
||||||
+
|
+
|
||||||
@ -116,8 +117,7 @@
|
|||||||
+ ret = ath_add_led(sc, led);
|
+ ret = ath_add_led(sc, led);
|
||||||
+ if (unlikely(ret < 0))
|
+ if (unlikely(ret < 0))
|
||||||
+ kfree(led);
|
+ kfree(led);
|
||||||
|
+
|
||||||
- ath9k_hw_set_gpio(sc->sc_ah, sc->sc_ah->led_pin, val);
|
|
||||||
+ return ret;
|
+ return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -125,11 +125,11 @@
|
|||||||
{
|
{
|
||||||
- if (!sc->led_registered)
|
- if (!sc->led_registered)
|
||||||
- return;
|
- return;
|
||||||
+ struct ath_led *led;
|
-
|
||||||
|
|
||||||
- ath_led_brightness(&sc->led_cdev, LED_OFF);
|
- ath_led_brightness(&sc->led_cdev, LED_OFF);
|
||||||
- led_classdev_unregister(&sc->led_cdev);
|
- led_classdev_unregister(&sc->led_cdev);
|
||||||
-
|
+ struct ath_led *led;
|
||||||
|
|
||||||
- ath9k_hw_gpio_free(sc->sc_ah, sc->sc_ah->led_pin);
|
- ath9k_hw_gpio_free(sc->sc_ah, sc->sc_ah->led_pin);
|
||||||
+ while (!list_empty(&sc->leds)) {
|
+ while (!list_empty(&sc->leds)) {
|
||||||
+ led = list_first_entry(&sc->leds, struct ath_led, list);
|
+ led = list_first_entry(&sc->leds, struct ath_led, list);
|
||||||
|
@ -125,7 +125,7 @@
|
|||||||
REG_SET_BIT(ah, AR_BTCOEX_WL_LNADIV, AR_BTCOEX_WL_LNADIV_FORCE_ON);
|
REG_SET_BIT(ah, AR_BTCOEX_WL_LNADIV, AR_BTCOEX_WL_LNADIV_FORCE_ON);
|
||||||
--- a/drivers/net/wireless/ath/ath9k/main.c
|
--- a/drivers/net/wireless/ath/ath9k/main.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/main.c
|
+++ b/drivers/net/wireless/ath/ath9k/main.c
|
||||||
@@ -528,6 +528,11 @@ irqreturn_t ath_isr(int irq, void *dev)
|
@@ -531,6 +531,11 @@ irqreturn_t ath_isr(int irq, void *dev)
|
||||||
if (test_bit(ATH_OP_HW_RESET, &common->op_flags))
|
if (test_bit(ATH_OP_HW_RESET, &common->op_flags))
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
|
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
ops->spectral_scan_config = ar9003_hw_spectral_scan_config;
|
ops->spectral_scan_config = ar9003_hw_spectral_scan_config;
|
||||||
--- a/drivers/net/wireless/ath/ath9k/init.c
|
--- a/drivers/net/wireless/ath/ath9k/init.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
+++ b/drivers/net/wireless/ath/ath9k/init.c
|
||||||
@@ -819,7 +819,8 @@ static void ath9k_init_txpower_limits(st
|
@@ -818,7 +818,8 @@ static void ath9k_init_txpower_limits(st
|
||||||
if (ah->caps.hw_caps & ATH9K_HW_CAP_5GHZ)
|
if (ah->caps.hw_caps & ATH9K_HW_CAP_5GHZ)
|
||||||
ath9k_init_band_txpower(sc, NL80211_BAND_5GHZ);
|
ath9k_init_band_txpower(sc, NL80211_BAND_5GHZ);
|
||||||
|
|
||||||
@ -66,7 +66,7 @@
|
|||||||
|
|
||||||
static const struct ieee80211_iface_limit if_limits[] = {
|
static const struct ieee80211_iface_limit if_limits[] = {
|
||||||
@@ -1015,6 +1016,18 @@ static void ath9k_set_hw_capab(struct at
|
@@ -1015,6 +1016,18 @@ static void ath9k_set_hw_capab(struct at
|
||||||
NL80211_EXT_FEATURE_MULTICAST_REGISTRATIONS);
|
wiphy_ext_feature_set(hw->wiphy, NL80211_EXT_FEATURE_CAN_REPLACE_PTK0);
|
||||||
}
|
}
|
||||||
|
|
||||||
+static void ath_get_initial_entropy(struct ath_softc *sc)
|
+static void ath_get_initial_entropy(struct ath_softc *sc)
|
||||||
@ -110,7 +110,7 @@
|
|||||||
static inline void ath9k_hw_set_bt_ant_diversity(struct ath_hw *ah, bool enable)
|
static inline void ath9k_hw_set_bt_ant_diversity(struct ath_hw *ah, bool enable)
|
||||||
--- a/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
--- a/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
+++ b/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
||||||
@@ -1320,9 +1320,30 @@ void ar5008_hw_init_rate_txpower(struct
|
@@ -1349,9 +1349,30 @@ void ar5008_hw_init_rate_txpower(struct
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -141,7 +141,7 @@
|
|||||||
static const u32 ar5416_cca_regs[6] = {
|
static const u32 ar5416_cca_regs[6] = {
|
||||||
AR_PHY_CCA,
|
AR_PHY_CCA,
|
||||||
AR_PHY_CH1_CCA,
|
AR_PHY_CH1_CCA,
|
||||||
@@ -1337,6 +1358,8 @@ int ar5008_hw_attach_phy_ops(struct ath_
|
@@ -1366,6 +1387,8 @@ int ar5008_hw_attach_phy_ops(struct ath_
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
--- a/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
||||||
+++ b/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
+++ b/drivers/net/wireless/ath/ath9k/ar5008_phy.c
|
||||||
@@ -949,55 +949,6 @@ static bool ar5008_hw_ani_control_new(st
|
@@ -978,55 +978,6 @@ static bool ar5008_hw_ani_control_new(st
|
||||||
* on == 0 means more noise imm
|
* on == 0 means more noise imm
|
||||||
*/
|
*/
|
||||||
u32 on = param ? 1 : 0;
|
u32 on = param ? 1 : 0;
|
||||||
|
@ -337,9 +337,9 @@
|
|||||||
#include "btcoex.h"
|
#include "btcoex.h"
|
||||||
+#include "hsr.h"
|
+#include "hsr.h"
|
||||||
|
|
||||||
u8 ath9k_parse_mpdudensity(u8 mpdudensity)
|
static void ath9k_flush(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
{
|
u32 queues, bool drop);
|
||||||
@@ -649,6 +650,7 @@ void ath_reset_work(struct work_struct *
|
@@ -652,6 +653,7 @@ void ath_reset_work(struct work_struct *
|
||||||
static int ath9k_start(struct ieee80211_hw *hw)
|
static int ath9k_start(struct ieee80211_hw *hw)
|
||||||
{
|
{
|
||||||
struct ath_softc *sc = hw->priv;
|
struct ath_softc *sc = hw->priv;
|
||||||
@ -347,7 +347,7 @@
|
|||||||
struct ath_hw *ah = sc->sc_ah;
|
struct ath_hw *ah = sc->sc_ah;
|
||||||
struct ath_common *common = ath9k_hw_common(ah);
|
struct ath_common *common = ath9k_hw_common(ah);
|
||||||
struct ieee80211_channel *curchan = sc->cur_chan->chandef.chan;
|
struct ieee80211_channel *curchan = sc->cur_chan->chandef.chan;
|
||||||
@@ -727,6 +729,11 @@ static int ath9k_start(struct ieee80211_
|
@@ -730,6 +732,11 @@ static int ath9k_start(struct ieee80211_
|
||||||
AR_GPIO_OUTPUT_MUX_AS_OUTPUT);
|
AR_GPIO_OUTPUT_MUX_AS_OUTPUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -371,7 +371,7 @@
|
|||||||
|
|
||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -112,6 +112,7 @@ ATH9K_WOW=
|
@@ -113,6 +113,7 @@ ATH9K_WOW=
|
||||||
ATH9K_RFKILL=
|
ATH9K_RFKILL=
|
||||||
ATH9K_CHANNEL_CONTEXT=
|
ATH9K_CHANNEL_CONTEXT=
|
||||||
ATH9K_PCOEM=
|
ATH9K_PCOEM=
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
static int ath9k_init_softc(u16 devid, struct ath_softc *sc,
|
static int ath9k_init_softc(u16 devid, struct ath_softc *sc,
|
||||||
const struct ath_bus_ops *bus_ops)
|
const struct ath_bus_ops *bus_ops)
|
||||||
{
|
{
|
||||||
@@ -758,6 +764,9 @@ static int ath9k_init_softc(u16 devid, s
|
@@ -757,6 +763,9 @@ static int ath9k_init_softc(u16 devid, s
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_hw;
|
goto err_hw;
|
||||||
|
|
||||||
|
@ -0,0 +1,49 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Sun, 14 Feb 2021 19:45:50 +0100
|
||||||
|
Subject: [PATCH] ath9k: fix transmitting to stations in dynamic SMPS mode
|
||||||
|
|
||||||
|
When transmitting to a receiver in dynamic SMPS mode, all transmissions that
|
||||||
|
use multiple spatial streams need to be sent using CTS-to-self or RTS/CTS to
|
||||||
|
give the receiver's extra chains some time to wake up.
|
||||||
|
This fixes the tx rate getting stuck at <= MCS7 for some clients, especially
|
||||||
|
Intel ones, which make aggressive use of SMPS.
|
||||||
|
|
||||||
|
Cc: stable@vger.kernel.org
|
||||||
|
Reported-by: Martin Kennedy <hurricos@gmail.com>
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/drivers/net/wireless/ath/ath9k/ath9k.h
|
||||||
|
+++ b/drivers/net/wireless/ath/ath9k/ath9k.h
|
||||||
|
@@ -179,7 +179,8 @@ struct ath_frame_info {
|
||||||
|
s8 txq;
|
||||||
|
u8 keyix;
|
||||||
|
u8 rtscts_rate;
|
||||||
|
- u8 retries : 7;
|
||||||
|
+ u8 retries : 6;
|
||||||
|
+ u8 dyn_smps : 1;
|
||||||
|
u8 baw_tracked : 1;
|
||||||
|
u8 tx_power;
|
||||||
|
enum ath9k_key_type keytype:2;
|
||||||
|
--- a/drivers/net/wireless/ath/ath9k/xmit.c
|
||||||
|
+++ b/drivers/net/wireless/ath/ath9k/xmit.c
|
||||||
|
@@ -1271,6 +1271,11 @@ static void ath_buf_set_rate(struct ath_
|
||||||
|
is_40, is_sgi, is_sp);
|
||||||
|
if (rix < 8 && (tx_info->flags & IEEE80211_TX_CTL_STBC))
|
||||||
|
info->rates[i].RateFlags |= ATH9K_RATESERIES_STBC;
|
||||||
|
+ if (rix >= 8 && fi->dyn_smps) {
|
||||||
|
+ info->rates[i].RateFlags |=
|
||||||
|
+ ATH9K_RATESERIES_RTS_CTS;
|
||||||
|
+ info->flags |= ATH9K_TXDESC_CTSENA;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
info->txpower[i] = ath_get_rate_txpower(sc, bf, rix,
|
||||||
|
is_40, false);
|
||||||
|
@@ -2114,6 +2119,7 @@ static void setup_frame_info(struct ieee
|
||||||
|
fi->keyix = an->ps_key;
|
||||||
|
else
|
||||||
|
fi->keyix = ATH9K_TXKEYIX_INVALID;
|
||||||
|
+ fi->dyn_smps = sta && sta->smps_mode == IEEE80211_SMPS_DYNAMIC;
|
||||||
|
fi->keytype = keytype;
|
||||||
|
fi->framelen = framelen;
|
||||||
|
fi->tx_power = txpower;
|
@ -14,7 +14,7 @@ Signed-off-by: Sven Eckelmann <sven@open-mesh.com>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath10k/core.c
|
--- a/drivers/net/wireless/ath/ath10k/core.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/core.c
|
+++ b/drivers/net/wireless/ath/ath10k/core.c
|
||||||
@@ -3172,6 +3172,16 @@ int ath10k_core_register(struct ath10k *
|
@@ -3189,6 +3189,16 @@ int ath10k_core_register(struct ath10k *
|
||||||
|
|
||||||
queue_work(ar->workqueue, &ar->register_work);
|
queue_work(ar->workqueue, &ar->register_work);
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
@@ -9053,6 +9053,21 @@ static int ath10k_mac_init_rd(struct ath
|
@@ -9713,6 +9713,21 @@ static int ath10k_mac_init_rd(struct ath
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -22,7 +22,7 @@
|
|||||||
int ath10k_mac_register(struct ath10k *ar)
|
int ath10k_mac_register(struct ath10k *ar)
|
||||||
{
|
{
|
||||||
static const u32 cipher_suites[] = {
|
static const u32 cipher_suites[] = {
|
||||||
@@ -9380,6 +9395,12 @@ int ath10k_mac_register(struct ath10k *a
|
@@ -10062,6 +10077,12 @@ int ath10k_mac_register(struct ath10k *a
|
||||||
|
|
||||||
ar->hw->weight_multiplier = ATH10K_AIRTIME_WEIGHT_MULTIPLIER;
|
ar->hw->weight_multiplier = ATH10K_AIRTIME_WEIGHT_MULTIPLIER;
|
||||||
|
|
||||||
|
@ -114,7 +114,7 @@ v13:
|
|||||||
ath10k_core-$(CONFIG_DEV_COREDUMP) += coredump.o
|
ath10k_core-$(CONFIG_DEV_COREDUMP) += coredump.o
|
||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -145,6 +145,7 @@ ATH10K_DEBUG=
|
@@ -146,6 +146,7 @@ ATH10K_DEBUG=
|
||||||
ATH10K_DEBUGFS=
|
ATH10K_DEBUGFS=
|
||||||
ATH10K_SPECTRAL=
|
ATH10K_SPECTRAL=
|
||||||
ATH10K_THERMAL=
|
ATH10K_THERMAL=
|
||||||
@ -140,7 +140,7 @@ v13:
|
|||||||
.patch_load_addr = QCA988X_HW_2_0_PATCH_LOAD_ADDR,
|
.patch_load_addr = QCA988X_HW_2_0_PATCH_LOAD_ADDR,
|
||||||
.uart_pin = 7,
|
.uart_pin = 7,
|
||||||
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_ALL,
|
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_ALL,
|
||||||
@@ -131,6 +133,7 @@ static const struct ath10k_hw_params ath
|
@@ -130,6 +132,7 @@ static const struct ath10k_hw_params ath
|
||||||
.dev_id = QCA9887_1_0_DEVICE_ID,
|
.dev_id = QCA9887_1_0_DEVICE_ID,
|
||||||
.bus = ATH10K_BUS_PCI,
|
.bus = ATH10K_BUS_PCI,
|
||||||
.name = "qca9887 hw1.0",
|
.name = "qca9887 hw1.0",
|
||||||
@ -148,7 +148,7 @@ v13:
|
|||||||
.patch_load_addr = QCA9887_HW_1_0_PATCH_LOAD_ADDR,
|
.patch_load_addr = QCA9887_HW_1_0_PATCH_LOAD_ADDR,
|
||||||
.uart_pin = 7,
|
.uart_pin = 7,
|
||||||
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_ALL,
|
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_ALL,
|
||||||
@@ -340,6 +343,7 @@ static const struct ath10k_hw_params ath
|
@@ -335,6 +338,7 @@ static const struct ath10k_hw_params ath
|
||||||
.dev_id = QCA99X0_2_0_DEVICE_ID,
|
.dev_id = QCA99X0_2_0_DEVICE_ID,
|
||||||
.bus = ATH10K_BUS_PCI,
|
.bus = ATH10K_BUS_PCI,
|
||||||
.name = "qca99x0 hw2.0",
|
.name = "qca99x0 hw2.0",
|
||||||
@ -156,7 +156,7 @@ v13:
|
|||||||
.patch_load_addr = QCA99X0_HW_2_0_PATCH_LOAD_ADDR,
|
.patch_load_addr = QCA99X0_HW_2_0_PATCH_LOAD_ADDR,
|
||||||
.uart_pin = 7,
|
.uart_pin = 7,
|
||||||
.otp_exe_param = 0x00000700,
|
.otp_exe_param = 0x00000700,
|
||||||
@@ -381,6 +385,7 @@ static const struct ath10k_hw_params ath
|
@@ -375,6 +379,7 @@ static const struct ath10k_hw_params ath
|
||||||
.dev_id = QCA9984_1_0_DEVICE_ID,
|
.dev_id = QCA9984_1_0_DEVICE_ID,
|
||||||
.bus = ATH10K_BUS_PCI,
|
.bus = ATH10K_BUS_PCI,
|
||||||
.name = "qca9984/qca9994 hw1.0",
|
.name = "qca9984/qca9994 hw1.0",
|
||||||
@ -164,7 +164,7 @@ v13:
|
|||||||
.patch_load_addr = QCA9984_HW_1_0_PATCH_LOAD_ADDR,
|
.patch_load_addr = QCA9984_HW_1_0_PATCH_LOAD_ADDR,
|
||||||
.uart_pin = 7,
|
.uart_pin = 7,
|
||||||
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_EACH,
|
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_EACH,
|
||||||
@@ -429,6 +434,7 @@ static const struct ath10k_hw_params ath
|
@@ -422,6 +427,7 @@ static const struct ath10k_hw_params ath
|
||||||
.dev_id = QCA9888_2_0_DEVICE_ID,
|
.dev_id = QCA9888_2_0_DEVICE_ID,
|
||||||
.bus = ATH10K_BUS_PCI,
|
.bus = ATH10K_BUS_PCI,
|
||||||
.name = "qca9888 hw2.0",
|
.name = "qca9888 hw2.0",
|
||||||
@ -172,7 +172,7 @@ v13:
|
|||||||
.patch_load_addr = QCA9888_HW_2_0_PATCH_LOAD_ADDR,
|
.patch_load_addr = QCA9888_HW_2_0_PATCH_LOAD_ADDR,
|
||||||
.uart_pin = 7,
|
.uart_pin = 7,
|
||||||
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_EACH,
|
.cc_wraparound_type = ATH10K_HW_CC_WRAP_SHIFTED_EACH,
|
||||||
@@ -2887,6 +2893,10 @@ int ath10k_core_start(struct ath10k *ar,
|
@@ -2904,6 +2910,10 @@ int ath10k_core_start(struct ath10k *ar,
|
||||||
goto err_hif_stop;
|
goto err_hif_stop;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -183,7 +183,7 @@ v13:
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
err_hif_stop:
|
err_hif_stop:
|
||||||
@@ -3145,9 +3155,18 @@ static void ath10k_core_register_work(st
|
@@ -3162,9 +3172,18 @@ static void ath10k_core_register_work(st
|
||||||
goto err_spectral_destroy;
|
goto err_spectral_destroy;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,7 +202,7 @@ v13:
|
|||||||
err_spectral_destroy:
|
err_spectral_destroy:
|
||||||
ath10k_spectral_destroy(ar);
|
ath10k_spectral_destroy(ar);
|
||||||
err_debug_destroy:
|
err_debug_destroy:
|
||||||
@@ -3193,6 +3212,8 @@ void ath10k_core_unregister(struct ath10
|
@@ -3210,6 +3229,8 @@ void ath10k_core_unregister(struct ath10
|
||||||
if (!test_bit(ATH10K_FLAG_CORE_REGISTERED, &ar->dev_flags))
|
if (!test_bit(ATH10K_FLAG_CORE_REGISTERED, &ar->dev_flags))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -221,7 +221,7 @@ v13:
|
|||||||
|
|
||||||
#include "htt.h"
|
#include "htt.h"
|
||||||
#include "htc.h"
|
#include "htc.h"
|
||||||
@@ -1216,6 +1217,13 @@ struct ath10k {
|
@@ -1237,6 +1238,13 @@ struct ath10k {
|
||||||
} testmode;
|
} testmode;
|
||||||
|
|
||||||
struct {
|
struct {
|
||||||
@ -407,10 +407,10 @@ v13:
|
|||||||
/* Rates */
|
/* Rates */
|
||||||
--- a/drivers/net/wireless/ath/ath10k/wmi-ops.h
|
--- a/drivers/net/wireless/ath/ath10k/wmi-ops.h
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/wmi-ops.h
|
+++ b/drivers/net/wireless/ath/ath10k/wmi-ops.h
|
||||||
@@ -224,7 +224,10 @@ struct wmi_ops {
|
@@ -226,7 +226,10 @@ struct wmi_ops {
|
||||||
struct sk_buff *(*gen_bb_timing)
|
|
||||||
(struct ath10k *ar,
|
|
||||||
const struct wmi_bb_timing_cfg_arg *arg);
|
const struct wmi_bb_timing_cfg_arg *arg);
|
||||||
|
struct sk_buff *(*gen_per_peer_per_tid_cfg)(struct ath10k *ar,
|
||||||
|
const struct wmi_per_peer_per_tid_cfg_arg *arg);
|
||||||
+ struct sk_buff *(*gen_gpio_config)(struct ath10k *ar, u32 gpio_num,
|
+ struct sk_buff *(*gen_gpio_config)(struct ath10k *ar, u32 gpio_num,
|
||||||
+ u32 input, u32 pull_type, u32 intr_mode);
|
+ u32 input, u32 pull_type, u32 intr_mode);
|
||||||
|
|
||||||
@ -418,7 +418,7 @@ v13:
|
|||||||
};
|
};
|
||||||
|
|
||||||
int ath10k_wmi_cmd_send(struct ath10k *ar, struct sk_buff *skb, u32 cmd_id);
|
int ath10k_wmi_cmd_send(struct ath10k *ar, struct sk_buff *skb, u32 cmd_id);
|
||||||
@@ -1120,6 +1123,35 @@ ath10k_wmi_force_fw_hang(struct ath10k *
|
@@ -1122,6 +1125,35 @@ ath10k_wmi_force_fw_hang(struct ath10k *
|
||||||
return ath10k_wmi_cmd_send(ar, skb, ar->wmi.cmd->force_fw_hang_cmdid);
|
return ath10k_wmi_cmd_send(ar, skb, ar->wmi.cmd->force_fw_hang_cmdid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -467,7 +467,7 @@ v13:
|
|||||||
static const struct wmi_peer_flags_map wmi_tlv_peer_flags_map = {
|
static const struct wmi_peer_flags_map wmi_tlv_peer_flags_map = {
|
||||||
--- a/drivers/net/wireless/ath/ath10k/wmi.c
|
--- a/drivers/net/wireless/ath/ath10k/wmi.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/wmi.c
|
+++ b/drivers/net/wireless/ath/ath10k/wmi.c
|
||||||
@@ -7471,6 +7471,49 @@ ath10k_wmi_op_gen_peer_set_param(struct
|
@@ -7463,6 +7463,49 @@ ath10k_wmi_op_gen_peer_set_param(struct
|
||||||
return skb;
|
return skb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -517,7 +517,7 @@ v13:
|
|||||||
static struct sk_buff *
|
static struct sk_buff *
|
||||||
ath10k_wmi_op_gen_set_psmode(struct ath10k *ar, u32 vdev_id,
|
ath10k_wmi_op_gen_set_psmode(struct ath10k *ar, u32 vdev_id,
|
||||||
enum wmi_sta_ps_mode psmode)
|
enum wmi_sta_ps_mode psmode)
|
||||||
@@ -9129,6 +9172,9 @@ static const struct wmi_ops wmi_ops = {
|
@@ -9151,6 +9194,9 @@ static const struct wmi_ops wmi_ops = {
|
||||||
.fw_stats_fill = ath10k_wmi_main_op_fw_stats_fill,
|
.fw_stats_fill = ath10k_wmi_main_op_fw_stats_fill,
|
||||||
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
||||||
.gen_echo = ath10k_wmi_op_gen_echo,
|
.gen_echo = ath10k_wmi_op_gen_echo,
|
||||||
@ -527,7 +527,7 @@ v13:
|
|||||||
/* .gen_bcn_tmpl not implemented */
|
/* .gen_bcn_tmpl not implemented */
|
||||||
/* .gen_prb_tmpl not implemented */
|
/* .gen_prb_tmpl not implemented */
|
||||||
/* .gen_p2p_go_bcn_ie not implemented */
|
/* .gen_p2p_go_bcn_ie not implemented */
|
||||||
@@ -9199,6 +9245,8 @@ static const struct wmi_ops wmi_10_1_ops
|
@@ -9221,6 +9267,8 @@ static const struct wmi_ops wmi_10_1_ops
|
||||||
.fw_stats_fill = ath10k_wmi_10x_op_fw_stats_fill,
|
.fw_stats_fill = ath10k_wmi_10x_op_fw_stats_fill,
|
||||||
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
||||||
.gen_echo = ath10k_wmi_op_gen_echo,
|
.gen_echo = ath10k_wmi_op_gen_echo,
|
||||||
@ -536,7 +536,7 @@ v13:
|
|||||||
/* .gen_bcn_tmpl not implemented */
|
/* .gen_bcn_tmpl not implemented */
|
||||||
/* .gen_prb_tmpl not implemented */
|
/* .gen_prb_tmpl not implemented */
|
||||||
/* .gen_p2p_go_bcn_ie not implemented */
|
/* .gen_p2p_go_bcn_ie not implemented */
|
||||||
@@ -9271,6 +9319,8 @@ static const struct wmi_ops wmi_10_2_ops
|
@@ -9293,6 +9341,8 @@ static const struct wmi_ops wmi_10_2_ops
|
||||||
.gen_delba_send = ath10k_wmi_op_gen_delba_send,
|
.gen_delba_send = ath10k_wmi_op_gen_delba_send,
|
||||||
.fw_stats_fill = ath10k_wmi_10x_op_fw_stats_fill,
|
.fw_stats_fill = ath10k_wmi_10x_op_fw_stats_fill,
|
||||||
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
.get_vdev_subtype = ath10k_wmi_op_get_vdev_subtype,
|
||||||
@ -545,7 +545,7 @@ v13:
|
|||||||
/* .gen_pdev_enable_adaptive_cca not implemented */
|
/* .gen_pdev_enable_adaptive_cca not implemented */
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -9342,6 +9392,8 @@ static const struct wmi_ops wmi_10_2_4_o
|
@@ -9364,6 +9414,8 @@ static const struct wmi_ops wmi_10_2_4_o
|
||||||
ath10k_wmi_op_gen_pdev_enable_adaptive_cca,
|
ath10k_wmi_op_gen_pdev_enable_adaptive_cca,
|
||||||
.get_vdev_subtype = ath10k_wmi_10_2_4_op_get_vdev_subtype,
|
.get_vdev_subtype = ath10k_wmi_10_2_4_op_get_vdev_subtype,
|
||||||
.gen_bb_timing = ath10k_wmi_10_2_4_op_gen_bb_timing,
|
.gen_bb_timing = ath10k_wmi_10_2_4_op_gen_bb_timing,
|
||||||
@ -554,7 +554,7 @@ v13:
|
|||||||
/* .gen_bcn_tmpl not implemented */
|
/* .gen_bcn_tmpl not implemented */
|
||||||
/* .gen_prb_tmpl not implemented */
|
/* .gen_prb_tmpl not implemented */
|
||||||
/* .gen_p2p_go_bcn_ie not implemented */
|
/* .gen_p2p_go_bcn_ie not implemented */
|
||||||
@@ -9422,6 +9474,8 @@ static const struct wmi_ops wmi_10_4_ops
|
@@ -9445,6 +9497,8 @@ static const struct wmi_ops wmi_10_4_ops
|
||||||
.gen_pdev_bss_chan_info_req = ath10k_wmi_10_2_op_gen_pdev_bss_chan_info,
|
.gen_pdev_bss_chan_info_req = ath10k_wmi_10_2_op_gen_pdev_bss_chan_info,
|
||||||
.gen_echo = ath10k_wmi_op_gen_echo,
|
.gen_echo = ath10k_wmi_op_gen_echo,
|
||||||
.gen_pdev_get_tpc_config = ath10k_wmi_10_2_4_op_gen_pdev_get_tpc_config,
|
.gen_pdev_get_tpc_config = ath10k_wmi_10_2_4_op_gen_pdev_get_tpc_config,
|
||||||
@ -565,7 +565,7 @@ v13:
|
|||||||
int ath10k_wmi_attach(struct ath10k *ar)
|
int ath10k_wmi_attach(struct ath10k *ar)
|
||||||
--- a/drivers/net/wireless/ath/ath10k/wmi.h
|
--- a/drivers/net/wireless/ath/ath10k/wmi.h
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/wmi.h
|
+++ b/drivers/net/wireless/ath/ath10k/wmi.h
|
||||||
@@ -3016,6 +3016,41 @@ enum wmi_10_4_feature_mask {
|
@@ -3027,6 +3027,41 @@ enum wmi_10_4_feature_mask {
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ Signed-off-by: Mathias Kresin <dev@kresin.me>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath10k/core.h
|
--- a/drivers/net/wireless/ath/ath10k/core.h
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/core.h
|
+++ b/drivers/net/wireless/ath/ath10k/core.h
|
||||||
@@ -1269,6 +1269,10 @@ struct ath10k {
|
@@ -1290,6 +1290,10 @@ struct ath10k {
|
||||||
bool coex_support;
|
bool coex_support;
|
||||||
int coex_gpio_pin;
|
int coex_gpio_pin;
|
||||||
|
|
||||||
@ -42,7 +42,7 @@ Signed-off-by: Mathias Kresin <dev@kresin.me>
|
|||||||
if (ret)
|
if (ret)
|
||||||
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
@@ -9397,7 +9397,7 @@ int ath10k_mac_register(struct ath10k *a
|
@@ -10079,7 +10079,7 @@ int ath10k_mac_register(struct ath10k *a
|
||||||
ar->hw->weight_multiplier = ATH10K_AIRTIME_WEIGHT_MULTIPLIER;
|
ar->hw->weight_multiplier = ATH10K_AIRTIME_WEIGHT_MULTIPLIER;
|
||||||
|
|
||||||
#ifdef CPTCFG_MAC80211_LEDS
|
#ifdef CPTCFG_MAC80211_LEDS
|
||||||
|
@ -20,7 +20,7 @@ Forwarded: https://patchwork.kernel.org/patch/10986723/
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
@@ -1043,7 +1043,7 @@ static int ath10k_monitor_vdev_start(str
|
@@ -1038,7 +1038,7 @@ static int ath10k_monitor_vdev_start(str
|
||||||
arg.channel.min_power = 0;
|
arg.channel.min_power = 0;
|
||||||
arg.channel.max_power = channel->max_power * 2;
|
arg.channel.max_power = channel->max_power * 2;
|
||||||
arg.channel.max_reg_power = channel->max_reg_power * 2;
|
arg.channel.max_reg_power = channel->max_reg_power * 2;
|
||||||
@ -29,7 +29,7 @@ Forwarded: https://patchwork.kernel.org/patch/10986723/
|
|||||||
|
|
||||||
reinit_completion(&ar->vdev_setup_done);
|
reinit_completion(&ar->vdev_setup_done);
|
||||||
reinit_completion(&ar->vdev_delete_done);
|
reinit_completion(&ar->vdev_delete_done);
|
||||||
@@ -1489,7 +1489,7 @@ static int ath10k_vdev_start_restart(str
|
@@ -1484,7 +1484,7 @@ static int ath10k_vdev_start_restart(str
|
||||||
arg.channel.min_power = 0;
|
arg.channel.min_power = 0;
|
||||||
arg.channel.max_power = chandef->chan->max_power * 2;
|
arg.channel.max_power = chandef->chan->max_power * 2;
|
||||||
arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
|
arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
|
||||||
@ -38,7 +38,7 @@ Forwarded: https://patchwork.kernel.org/patch/10986723/
|
|||||||
|
|
||||||
if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
|
if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
|
||||||
arg.ssid = arvif->u.ap.ssid;
|
arg.ssid = arvif->u.ap.ssid;
|
||||||
@@ -3194,7 +3194,7 @@ static int ath10k_update_channel_list(st
|
@@ -3255,7 +3255,7 @@ static int ath10k_update_channel_list(st
|
||||||
ch->min_power = 0;
|
ch->min_power = 0;
|
||||||
ch->max_power = channel->max_power * 2;
|
ch->max_power = channel->max_power * 2;
|
||||||
ch->max_reg_power = channel->max_reg_power * 2;
|
ch->max_reg_power = channel->max_reg_power * 2;
|
||||||
|
@ -28,7 +28,7 @@ Forwarded: no
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
--- a/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
+++ b/drivers/net/wireless/ath/ath10k/mac.c
|
||||||
@@ -1011,6 +1011,40 @@ static inline int ath10k_vdev_setup_sync
|
@@ -1006,6 +1006,40 @@ static inline int ath10k_vdev_setup_sync
|
||||||
return ar->last_wmi_vdev_start_status;
|
return ar->last_wmi_vdev_start_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,7 +69,7 @@ Forwarded: no
|
|||||||
static int ath10k_monitor_vdev_start(struct ath10k *ar, int vdev_id)
|
static int ath10k_monitor_vdev_start(struct ath10k *ar, int vdev_id)
|
||||||
{
|
{
|
||||||
struct cfg80211_chan_def *chandef = NULL;
|
struct cfg80211_chan_def *chandef = NULL;
|
||||||
@@ -1043,7 +1077,8 @@ static int ath10k_monitor_vdev_start(str
|
@@ -1038,7 +1072,8 @@ static int ath10k_monitor_vdev_start(str
|
||||||
arg.channel.min_power = 0;
|
arg.channel.min_power = 0;
|
||||||
arg.channel.max_power = channel->max_power * 2;
|
arg.channel.max_power = channel->max_power * 2;
|
||||||
arg.channel.max_reg_power = channel->max_reg_power * 2;
|
arg.channel.max_reg_power = channel->max_reg_power * 2;
|
||||||
@ -79,7 +79,7 @@ Forwarded: no
|
|||||||
|
|
||||||
reinit_completion(&ar->vdev_setup_done);
|
reinit_completion(&ar->vdev_setup_done);
|
||||||
reinit_completion(&ar->vdev_delete_done);
|
reinit_completion(&ar->vdev_delete_done);
|
||||||
@@ -1489,7 +1524,8 @@ static int ath10k_vdev_start_restart(str
|
@@ -1484,7 +1519,8 @@ static int ath10k_vdev_start_restart(str
|
||||||
arg.channel.min_power = 0;
|
arg.channel.min_power = 0;
|
||||||
arg.channel.max_power = chandef->chan->max_power * 2;
|
arg.channel.max_power = chandef->chan->max_power * 2;
|
||||||
arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
|
arg.channel.max_reg_power = chandef->chan->max_reg_power * 2;
|
||||||
@ -89,7 +89,7 @@ Forwarded: no
|
|||||||
|
|
||||||
if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
|
if (arvif->vdev_type == WMI_VDEV_TYPE_AP) {
|
||||||
arg.ssid = arvif->u.ap.ssid;
|
arg.ssid = arvif->u.ap.ssid;
|
||||||
@@ -3194,7 +3230,8 @@ static int ath10k_update_channel_list(st
|
@@ -3255,7 +3291,8 @@ static int ath10k_update_channel_list(st
|
||||||
ch->min_power = 0;
|
ch->min_power = 0;
|
||||||
ch->max_power = channel->max_power * 2;
|
ch->max_power = channel->max_power * 2;
|
||||||
ch->max_reg_power = channel->max_reg_power * 2;
|
ch->max_reg_power = channel->max_reg_power * 2;
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
static int modparam_bad_frames_preempt;
|
static int modparam_bad_frames_preempt;
|
||||||
module_param_named(bad_frames_preempt, modparam_bad_frames_preempt, int, 0444);
|
module_param_named(bad_frames_preempt, modparam_bad_frames_preempt, int, 0444);
|
||||||
MODULE_PARM_DESC(bad_frames_preempt,
|
MODULE_PARM_DESC(bad_frames_preempt,
|
||||||
@@ -2867,10 +2872,10 @@ static int b43_gpio_init(struct b43_wlde
|
@@ -2869,10 +2874,10 @@ static int b43_gpio_init(struct b43_wlde
|
||||||
u32 mask, set;
|
u32 mask, set;
|
||||||
|
|
||||||
b43_maskset32(dev, B43_MMIO_MACCTL, ~B43_MACCTL_GPOUTSMSK, 0);
|
b43_maskset32(dev, B43_MMIO_MACCTL, ~B43_MACCTL_GPOUTSMSK, 0);
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
b43-$(CPTCFG_B43_LEDS) += leds.o
|
b43-$(CPTCFG_B43_LEDS) += leds.o
|
||||||
--- a/drivers/net/wireless/broadcom/b43/main.c
|
--- a/drivers/net/wireless/broadcom/b43/main.c
|
||||||
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
||||||
@@ -2000,10 +2000,12 @@ static void b43_do_interrupt_thread(stru
|
@@ -2001,10 +2001,12 @@ static void b43_do_interrupt_thread(stru
|
||||||
dma_reason[0], dma_reason[1],
|
dma_reason[0], dma_reason[1],
|
||||||
dma_reason[2], dma_reason[3],
|
dma_reason[2], dma_reason[3],
|
||||||
dma_reason[4], dma_reason[5]);
|
dma_reason[4], dma_reason[5]);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/broadcom/b43/main.c
|
--- a/drivers/net/wireless/broadcom/b43/main.c
|
||||||
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
||||||
@@ -1642,7 +1642,7 @@ static void b43_write_beacon_template(st
|
@@ -1643,7 +1643,7 @@ static void b43_write_beacon_template(st
|
||||||
len, ram_offset, shm_size_offset, rate);
|
len, ram_offset, shm_size_offset, rate);
|
||||||
|
|
||||||
/* Write the PHY TX control parameters. */
|
/* Write the PHY TX control parameters. */
|
||||||
@ -9,7 +9,7 @@
|
|||||||
antenna = b43_antenna_to_phyctl(antenna);
|
antenna = b43_antenna_to_phyctl(antenna);
|
||||||
ctl = b43_shm_read16(dev, B43_SHM_SHARED, B43_SHM_SH_BEACPHYCTL);
|
ctl = b43_shm_read16(dev, B43_SHM_SHARED, B43_SHM_SH_BEACPHYCTL);
|
||||||
/* We can't send beacons with short preamble. Would get PHY errors. */
|
/* We can't send beacons with short preamble. Would get PHY errors. */
|
||||||
@@ -3282,8 +3282,8 @@ static int b43_chip_init(struct b43_wlde
|
@@ -3284,8 +3284,8 @@ static int b43_chip_init(struct b43_wlde
|
||||||
|
|
||||||
/* Select the antennae */
|
/* Select the antennae */
|
||||||
if (phy->ops->set_rx_antenna)
|
if (phy->ops->set_rx_antenna)
|
||||||
@ -20,7 +20,7 @@
|
|||||||
|
|
||||||
if (phy->type == B43_PHYTYPE_B) {
|
if (phy->type == B43_PHYTYPE_B) {
|
||||||
value16 = b43_read16(dev, 0x005E);
|
value16 = b43_read16(dev, 0x005E);
|
||||||
@@ -3983,7 +3983,6 @@ static int b43_op_config(struct ieee8021
|
@@ -3985,7 +3985,6 @@ static int b43_op_config(struct ieee8021
|
||||||
struct b43_wldev *dev = wl->current_dev;
|
struct b43_wldev *dev = wl->current_dev;
|
||||||
struct b43_phy *phy = &dev->phy;
|
struct b43_phy *phy = &dev->phy;
|
||||||
struct ieee80211_conf *conf = &hw->conf;
|
struct ieee80211_conf *conf = &hw->conf;
|
||||||
@ -28,7 +28,7 @@
|
|||||||
int err = 0;
|
int err = 0;
|
||||||
|
|
||||||
mutex_lock(&wl->mutex);
|
mutex_lock(&wl->mutex);
|
||||||
@@ -4026,11 +4025,9 @@ static int b43_op_config(struct ieee8021
|
@@ -4028,11 +4027,9 @@ static int b43_op_config(struct ieee8021
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Antennas for RX and management frame TX. */
|
/* Antennas for RX and management frame TX. */
|
||||||
@ -42,7 +42,7 @@
|
|||||||
|
|
||||||
if (wl->radio_enabled != phy->radio_on) {
|
if (wl->radio_enabled != phy->radio_on) {
|
||||||
if (wl->radio_enabled) {
|
if (wl->radio_enabled) {
|
||||||
@@ -5174,6 +5171,47 @@ static int b43_op_get_survey(struct ieee
|
@@ -5176,6 +5173,47 @@ static int b43_op_get_survey(struct ieee
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,7 +90,7 @@
|
|||||||
static const struct ieee80211_ops b43_hw_ops = {
|
static const struct ieee80211_ops b43_hw_ops = {
|
||||||
.tx = b43_op_tx,
|
.tx = b43_op_tx,
|
||||||
.conf_tx = b43_op_conf_tx,
|
.conf_tx = b43_op_conf_tx,
|
||||||
@@ -5195,6 +5233,8 @@ static const struct ieee80211_ops b43_hw
|
@@ -5197,6 +5235,8 @@ static const struct ieee80211_ops b43_hw
|
||||||
.sw_scan_complete = b43_op_sw_scan_complete_notifier,
|
.sw_scan_complete = b43_op_sw_scan_complete_notifier,
|
||||||
.get_survey = b43_op_get_survey,
|
.get_survey = b43_op_get_survey,
|
||||||
.rfkill_poll = b43_rfkill_poll,
|
.rfkill_poll = b43_rfkill_poll,
|
||||||
@ -99,7 +99,7 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* Hard-reset the chip. Do not call this directly.
|
/* Hard-reset the chip. Do not call this directly.
|
||||||
@@ -5496,6 +5536,8 @@ static int b43_one_core_attach(struct b4
|
@@ -5498,6 +5538,8 @@ static int b43_one_core_attach(struct b4
|
||||||
if (!wldev)
|
if (!wldev)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
@ -108,7 +108,7 @@
|
|||||||
wldev->use_pio = b43_modparam_pio;
|
wldev->use_pio = b43_modparam_pio;
|
||||||
wldev->dev = dev;
|
wldev->dev = dev;
|
||||||
wldev->wl = wl;
|
wldev->wl = wl;
|
||||||
@@ -5590,6 +5632,9 @@ static struct b43_wl *b43_wireless_init(
|
@@ -5592,6 +5634,9 @@ static struct b43_wl *b43_wireless_init(
|
||||||
|
|
||||||
wiphy_ext_feature_set(hw->wiphy, NL80211_EXT_FEATURE_CQM_RSSI_LIST);
|
wiphy_ext_feature_set(hw->wiphy, NL80211_EXT_FEATURE_CQM_RSSI_LIST);
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/broadcom/b43/main.c
|
--- a/drivers/net/wireless/broadcom/b43/main.c
|
||||||
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
||||||
@@ -2884,6 +2884,14 @@ static int b43_gpio_init(struct b43_wlde
|
@@ -2886,6 +2886,14 @@ static int b43_gpio_init(struct b43_wlde
|
||||||
} else if (dev->dev->chip_id == 0x5354) {
|
} else if (dev->dev->chip_id == 0x5354) {
|
||||||
/* Don't allow overtaking buttons GPIOs */
|
/* Don't allow overtaking buttons GPIOs */
|
||||||
set &= 0x2; /* 0x2 is LED GPIO on BCM5354 */
|
set &= 0x2; /* 0x2 is LED GPIO on BCM5354 */
|
||||||
|
@ -13,7 +13,7 @@ Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
||||||
@@ -1551,6 +1551,7 @@ int __init brcmf_core_init(void)
|
@@ -1557,6 +1557,7 @@ int __init brcmf_core_init(void)
|
||||||
{
|
{
|
||||||
if (!schedule_work(&brcmf_driver_work))
|
if (!schedule_work(&brcmf_driver_work))
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
|
@ -10,7 +10,7 @@ Signed-off-by: Rafał Miłecki <zajec5@gmail.com>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
@@ -714,8 +714,36 @@ static struct wireless_dev *brcmf_cfg802
|
@@ -715,8 +715,36 @@ static struct wireless_dev *brcmf_cfg802
|
||||||
struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
|
struct brcmf_cfg80211_info *cfg = wiphy_to_cfg(wiphy);
|
||||||
struct brcmf_pub *drvr = cfg->pub;
|
struct brcmf_pub *drvr = cfg->pub;
|
||||||
struct wireless_dev *wdev;
|
struct wireless_dev *wdev;
|
||||||
|
@ -14,7 +14,7 @@ Signed-off-by: Phil Elwell <phil@raspberrypi.org>
|
|||||||
|
|
||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
@@ -2955,6 +2955,10 @@ brcmf_cfg80211_set_power_mgmt(struct wip
|
@@ -2957,6 +2957,10 @@ brcmf_cfg80211_set_power_mgmt(struct wip
|
||||||
* preference in cfg struct to apply this to
|
* preference in cfg struct to apply this to
|
||||||
* FW later while initializing the dongle
|
* FW later while initializing the dongle
|
||||||
*/
|
*/
|
||||||
|
@ -49,7 +49,7 @@ Signed-off-by: Rafał Miłecki <rafal@milecki.pl>
|
|||||||
void brcmf_of_probe(struct device *dev, enum brcmf_bus_type bus_type,
|
void brcmf_of_probe(struct device *dev, enum brcmf_bus_type bus_type,
|
||||||
struct brcmf_mp_device *settings)
|
struct brcmf_mp_device *settings)
|
||||||
{
|
{
|
||||||
@@ -30,6 +60,8 @@ void brcmf_of_probe(struct device *dev,
|
@@ -43,6 +73,8 @@ void brcmf_of_probe(struct device *dev,
|
||||||
of_node_put(root);
|
of_node_put(root);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c
|
||||||
@@ -2907,6 +2907,63 @@ done:
|
@@ -2909,6 +2909,63 @@ done:
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -64,7 +64,7 @@
|
|||||||
brcmf_cfg80211_dump_station(struct wiphy *wiphy, struct net_device *ndev,
|
brcmf_cfg80211_dump_station(struct wiphy *wiphy, struct net_device *ndev,
|
||||||
int idx, u8 *mac, struct station_info *sinfo)
|
int idx, u8 *mac, struct station_info *sinfo)
|
||||||
{
|
{
|
||||||
@@ -3002,6 +3059,7 @@ static s32 brcmf_inform_single_bss(struc
|
@@ -3004,6 +3061,7 @@ static s32 brcmf_inform_single_bss(struc
|
||||||
struct brcmu_chan ch;
|
struct brcmu_chan ch;
|
||||||
u16 channel;
|
u16 channel;
|
||||||
u32 freq;
|
u32 freq;
|
||||||
@ -72,7 +72,7 @@
|
|||||||
u16 notify_capability;
|
u16 notify_capability;
|
||||||
u16 notify_interval;
|
u16 notify_interval;
|
||||||
u8 *notify_ie;
|
u8 *notify_ie;
|
||||||
@@ -3026,6 +3084,17 @@ static s32 brcmf_inform_single_bss(struc
|
@@ -3028,6 +3086,17 @@ static s32 brcmf_inform_single_bss(struc
|
||||||
band = NL80211_BAND_5GHZ;
|
band = NL80211_BAND_5GHZ;
|
||||||
|
|
||||||
freq = ieee80211_channel_to_frequency(channel, band);
|
freq = ieee80211_channel_to_frequency(channel, band);
|
||||||
@ -90,7 +90,7 @@
|
|||||||
bss_data.chan = ieee80211_get_channel(wiphy, freq);
|
bss_data.chan = ieee80211_get_channel(wiphy, freq);
|
||||||
bss_data.scan_width = NL80211_BSS_CHAN_WIDTH_20;
|
bss_data.scan_width = NL80211_BSS_CHAN_WIDTH_20;
|
||||||
bss_data.boottime_ns = ktime_to_ns(ktime_get_boottime());
|
bss_data.boottime_ns = ktime_to_ns(ktime_get_boottime());
|
||||||
@@ -5478,6 +5547,7 @@ static struct cfg80211_ops brcmf_cfg8021
|
@@ -5514,6 +5583,7 @@ static struct cfg80211_ops brcmf_cfg8021
|
||||||
.leave_ibss = brcmf_cfg80211_leave_ibss,
|
.leave_ibss = brcmf_cfg80211_leave_ibss,
|
||||||
.get_station = brcmf_cfg80211_get_station,
|
.get_station = brcmf_cfg80211_get_station,
|
||||||
.dump_station = brcmf_cfg80211_dump_station,
|
.dump_station = brcmf_cfg80211_dump_station,
|
||||||
@ -100,7 +100,7 @@
|
|||||||
.add_key = brcmf_cfg80211_add_key,
|
.add_key = brcmf_cfg80211_add_key,
|
||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c
|
||||||
@@ -1349,6 +1349,8 @@ int brcmf_attach(struct device *dev)
|
@@ -1356,6 +1356,8 @@ int brcmf_attach(struct device *dev)
|
||||||
|
|
||||||
/* Link to bus module */
|
/* Link to bus module */
|
||||||
drvr->hdrlen = 0;
|
drvr->hdrlen = 0;
|
||||||
@ -109,7 +109,7 @@
|
|||||||
|
|
||||||
/* Attach and link in the protocol */
|
/* Attach and link in the protocol */
|
||||||
ret = brcmf_proto_attach(drvr);
|
ret = brcmf_proto_attach(drvr);
|
||||||
@@ -1431,6 +1433,12 @@ void brcmf_detach(struct device *dev)
|
@@ -1438,6 +1440,12 @@ void brcmf_detach(struct device *dev)
|
||||||
if (drvr == NULL)
|
if (drvr == NULL)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -424,43 +424,6 @@ USB_SIERRA_NET=
|
@@ -437,43 +437,6 @@ USB_SIERRA_NET=
|
||||||
USB_VL600=
|
USB_VL600=
|
||||||
USB_NET_CH9200=
|
USB_NET_CH9200=
|
||||||
USB_NET_AQC111=
|
USB_NET_AQC111=
|
||||||
@ -90,7 +90,7 @@
|
|||||||
config B43_PHY_G
|
config B43_PHY_G
|
||||||
--- a/drivers/net/wireless/broadcom/b43/main.c
|
--- a/drivers/net/wireless/broadcom/b43/main.c
|
||||||
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
+++ b/drivers/net/wireless/broadcom/b43/main.c
|
||||||
@@ -2851,7 +2851,7 @@ static struct ssb_device *b43_ssb_gpio_d
|
@@ -2853,7 +2853,7 @@ static struct ssb_device *b43_ssb_gpio_d
|
||||||
{
|
{
|
||||||
struct ssb_bus *bus = dev->dev->sdev->bus;
|
struct ssb_bus *bus = dev->dev->sdev->bus;
|
||||||
|
|
||||||
@ -99,7 +99,7 @@
|
|||||||
return (bus->chipco.dev ? bus->chipco.dev : bus->pcicore.dev);
|
return (bus->chipco.dev ? bus->chipco.dev : bus->pcicore.dev);
|
||||||
#else
|
#else
|
||||||
return bus->chipco.dev;
|
return bus->chipco.dev;
|
||||||
@@ -4868,7 +4868,7 @@ static int b43_wireless_core_init(struct
|
@@ -4870,7 +4870,7 @@ static int b43_wireless_core_init(struct
|
||||||
}
|
}
|
||||||
if (sprom->boardflags_lo & B43_BFL_XTAL_NOSLOW)
|
if (sprom->boardflags_lo & B43_BFL_XTAL_NOSLOW)
|
||||||
hf |= B43_HF_DSCRQ; /* Disable slowclock requests from ucode. */
|
hf |= B43_HF_DSCRQ; /* Disable slowclock requests from ucode. */
|
||||||
@ -140,7 +140,7 @@
|
|||||||
# LED support
|
# LED support
|
||||||
--- a/drivers/net/wireless/broadcom/b43legacy/main.c
|
--- a/drivers/net/wireless/broadcom/b43legacy/main.c
|
||||||
+++ b/drivers/net/wireless/broadcom/b43legacy/main.c
|
+++ b/drivers/net/wireless/broadcom/b43legacy/main.c
|
||||||
@@ -1906,7 +1906,7 @@ static int b43legacy_gpio_init(struct b4
|
@@ -1907,7 +1907,7 @@ static int b43legacy_gpio_init(struct b4
|
||||||
if (dev->dev->id.revision >= 2)
|
if (dev->dev->id.revision >= 2)
|
||||||
mask |= 0x0010; /* FIXME: This is redundant. */
|
mask |= 0x0010; /* FIXME: This is redundant. */
|
||||||
|
|
||||||
@ -149,7 +149,7 @@
|
|||||||
pcidev = bus->pcicore.dev;
|
pcidev = bus->pcicore.dev;
|
||||||
#endif
|
#endif
|
||||||
gpiodev = bus->chipco.dev ? : pcidev;
|
gpiodev = bus->chipco.dev ? : pcidev;
|
||||||
@@ -1925,7 +1925,7 @@ static void b43legacy_gpio_cleanup(struc
|
@@ -1926,7 +1926,7 @@ static void b43legacy_gpio_cleanup(struc
|
||||||
struct ssb_bus *bus = dev->dev->bus;
|
struct ssb_bus *bus = dev->dev->bus;
|
||||||
struct ssb_device *gpiodev, *pcidev = NULL;
|
struct ssb_device *gpiodev, *pcidev = NULL;
|
||||||
|
|
||||||
@ -160,8 +160,8 @@
|
|||||||
gpiodev = bus->chipco.dev ? : pcidev;
|
gpiodev = bus->chipco.dev ? : pcidev;
|
||||||
--- a/drivers/net/wireless/broadcom/brcm80211/brcmsmac/led.h
|
--- a/drivers/net/wireless/broadcom/brcm80211/brcmsmac/led.h
|
||||||
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmsmac/led.h
|
+++ b/drivers/net/wireless/broadcom/brcm80211/brcmsmac/led.h
|
||||||
@@ -22,7 +22,7 @@ struct brcms_led {
|
@@ -24,7 +24,7 @@ struct brcms_led {
|
||||||
bool active_low;
|
struct gpio_desc *gpiod;
|
||||||
};
|
};
|
||||||
|
|
||||||
-#ifdef CPTCFG_BCMA_DRIVER_GPIO
|
-#ifdef CPTCFG_BCMA_DRIVER_GPIO
|
||||||
@ -192,7 +192,7 @@
|
|||||||
select BRCMUTIL
|
select BRCMUTIL
|
||||||
--- a/Kconfig.local
|
--- a/Kconfig.local
|
||||||
+++ b/Kconfig.local
|
+++ b/Kconfig.local
|
||||||
@@ -1276,117 +1276,6 @@ config BACKPORTED_USB_NET_CH9200
|
@@ -1315,117 +1315,6 @@ config BACKPORTED_USB_NET_CH9200
|
||||||
config BACKPORTED_USB_NET_AQC111
|
config BACKPORTED_USB_NET_AQC111
|
||||||
tristate
|
tristate
|
||||||
default USB_NET_AQC111
|
default USB_NET_AQC111
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/local-symbols
|
--- a/local-symbols
|
||||||
+++ b/local-symbols
|
+++ b/local-symbols
|
||||||
@@ -321,6 +321,7 @@ RT2X00_LIB_FIRMWARE=
|
@@ -333,6 +333,7 @@ RT2X00_LIB_FIRMWARE=
|
||||||
RT2X00_LIB_CRYPTO=
|
RT2X00_LIB_CRYPTO=
|
||||||
RT2X00_LIB_LEDS=
|
RT2X00_LIB_LEDS=
|
||||||
RT2X00_LIB_DEBUGFS=
|
RT2X00_LIB_DEBUGFS=
|
||||||
@ -127,7 +127,7 @@
|
|||||||
DECLARE_KFIFO_PTR(txstatus_fifo, u32);
|
DECLARE_KFIFO_PTR(txstatus_fifo, u32);
|
||||||
--- a/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
--- a/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
||||||
+++ b/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
+++ b/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
||||||
@@ -1407,6 +1407,10 @@ int rt2x00lib_probe_dev(struct rt2x00_de
|
@@ -1406,6 +1406,10 @@ int rt2x00lib_probe_dev(struct rt2x00_de
|
||||||
INIT_DELAYED_WORK(&rt2x00dev->autowakeup_work, rt2x00lib_autowakeup);
|
INIT_DELAYED_WORK(&rt2x00dev->autowakeup_work, rt2x00lib_autowakeup);
|
||||||
INIT_WORK(&rt2x00dev->sleep_work, rt2x00lib_sleep);
|
INIT_WORK(&rt2x00dev->sleep_work, rt2x00lib_sleep);
|
||||||
|
|
||||||
@ -138,7 +138,7 @@
|
|||||||
/*
|
/*
|
||||||
* Let the driver probe the device to detect the capabilities.
|
* Let the driver probe the device to detect the capabilities.
|
||||||
*/
|
*/
|
||||||
@@ -1550,6 +1554,11 @@ void rt2x00lib_remove_dev(struct rt2x00_
|
@@ -1549,6 +1553,11 @@ void rt2x00lib_remove_dev(struct rt2x00_
|
||||||
* Free the driver data.
|
* Free the driver data.
|
||||||
*/
|
*/
|
||||||
kfree(rt2x00dev->drv_data);
|
kfree(rt2x00dev->drv_data);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
--- a/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
||||||
+++ b/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
+++ b/drivers/net/wireless/ralink/rt2x00/rt2x00dev.c
|
||||||
@@ -1345,7 +1345,7 @@ static inline void rt2x00lib_set_if_comb
|
@@ -1344,7 +1344,7 @@ static inline void rt2x00lib_set_if_comb
|
||||||
*/
|
*/
|
||||||
if_limit = &rt2x00dev->if_limits_ap;
|
if_limit = &rt2x00dev->if_limits_ap;
|
||||||
if_limit->max = rt2x00dev->ops->max_ap_intf;
|
if_limit->max = rt2x00dev->ops->max_ap_intf;
|
||||||
|
@ -31,7 +31,7 @@ Tested-by: Christoph Krapp <achterin@googlemail.com>
|
|||||||
static int rt2x00lib_probe_hw(struct rt2x00_dev *rt2x00dev)
|
static int rt2x00lib_probe_hw(struct rt2x00_dev *rt2x00dev)
|
||||||
{
|
{
|
||||||
struct hw_mode_spec *spec = &rt2x00dev->spec;
|
struct hw_mode_spec *spec = &rt2x00dev->spec;
|
||||||
@@ -1211,6 +1224,10 @@ static int rt2x00lib_probe_hw(struct rt2
|
@@ -1210,6 +1223,10 @@ static int rt2x00lib_probe_hw(struct rt2
|
||||||
|
|
||||||
#undef RT2X00_TASKLET_INIT
|
#undef RT2X00_TASKLET_INIT
|
||||||
|
|
||||||
|
@ -22,16 +22,15 @@
|
|||||||
- rfcsr = rt2800_rfcsr_read(rt2x00dev, 16);
|
- rfcsr = rt2800_rfcsr_read(rt2x00dev, 16);
|
||||||
- rt2x00_set_field8(&rfcsr, RFCSR16_SDM_MODE_MT7620, 0x80);
|
- rt2x00_set_field8(&rfcsr, RFCSR16_SDM_MODE_MT7620, 0x80);
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 16, rfcsr);
|
- rt2800_rfcsr_write(rt2x00dev, 16, rfcsr);
|
||||||
-
|
|
||||||
- rfcsr = rt2800_rfcsr_read(rt2x00dev, 21);
|
|
||||||
- rt2x00_set_field8(&rfcsr, RFCSR21_BIT8, 1);
|
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 21, rfcsr);
|
|
||||||
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
||||||
+ /* Default: XO=20MHz , SDM mode */
|
+ /* Default: XO=20MHz , SDM mode */
|
||||||
+ rfcsr = rt2800_rfcsr_read(rt2x00dev, 16);
|
+ rfcsr = rt2800_rfcsr_read(rt2x00dev, 16);
|
||||||
+ rt2x00_set_field8(&rfcsr, RFCSR16_SDM_MODE_MT7620, 0x80);
|
+ rt2x00_set_field8(&rfcsr, RFCSR16_SDM_MODE_MT7620, 0x80);
|
||||||
+ rt2800_rfcsr_write(rt2x00dev, 16, rfcsr);
|
+ rt2800_rfcsr_write(rt2x00dev, 16, rfcsr);
|
||||||
+
|
|
||||||
|
- rfcsr = rt2800_rfcsr_read(rt2x00dev, 21);
|
||||||
|
- rt2x00_set_field8(&rfcsr, RFCSR21_BIT8, 1);
|
||||||
|
- rt2800_rfcsr_write(rt2x00dev, 21, rfcsr);
|
||||||
+ rfcsr = rt2800_rfcsr_read(rt2x00dev, 21);
|
+ rfcsr = rt2800_rfcsr_read(rt2x00dev, 21);
|
||||||
+ rt2x00_set_field8(&rfcsr, RFCSR21_BIT8, 1);
|
+ rt2x00_set_field8(&rfcsr, RFCSR21_BIT8, 1);
|
||||||
+ rt2800_rfcsr_write(rt2x00dev, 21, rfcsr);
|
+ rt2800_rfcsr_write(rt2x00dev, 21, rfcsr);
|
||||||
@ -217,10 +216,6 @@
|
|||||||
- rt2800_rfcsr_write(rt2x00dev, 28, 0x61);
|
- rt2800_rfcsr_write(rt2x00dev, 28, 0x61);
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 29, 0xB5);
|
- rt2800_rfcsr_write(rt2x00dev, 29, 0xB5);
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 43, 0x02);
|
- rt2800_rfcsr_write(rt2x00dev, 43, 0x02);
|
||||||
-
|
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 28, 0x62);
|
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 29, 0xAD);
|
|
||||||
- rt2800_rfcsr_write(rt2x00dev, 39, 0x80);
|
|
||||||
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
||||||
+ rt2800_rfcsr_write(rt2x00dev, 11, 0x21);
|
+ rt2800_rfcsr_write(rt2x00dev, 11, 0x21);
|
||||||
+ if (rt2800_clk_is_20mhz(rt2x00dev))
|
+ if (rt2800_clk_is_20mhz(rt2x00dev))
|
||||||
@ -244,7 +239,10 @@
|
|||||||
+ rt2800_rfcsr_write(rt2x00dev, 29, 0xB5);
|
+ rt2800_rfcsr_write(rt2x00dev, 29, 0xB5);
|
||||||
+ rt2800_rfcsr_write(rt2x00dev, 43, 0x02);
|
+ rt2800_rfcsr_write(rt2x00dev, 43, 0x02);
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
|
- rt2800_rfcsr_write(rt2x00dev, 28, 0x62);
|
||||||
|
- rt2800_rfcsr_write(rt2x00dev, 29, 0xAD);
|
||||||
|
- rt2800_rfcsr_write(rt2x00dev, 39, 0x80);
|
||||||
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1 &&
|
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1 &&
|
||||||
+ rt2800_hw_get_chipeco(rt2x00dev) >= 2) {
|
+ rt2800_hw_get_chipeco(rt2x00dev) >= 2) {
|
||||||
+ rt2800_rfcsr_write(rt2x00dev, 28, 0x62);
|
+ rt2800_rfcsr_write(rt2x00dev, 28, 0x62);
|
||||||
@ -288,33 +286,6 @@
|
|||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xF7);
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xF7);
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 61, 0x09);
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 61, 0x09);
|
||||||
-
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x51);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x06);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 19, 0xA7);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 28, 0x2C);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x64);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 8, 0x51);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x36);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 11, 0x53);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x16);
|
|
||||||
-
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x6C);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 48, 0xFC);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 49, 0x1F);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 54, 0x27);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x66);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
|
||||||
-
|
|
||||||
- /* Initialize RF channel register for DRQFN */
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 43, 0xD3);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 44, 0xE3);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 45, 0xE5);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x28);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x68);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 56, 0xF7);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 58, 0x02);
|
|
||||||
- rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xC7);
|
|
||||||
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1) {
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x47);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x47);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x71);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x71);
|
||||||
@ -347,7 +318,16 @@
|
|||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xF7);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xF7);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 61, 0x09);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 61, 0x09);
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x51);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x06);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 19, 0xA7);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 28, 0x2C);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x64);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 8, 0x51);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x36);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 11, 0x53);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x16);
|
||||||
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1 &&
|
+ if (rt2800_hw_get_chipver(rt2x00dev) > 1 &&
|
||||||
+ rt2800_hw_get_chipeco(rt2x00dev) >= 2) {
|
+ rt2800_hw_get_chipeco(rt2x00dev) >= 2) {
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x51);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 10, 0x51);
|
||||||
@ -359,7 +339,13 @@
|
|||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x36);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 9, 0x36);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 11, 0x53);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 11, 0x53);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x16);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 14, 0x16);
|
||||||
+
|
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x6C);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 48, 0xFC);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 49, 0x1F);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 54, 0x27);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x66);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x6C);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x6C);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 48, 0xFC);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 48, 0xFC);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 49, 0x1F);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 49, 0x1F);
|
||||||
@ -367,7 +353,16 @@
|
|||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x66);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x66);
|
||||||
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
+ rt2800_rfcsr_write_chanreg(rt2x00dev, 59, 0x6B);
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
|
- /* Initialize RF channel register for DRQFN */
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 43, 0xD3);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 44, 0xE3);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 45, 0xE5);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 47, 0x28);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 55, 0x68);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 56, 0xF7);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 58, 0x02);
|
||||||
|
- rt2800_rfcsr_write_chanreg(rt2x00dev, 60, 0xC7);
|
||||||
+ if (rt2800_hw_get_chippkg(rt2x00dev) == 0 &&
|
+ if (rt2800_hw_get_chippkg(rt2x00dev) == 0 &&
|
||||||
+ rt2800_hw_get_chipver(rt2x00dev) == 1) {
|
+ rt2800_hw_get_chipver(rt2x00dev) == 1) {
|
||||||
+ /* Initialize RF channel register for DRQFN */
|
+ /* Initialize RF channel register for DRQFN */
|
||||||
|
@ -53,22 +53,20 @@
|
|||||||
- idle = rt2800_register_read(rt2x00dev, CH_IDLE_STA);
|
- idle = rt2800_register_read(rt2x00dev, CH_IDLE_STA);
|
||||||
- busy = rt2800_register_read(rt2x00dev, CH_BUSY_STA);
|
- busy = rt2800_register_read(rt2x00dev, CH_BUSY_STA);
|
||||||
- busy_ext = rt2800_register_read(rt2x00dev, CH_BUSY_STA_SEC);
|
- busy_ext = rt2800_register_read(rt2x00dev, CH_BUSY_STA_SEC);
|
||||||
-
|
+ survey->channel = &rt2x00dev->bands[band].channels[idx];
|
||||||
|
|
||||||
- if (idle || busy) {
|
- if (idle || busy) {
|
||||||
- survey->filled = SURVEY_INFO_TIME |
|
- survey->filled = SURVEY_INFO_TIME |
|
||||||
- SURVEY_INFO_TIME_BUSY |
|
- SURVEY_INFO_TIME_BUSY |
|
||||||
- SURVEY_INFO_TIME_EXT_BUSY;
|
- SURVEY_INFO_TIME_EXT_BUSY;
|
||||||
-
|
+ survey->filled = SURVEY_INFO_TIME |
|
||||||
|
+ SURVEY_INFO_TIME_BUSY |
|
||||||
|
+ SURVEY_INFO_TIME_EXT_BUSY;
|
||||||
|
|
||||||
- survey->time = (idle + busy) / 1000;
|
- survey->time = (idle + busy) / 1000;
|
||||||
- survey->time_busy = busy / 1000;
|
- survey->time_busy = busy / 1000;
|
||||||
- survey->time_ext_busy = busy_ext / 1000;
|
- survey->time_ext_busy = busy_ext / 1000;
|
||||||
- }
|
- }
|
||||||
+ survey->channel = &rt2x00dev->bands[band].channels[idx];
|
|
||||||
+
|
|
||||||
+ survey->filled = SURVEY_INFO_TIME |
|
|
||||||
+ SURVEY_INFO_TIME_BUSY |
|
|
||||||
+ SURVEY_INFO_TIME_EXT_BUSY;
|
|
||||||
+
|
|
||||||
+ survey->time = div_u64(chan_survey->time_idle + chan_survey->time_busy, 1000);
|
+ survey->time = div_u64(chan_survey->time_idle + chan_survey->time_busy, 1000);
|
||||||
+ survey->time_busy = div_u64(chan_survey->time_busy, 1000);
|
+ survey->time_busy = div_u64(chan_survey->time_busy, 1000);
|
||||||
+ survey->time_ext_busy = div_u64(chan_survey->time_ext_busy, 1000);
|
+ survey->time_ext_busy = div_u64(chan_survey->time_ext_busy, 1000);
|
||||||
|
@ -1,30 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 14 Aug 2020 16:13:45 +0200
|
|
||||||
Subject: [PATCH] backports: add netif_receive_skb_list
|
|
||||||
|
|
||||||
It will be needed by pending mac80211 changes
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/backport-include/linux/netdevice.h
|
|
||||||
+++ b/backport-include/linux/netdevice.h
|
|
||||||
@@ -372,6 +372,18 @@ static inline int _bp_netdev_upper_dev_l
|
|
||||||
macro_dispatcher(netdev_upper_dev_link, __VA_ARGS__)(__VA_ARGS__)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#if LINUX_VERSION_IS_LESS(4,19,0)
|
|
||||||
+static inline void netif_receive_skb_list(struct list_head *head)
|
|
||||||
+{
|
|
||||||
+ struct sk_buff *skb, *next;
|
|
||||||
+
|
|
||||||
+ list_for_each_entry_safe(skb, next, head, list) {
|
|
||||||
+ skb_list_del_init(skb);
|
|
||||||
+ netif_receive_skb(skb);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
#if LINUX_VERSION_IS_LESS(5,0,0)
|
|
||||||
static inline int backport_dev_open(struct net_device *dev, struct netlink_ext_ack *extack)
|
|
||||||
{
|
|
@ -1,24 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 14 Aug 2020 16:13:55 +0200
|
|
||||||
Subject: [PATCH] backports: add skb_list_del_init
|
|
||||||
|
|
||||||
It will be needed by pending mac80211 changes
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/backport-include/linux/skbuff.h
|
|
||||||
+++ b/backport-include/linux/skbuff.h
|
|
||||||
@@ -384,6 +384,12 @@ static inline void skb_mark_not_on_list(
|
|
||||||
{
|
|
||||||
skb->next = NULL;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+static inline void skb_list_del_init(struct sk_buff *skb)
|
|
||||||
+{
|
|
||||||
+ __list_del_entry(&skb->list);
|
|
||||||
+ skb_mark_not_on_list(skb);
|
|
||||||
+}
|
|
||||||
#endif /* 4.19.10 <= x < 4.20 */
|
|
||||||
#endif
|
|
||||||
|
|
@ -1,32 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 28 Sep 2020 08:35:28 +0200
|
|
||||||
Subject: [PATCH] backports: add sched_set_fifo_low
|
|
||||||
|
|
||||||
It is needed for mt76
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
create mode 100644 backport/backport-include/linux/sched.h
|
|
||||||
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/backport-include/linux/sched.h
|
|
||||||
@@ -0,0 +1,19 @@
|
|
||||||
+#ifndef __BACKPORT_LINUX_SCHED_H
|
|
||||||
+#define __BACKPORT_LINUX_SCHED_H
|
|
||||||
+
|
|
||||||
+#include_next <linux/sched.h>
|
|
||||||
+#include <linux/version.h>
|
|
||||||
+
|
|
||||||
+#if LINUX_VERSION_IS_LESS(5,9,0)
|
|
||||||
+#include <uapi/linux/sched/types.h>
|
|
||||||
+
|
|
||||||
+static inline void sched_set_fifo_low(struct task_struct *p)
|
|
||||||
+{
|
|
||||||
+ struct sched_param sparam = {.sched_priority = 1};
|
|
||||||
+
|
|
||||||
+ sched_setscheduler(p, SCHED_FIFO, &sparam);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+#endif
|
|
@ -1,35 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Wed, 11 Nov 2020 13:34:26 +0100
|
|
||||||
Subject: [PATCH] backports: backport tasklet_setup, from_tasklet
|
|
||||||
|
|
||||||
Backport the new tasklet API
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/backport-include/linux/interrupt.h
|
|
||||||
+++ b/backport-include/linux/interrupt.h
|
|
||||||
@@ -31,6 +31,23 @@ static inline void backport_hrtimer_star
|
|
||||||
hrtimer_start(timer, _time, mode);
|
|
||||||
}
|
|
||||||
#define hrtimer_start LINUX_BACKPORT(hrtimer_start)
|
|
||||||
+
|
|
||||||
+#endif
|
|
||||||
+
|
|
||||||
+#if LINUX_VERSION_IS_LESS(5,9,0)
|
|
||||||
+
|
|
||||||
+static inline void
|
|
||||||
+tasklet_setup(struct tasklet_struct *t,
|
|
||||||
+ void (*callback)(struct tasklet_struct *))
|
|
||||||
+{
|
|
||||||
+ void (*cb)(unsigned long data) = (void *)callback;
|
|
||||||
+
|
|
||||||
+ tasklet_init(t, cb, (unsigned long)t);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+#define from_tasklet(var, callback_tasklet, tasklet_fieldname) \
|
|
||||||
+ container_of(callback_tasklet, typeof(*var), tasklet_fieldname)
|
|
||||||
+
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* _BP_LINUX_INTERRUPT_H */
|
|
@ -8,7 +8,7 @@
|
|||||||
wpa.o \
|
wpa.o \
|
||||||
scan.o offchannel.o \
|
scan.o offchannel.o \
|
||||||
ht.o agg-tx.o agg-rx.o \
|
ht.o agg-tx.o agg-rx.o \
|
||||||
@@ -18,8 +17,8 @@ mac80211-y := \
|
@@ -19,8 +18,8 @@ mac80211-y := \
|
||||||
rate.o \
|
rate.o \
|
||||||
michael.o \
|
michael.o \
|
||||||
tkip.o \
|
tkip.o \
|
||||||
@ -64,7 +64,7 @@
|
|||||||
- aead_request_set_ad(aead_req, sg[0].length);
|
- aead_request_set_ad(aead_req, sg[0].length);
|
||||||
-
|
-
|
||||||
- crypto_aead_encrypt(aead_req);
|
- crypto_aead_encrypt(aead_req);
|
||||||
- kzfree(aead_req);
|
- kfree_sensitive(aead_req);
|
||||||
-
|
-
|
||||||
- return 0;
|
- return 0;
|
||||||
-}
|
-}
|
||||||
@ -99,7 +99,7 @@
|
|||||||
- aead_request_set_ad(aead_req, sg[0].length);
|
- aead_request_set_ad(aead_req, sg[0].length);
|
||||||
-
|
-
|
||||||
- err = crypto_aead_decrypt(aead_req);
|
- err = crypto_aead_decrypt(aead_req);
|
||||||
- kzfree(aead_req);
|
- kfree_sensitive(aead_req);
|
||||||
-
|
-
|
||||||
- return err;
|
- return err;
|
||||||
-}
|
-}
|
||||||
@ -166,8 +166,7 @@
|
|||||||
#define AES_CCM_H
|
#define AES_CCM_H
|
||||||
|
|
||||||
-#include "aead_api.h"
|
-#include "aead_api.h"
|
||||||
+#include <linux/crypto.h>
|
-
|
||||||
|
|
||||||
-#define CCM_AAD_LEN 32
|
-#define CCM_AAD_LEN 32
|
||||||
-
|
-
|
||||||
-static inline struct crypto_aead *
|
-static inline struct crypto_aead *
|
||||||
@ -195,7 +194,8 @@
|
|||||||
- be16_to_cpup((__be16 *)aad),
|
- be16_to_cpup((__be16 *)aad),
|
||||||
- data, data_len, mic);
|
- data, data_len, mic);
|
||||||
-}
|
-}
|
||||||
-
|
+#include <linux/crypto.h>
|
||||||
|
|
||||||
-static inline void ieee80211_aes_key_free(struct crypto_aead *tfm)
|
-static inline void ieee80211_aes_key_free(struct crypto_aead *tfm)
|
||||||
-{
|
-{
|
||||||
- return aead_key_free(tfm);
|
- return aead_key_free(tfm);
|
||||||
@ -331,10 +331,10 @@
|
|||||||
#define AES_GCM_H
|
#define AES_GCM_H
|
||||||
|
|
||||||
-#include "aead_api.h"
|
-#include "aead_api.h"
|
||||||
|
-
|
||||||
|
-#define GCM_AAD_LEN 32
|
||||||
+#include <linux/crypto.h>
|
+#include <linux/crypto.h>
|
||||||
|
|
||||||
-#define GCM_AAD_LEN 32
|
|
||||||
-
|
|
||||||
-static inline int ieee80211_aes_gcm_encrypt(struct crypto_aead *tfm,
|
-static inline int ieee80211_aes_gcm_encrypt(struct crypto_aead *tfm,
|
||||||
- u8 *j_0, u8 *aad, u8 *data,
|
- u8 *j_0, u8 *aad, u8 *data,
|
||||||
- size_t data_len, u8 *mic)
|
- size_t data_len, u8 *mic)
|
||||||
|
@ -2,7 +2,7 @@ Used for AP+STA support in OpenWrt - preserve AP mode keys across STA reconnects
|
|||||||
|
|
||||||
--- a/net/mac80211/cfg.c
|
--- a/net/mac80211/cfg.c
|
||||||
+++ b/net/mac80211/cfg.c
|
+++ b/net/mac80211/cfg.c
|
||||||
@@ -1198,7 +1198,6 @@ static int ieee80211_stop_ap(struct wiph
|
@@ -1288,7 +1288,6 @@ static int ieee80211_stop_ap(struct wiph
|
||||||
sdata->vif.bss_conf.ftmr_params = NULL;
|
sdata->vif.bss_conf.ftmr_params = NULL;
|
||||||
|
|
||||||
__sta_info_flush(sdata, true);
|
__sta_info_flush(sdata, true);
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
--- a/net/mac80211/cfg.c
|
--- a/net/mac80211/cfg.c
|
||||||
+++ b/net/mac80211/cfg.c
|
+++ b/net/mac80211/cfg.c
|
||||||
@@ -2346,7 +2346,7 @@ static int ieee80211_scan(struct wiphy *
|
@@ -2442,7 +2442,7 @@ static int ieee80211_scan(struct wiphy *
|
||||||
* the frames sent while scanning on other channel will be
|
* the frames sent while scanning on other channel will be
|
||||||
* lost)
|
* lost)
|
||||||
*/
|
*/
|
||||||
|
@ -1,201 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Sun, 17 Mar 2019 18:11:30 +0100
|
|
||||||
Subject: [PATCH] mac80211: optimize skb resizing
|
|
||||||
|
|
||||||
When forwarding unicast packets from ethernet to batman-adv over 802.11s
|
|
||||||
(with forwarding disabled), the typical required headroom to transmit
|
|
||||||
encrypted packets on mt76 is 32 (802.11) + 6 (802.11s) + 8 (CCMP) +
|
|
||||||
2 (padding) + 6 (LLC) + 18 (batman-adv) - 14 (old ethernet header) = 58 bytes.
|
|
||||||
|
|
||||||
On systems where NET_SKB_PAD is 64 this leads to a call to pskb_expand_head
|
|
||||||
for every packet, since mac80211 also tries to allocate 16 bytes status
|
|
||||||
headroom for radiotap headers.
|
|
||||||
|
|
||||||
This patch fixes these unnecessary reallocations by only requiring the extra
|
|
||||||
status headroom in ieee80211_tx_monitor()
|
|
||||||
If however a reallocation happens before that call, the status headroom gets
|
|
||||||
added there as well, in order to avoid double reallocation.
|
|
||||||
|
|
||||||
The patch also cleans up the code by moving the headroom calculation to
|
|
||||||
ieee80211_skb_resize.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/ieee80211_i.h
|
|
||||||
+++ b/net/mac80211/ieee80211_i.h
|
|
||||||
@@ -1809,6 +1809,9 @@ int ieee80211_tx_control_port(struct wip
|
|
||||||
u64 *cookie);
|
|
||||||
int ieee80211_probe_mesh_link(struct wiphy *wiphy, struct net_device *dev,
|
|
||||||
const u8 *buf, size_t len);
|
|
||||||
+int ieee80211_skb_resize(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata,
|
|
||||||
+ struct sk_buff *skb, int hdrlen, int hdr_add);
|
|
||||||
|
|
||||||
/* HT */
|
|
||||||
void ieee80211_apply_htcap_overrides(struct ieee80211_sub_if_data *sdata,
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -846,6 +846,11 @@ void ieee80211_tx_monitor(struct ieee802
|
|
||||||
struct net_device *prev_dev = NULL;
|
|
||||||
int rtap_len;
|
|
||||||
|
|
||||||
+ if (ieee80211_skb_resize(local, NULL, skb, 0, 0)) {
|
|
||||||
+ dev_kfree_skb(skb);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
/* send frame to monitor interfaces now */
|
|
||||||
rtap_len = ieee80211_tx_radiotap_len(info, status);
|
|
||||||
if (WARN_ON_ONCE(skb_headroom(skb) < rtap_len)) {
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -1937,37 +1937,53 @@ static bool ieee80211_tx(struct ieee8021
|
|
||||||
}
|
|
||||||
|
|
||||||
/* device xmit handlers */
|
|
||||||
-
|
|
||||||
-static int ieee80211_skb_resize(struct ieee80211_sub_if_data *sdata,
|
|
||||||
- struct sk_buff *skb,
|
|
||||||
- int head_need, bool may_encrypt)
|
|
||||||
+int ieee80211_skb_resize(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata,
|
|
||||||
+ struct sk_buff *skb, int hdr_len, int hdr_extra)
|
|
||||||
{
|
|
||||||
- struct ieee80211_local *local = sdata->local;
|
|
||||||
+ struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
struct ieee80211_hdr *hdr;
|
|
||||||
- bool enc_tailroom;
|
|
||||||
- int tail_need = 0;
|
|
||||||
-
|
|
||||||
- hdr = (struct ieee80211_hdr *) skb->data;
|
|
||||||
- enc_tailroom = may_encrypt &&
|
|
||||||
- (sdata->crypto_tx_tailroom_needed_cnt ||
|
|
||||||
- ieee80211_is_mgmt(hdr->frame_control));
|
|
||||||
-
|
|
||||||
- if (enc_tailroom) {
|
|
||||||
- tail_need = IEEE80211_ENCRYPT_TAILROOM;
|
|
||||||
- tail_need -= skb_tailroom(skb);
|
|
||||||
- tail_need = max_t(int, tail_need, 0);
|
|
||||||
+ int head_need, head_max;
|
|
||||||
+ int tail_need, tail_max;
|
|
||||||
+ bool enc_tailroom = false;
|
|
||||||
+
|
|
||||||
+ if (sdata && !hdr_len &&
|
|
||||||
+ !(info->flags & IEEE80211_TX_INTFL_DONT_ENCRYPT)) {
|
|
||||||
+ hdr = (struct ieee80211_hdr *) skb->data;
|
|
||||||
+ enc_tailroom = (sdata->crypto_tx_tailroom_needed_cnt ||
|
|
||||||
+ ieee80211_is_mgmt(hdr->frame_control));
|
|
||||||
+ hdr_len += sdata->encrypt_headroom;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ head_need = head_max = hdr_len;
|
|
||||||
+ tail_need = tail_max = 0;
|
|
||||||
+ if (!sdata) {
|
|
||||||
+ head_need = head_max = local->tx_headroom;
|
|
||||||
+ } else {
|
|
||||||
+ head_max += hdr_extra;
|
|
||||||
+ head_max += max_t(int, local->tx_headroom,
|
|
||||||
+ local->hw.extra_tx_headroom);
|
|
||||||
+ head_need += local->hw.extra_tx_headroom;
|
|
||||||
+
|
|
||||||
+ tail_max = IEEE80211_ENCRYPT_TAILROOM;
|
|
||||||
+ if (enc_tailroom)
|
|
||||||
+ tail_need = tail_max;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (skb_cloned(skb) &&
|
|
||||||
(!ieee80211_hw_check(&local->hw, SUPPORTS_CLONED_SKBS) ||
|
|
||||||
!skb_clone_writable(skb, ETH_HLEN) || enc_tailroom))
|
|
||||||
I802_DEBUG_INC(local->tx_expand_skb_head_cloned);
|
|
||||||
- else if (head_need || tail_need)
|
|
||||||
+ else if (head_need > skb_headroom(skb) ||
|
|
||||||
+ tail_need > skb_tailroom(skb))
|
|
||||||
I802_DEBUG_INC(local->tx_expand_skb_head);
|
|
||||||
else
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
- if (pskb_expand_head(skb, head_need, tail_need, GFP_ATOMIC)) {
|
|
||||||
+ head_max = max_t(int, 0, head_max - skb_headroom(skb));
|
|
||||||
+ tail_max = max_t(int, 0, tail_max - skb_tailroom(skb));
|
|
||||||
+
|
|
||||||
+ if (pskb_expand_head(skb, head_max, tail_max, GFP_ATOMIC)) {
|
|
||||||
wiphy_debug(local->hw.wiphy,
|
|
||||||
"failed to reallocate TX buffer\n");
|
|
||||||
return -ENOMEM;
|
|
||||||
@@ -1983,18 +1999,8 @@ void ieee80211_xmit(struct ieee80211_sub
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
struct ieee80211_hdr *hdr;
|
|
||||||
- int headroom;
|
|
||||||
- bool may_encrypt;
|
|
||||||
-
|
|
||||||
- may_encrypt = !(info->flags & IEEE80211_TX_INTFL_DONT_ENCRYPT);
|
|
||||||
|
|
||||||
- headroom = local->tx_headroom;
|
|
||||||
- if (may_encrypt)
|
|
||||||
- headroom += sdata->encrypt_headroom;
|
|
||||||
- headroom -= skb_headroom(skb);
|
|
||||||
- headroom = max_t(int, 0, headroom);
|
|
||||||
-
|
|
||||||
- if (ieee80211_skb_resize(sdata, skb, headroom, may_encrypt)) {
|
|
||||||
+ if (ieee80211_skb_resize(local, sdata, skb, 0, 0)) {
|
|
||||||
ieee80211_free_txskb(&local->hw, skb);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
@@ -2809,29 +2815,13 @@ static struct sk_buff *ieee80211_build_h
|
|
||||||
}
|
|
||||||
|
|
||||||
skb_pull(skb, skip_header_bytes);
|
|
||||||
- head_need = hdrlen + encaps_len + meshhdrlen - skb_headroom(skb);
|
|
||||||
+ head_need = hdrlen + encaps_len + meshhdrlen;
|
|
||||||
|
|
||||||
- /*
|
|
||||||
- * So we need to modify the skb header and hence need a copy of
|
|
||||||
- * that. The head_need variable above doesn't, so far, include
|
|
||||||
- * the needed header space that we don't need right away. If we
|
|
||||||
- * can, then we don't reallocate right now but only after the
|
|
||||||
- * frame arrives at the master device (if it does...)
|
|
||||||
- *
|
|
||||||
- * If we cannot, however, then we will reallocate to include all
|
|
||||||
- * the ever needed space. Also, if we need to reallocate it anyway,
|
|
||||||
- * make it big enough for everything we may ever need.
|
|
||||||
- */
|
|
||||||
-
|
|
||||||
- if (head_need > 0 || skb_cloned(skb)) {
|
|
||||||
- head_need += sdata->encrypt_headroom;
|
|
||||||
- head_need += local->tx_headroom;
|
|
||||||
- head_need = max_t(int, 0, head_need);
|
|
||||||
- if (ieee80211_skb_resize(sdata, skb, head_need, true)) {
|
|
||||||
- ieee80211_free_txskb(&local->hw, skb);
|
|
||||||
- skb = NULL;
|
|
||||||
- return ERR_PTR(-ENOMEM);
|
|
||||||
- }
|
|
||||||
+ if (ieee80211_skb_resize(local, sdata, skb, head_need,
|
|
||||||
+ sdata->encrypt_headroom)) {
|
|
||||||
+ ieee80211_free_txskb(&local->hw, skb);
|
|
||||||
+ skb = NULL;
|
|
||||||
+ return ERR_PTR(-ENOMEM);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (encaps_data)
|
|
||||||
@@ -3446,7 +3436,6 @@ static bool ieee80211_xmit_fast(struct i
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
u16 ethertype = (skb->data[12] << 8) | skb->data[13];
|
|
||||||
int extra_head = fast_tx->hdr_len - (ETH_HLEN - 2);
|
|
||||||
- int hw_headroom = sdata->local->hw.extra_tx_headroom;
|
|
||||||
struct ethhdr eth;
|
|
||||||
struct ieee80211_tx_info *info;
|
|
||||||
struct ieee80211_hdr *hdr = (void *)fast_tx->hdr;
|
|
||||||
@@ -3498,10 +3487,7 @@ static bool ieee80211_xmit_fast(struct i
|
|
||||||
* as the may-encrypt argument for the resize to not account for
|
|
||||||
* more room than we already have in 'extra_head'
|
|
||||||
*/
|
|
||||||
- if (unlikely(ieee80211_skb_resize(sdata, skb,
|
|
||||||
- max_t(int, extra_head + hw_headroom -
|
|
||||||
- skb_headroom(skb), 0),
|
|
||||||
- false))) {
|
|
||||||
+ if (unlikely(ieee80211_skb_resize(local, sdata, skb, extra_head, 0))) {
|
|
||||||
kfree_skb(skb);
|
|
||||||
return true;
|
|
||||||
}
|
|
@ -28,7 +28,7 @@ Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
|||||||
|
|
||||||
--- a/net/mac80211/sta_info.c
|
--- a/net/mac80211/sta_info.c
|
||||||
+++ b/net/mac80211/sta_info.c
|
+++ b/net/mac80211/sta_info.c
|
||||||
@@ -339,6 +339,7 @@ struct sta_info *sta_info_alloc(struct i
|
@@ -357,6 +357,7 @@ struct sta_info *sta_info_alloc(struct i
|
||||||
INIT_WORK(&sta->drv_deliver_wk, sta_deliver_ps_frames);
|
INIT_WORK(&sta->drv_deliver_wk, sta_deliver_ps_frames);
|
||||||
INIT_WORK(&sta->ampdu_mlme.work, ieee80211_ba_session_work);
|
INIT_WORK(&sta->ampdu_mlme.work, ieee80211_ba_session_work);
|
||||||
mutex_init(&sta->ampdu_mlme.mtx);
|
mutex_init(&sta->ampdu_mlme.mtx);
|
||||||
|
@ -1,81 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 24 Jul 2020 20:25:07 +0200
|
|
||||||
Subject: [PATCH] mac80211: improve AQL tx airtime estimation
|
|
||||||
|
|
||||||
AQL does not take into account that most HT/VHT/HE traffic is A-MPDU aggregated.
|
|
||||||
Because of that, the per-packet airtime overhead is vastly overestimated.
|
|
||||||
Improve it by assuming an average aggregation length of 16 for non-legacy
|
|
||||||
traffic if not using the VO AC queue.
|
|
||||||
This should improve performance with high data rates, especially with multiple
|
|
||||||
stations
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/airtime.c
|
|
||||||
+++ b/net/mac80211/airtime.c
|
|
||||||
@@ -551,7 +551,7 @@ EXPORT_SYMBOL_GPL(ieee80211_calc_tx_airt
|
|
||||||
u32 ieee80211_calc_expected_tx_airtime(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif,
|
|
||||||
struct ieee80211_sta *pubsta,
|
|
||||||
- int len)
|
|
||||||
+ int len, bool ampdu)
|
|
||||||
{
|
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
struct ieee80211_chanctx_conf *conf;
|
|
||||||
@@ -572,10 +572,26 @@ u32 ieee80211_calc_expected_tx_airtime(s
|
|
||||||
if (pubsta) {
|
|
||||||
struct sta_info *sta = container_of(pubsta, struct sta_info,
|
|
||||||
sta);
|
|
||||||
+ struct ieee80211_tx_rate *rate = &sta->tx_stats.last_rate;
|
|
||||||
+ u32 airtime;
|
|
||||||
|
|
||||||
- return ieee80211_calc_tx_airtime_rate(hw,
|
|
||||||
- &sta->tx_stats.last_rate,
|
|
||||||
- band, len);
|
|
||||||
+ if (!(rate->flags & (IEEE80211_TX_RC_VHT_MCS |
|
|
||||||
+ IEEE80211_TX_RC_MCS)))
|
|
||||||
+ ampdu = false;
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Assume that HT/VHT transmission on any AC except VO will
|
|
||||||
+ * use aggregation. Since we don't have reliable reporting
|
|
||||||
+ * of aggregation length, assume an average of 16.
|
|
||||||
+ * This will not be very accurate, but much better than simply
|
|
||||||
+ * assuming un-aggregated tx.
|
|
||||||
+ */
|
|
||||||
+ airtime = ieee80211_calc_tx_airtime_rate(hw, rate, band,
|
|
||||||
+ ampdu ? len * 16 : len);
|
|
||||||
+ if (ampdu)
|
|
||||||
+ airtime /= 16;
|
|
||||||
+
|
|
||||||
+ return airtime;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!conf)
|
|
||||||
--- a/net/mac80211/ieee80211_i.h
|
|
||||||
+++ b/net/mac80211/ieee80211_i.h
|
|
||||||
@@ -2294,7 +2294,7 @@ extern const struct ethtool_ops ieee8021
|
|
||||||
u32 ieee80211_calc_expected_tx_airtime(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif,
|
|
||||||
struct ieee80211_sta *pubsta,
|
|
||||||
- int len);
|
|
||||||
+ int len, bool ampdu);
|
|
||||||
#ifdef CPTCFG_MAC80211_NOINLINE
|
|
||||||
#define debug_noinline noinline
|
|
||||||
#else
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -3707,10 +3707,11 @@ encap_out:
|
|
||||||
|
|
||||||
if (vif &&
|
|
||||||
wiphy_ext_feature_isset(local->hw.wiphy, NL80211_EXT_FEATURE_AQL)) {
|
|
||||||
+ bool ampdu = txq->ac != IEEE80211_AC_VO;
|
|
||||||
u32 airtime;
|
|
||||||
|
|
||||||
airtime = ieee80211_calc_expected_tx_airtime(hw, vif, txq->sta,
|
|
||||||
- skb->len);
|
|
||||||
+ skb->len, ampdu);
|
|
||||||
if (airtime) {
|
|
||||||
airtime = ieee80211_info_set_tx_time_est(info, airtime);
|
|
||||||
ieee80211_sta_update_pending_airtime(local, tx.sta,
|
|
@ -1,186 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Sat, 25 Jul 2020 20:53:23 +0200
|
|
||||||
Subject: [PATCH] mac80211: add a function for running rx without passing skbs
|
|
||||||
to the stack
|
|
||||||
|
|
||||||
This can be used to run mac80211 rx processing on a batch of frames in NAPI
|
|
||||||
poll before passing them to the network stack in a large batch.
|
|
||||||
This can improve icache footprint, or it can be used to pass frames via
|
|
||||||
netif_receive_skb_list.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/include/net/mac80211.h
|
|
||||||
+++ b/include/net/mac80211.h
|
|
||||||
@@ -4358,6 +4358,31 @@ void ieee80211_free_hw(struct ieee80211_
|
|
||||||
void ieee80211_restart_hw(struct ieee80211_hw *hw);
|
|
||||||
|
|
||||||
/**
|
|
||||||
+ * ieee80211_rx_list - receive frame and store processed skbs in a list
|
|
||||||
+ *
|
|
||||||
+ * Use this function to hand received frames to mac80211. The receive
|
|
||||||
+ * buffer in @skb must start with an IEEE 802.11 header. In case of a
|
|
||||||
+ * paged @skb is used, the driver is recommended to put the ieee80211
|
|
||||||
+ * header of the frame on the linear part of the @skb to avoid memory
|
|
||||||
+ * allocation and/or memcpy by the stack.
|
|
||||||
+ *
|
|
||||||
+ * This function may not be called in IRQ context. Calls to this function
|
|
||||||
+ * for a single hardware must be synchronized against each other. Calls to
|
|
||||||
+ * this function, ieee80211_rx_ni() and ieee80211_rx_irqsafe() may not be
|
|
||||||
+ * mixed for a single hardware. Must not run concurrently with
|
|
||||||
+ * ieee80211_tx_status() or ieee80211_tx_status_ni().
|
|
||||||
+ *
|
|
||||||
+ * This function must be called with BHs disabled and RCU read lock
|
|
||||||
+ *
|
|
||||||
+ * @hw: the hardware this frame came in on
|
|
||||||
+ * @sta: the station the frame was received from, or %NULL
|
|
||||||
+ * @skb: the buffer to receive, owned by mac80211 after this call
|
|
||||||
+ * @list: the destination list
|
|
||||||
+ */
|
|
||||||
+void ieee80211_rx_list(struct ieee80211_hw *hw, struct ieee80211_sta *sta,
|
|
||||||
+ struct sk_buff *skb, struct list_head *list);
|
|
||||||
+
|
|
||||||
+/**
|
|
||||||
* ieee80211_rx_napi - receive frame from NAPI context
|
|
||||||
*
|
|
||||||
* Use this function to hand received frames to mac80211. The receive
|
|
||||||
--- a/net/mac80211/ieee80211_i.h
|
|
||||||
+++ b/net/mac80211/ieee80211_i.h
|
|
||||||
@@ -218,7 +218,7 @@ enum ieee80211_rx_flags {
|
|
||||||
};
|
|
||||||
|
|
||||||
struct ieee80211_rx_data {
|
|
||||||
- struct napi_struct *napi;
|
|
||||||
+ struct list_head *list;
|
|
||||||
struct sk_buff *skb;
|
|
||||||
struct ieee80211_local *local;
|
|
||||||
struct ieee80211_sub_if_data *sdata;
|
|
||||||
--- a/net/mac80211/rx.c
|
|
||||||
+++ b/net/mac80211/rx.c
|
|
||||||
@@ -2579,8 +2579,8 @@ static void ieee80211_deliver_skb_to_loc
|
|
||||||
memset(skb->cb, 0, sizeof(skb->cb));
|
|
||||||
|
|
||||||
/* deliver to local stack */
|
|
||||||
- if (rx->napi)
|
|
||||||
- napi_gro_receive(rx->napi, skb);
|
|
||||||
+ if (rx->list)
|
|
||||||
+ list_add_tail(&skb->list, rx->list);
|
|
||||||
else
|
|
||||||
netif_receive_skb(skb);
|
|
||||||
}
|
|
||||||
@@ -3870,7 +3870,6 @@ void ieee80211_release_reorder_timeout(s
|
|
||||||
/* This is OK -- must be QoS data frame */
|
|
||||||
.security_idx = tid,
|
|
||||||
.seqno_idx = tid,
|
|
||||||
- .napi = NULL, /* must be NULL to not have races */
|
|
||||||
};
|
|
||||||
struct tid_ampdu_rx *tid_agg_rx;
|
|
||||||
|
|
||||||
@@ -4480,8 +4479,8 @@ static bool ieee80211_invoke_fast_rx(str
|
|
||||||
/* deliver to local stack */
|
|
||||||
skb->protocol = eth_type_trans(skb, fast_rx->dev);
|
|
||||||
memset(skb->cb, 0, sizeof(skb->cb));
|
|
||||||
- if (rx->napi)
|
|
||||||
- napi_gro_receive(rx->napi, skb);
|
|
||||||
+ if (rx->list)
|
|
||||||
+ list_add_tail(&skb->list, rx->list);
|
|
||||||
else
|
|
||||||
netif_receive_skb(skb);
|
|
||||||
|
|
||||||
@@ -4548,7 +4547,7 @@ static bool ieee80211_prepare_and_rx_han
|
|
||||||
static void __ieee80211_rx_handle_packet(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_sta *pubsta,
|
|
||||||
struct sk_buff *skb,
|
|
||||||
- struct napi_struct *napi)
|
|
||||||
+ struct list_head *list)
|
|
||||||
{
|
|
||||||
struct ieee80211_local *local = hw_to_local(hw);
|
|
||||||
struct ieee80211_sub_if_data *sdata;
|
|
||||||
@@ -4563,7 +4562,7 @@ static void __ieee80211_rx_handle_packet
|
|
||||||
memset(&rx, 0, sizeof(rx));
|
|
||||||
rx.skb = skb;
|
|
||||||
rx.local = local;
|
|
||||||
- rx.napi = napi;
|
|
||||||
+ rx.list = list;
|
|
||||||
|
|
||||||
if (ieee80211_is_data(fc) || ieee80211_is_mgmt(fc))
|
|
||||||
I802_DEBUG_INC(local->dot11ReceivedFragmentCount);
|
|
||||||
@@ -4671,8 +4670,8 @@ static void __ieee80211_rx_handle_packet
|
|
||||||
* This is the receive path handler. It is called by a low level driver when an
|
|
||||||
* 802.11 MPDU is received from the hardware.
|
|
||||||
*/
|
|
||||||
-void ieee80211_rx_napi(struct ieee80211_hw *hw, struct ieee80211_sta *pubsta,
|
|
||||||
- struct sk_buff *skb, struct napi_struct *napi)
|
|
||||||
+void ieee80211_rx_list(struct ieee80211_hw *hw, struct ieee80211_sta *pubsta,
|
|
||||||
+ struct sk_buff *skb, struct list_head *list)
|
|
||||||
{
|
|
||||||
struct ieee80211_local *local = hw_to_local(hw);
|
|
||||||
struct ieee80211_rate *rate = NULL;
|
|
||||||
@@ -4764,36 +4763,53 @@ void ieee80211_rx_napi(struct ieee80211_
|
|
||||||
status->rx_flags = 0;
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * key references and virtual interfaces are protected using RCU
|
|
||||||
- * and this requires that we are in a read-side RCU section during
|
|
||||||
- * receive processing
|
|
||||||
- */
|
|
||||||
- rcu_read_lock();
|
|
||||||
-
|
|
||||||
- /*
|
|
||||||
* Frames with failed FCS/PLCP checksum are not returned,
|
|
||||||
* all other frames are returned without radiotap header
|
|
||||||
* if it was previously present.
|
|
||||||
* Also, frames with less than 16 bytes are dropped.
|
|
||||||
*/
|
|
||||||
skb = ieee80211_rx_monitor(local, skb, rate);
|
|
||||||
- if (!skb) {
|
|
||||||
- rcu_read_unlock();
|
|
||||||
+ if (!skb)
|
|
||||||
return;
|
|
||||||
- }
|
|
||||||
|
|
||||||
ieee80211_tpt_led_trig_rx(local,
|
|
||||||
((struct ieee80211_hdr *)skb->data)->frame_control,
|
|
||||||
skb->len);
|
|
||||||
|
|
||||||
- __ieee80211_rx_handle_packet(hw, pubsta, skb, napi);
|
|
||||||
-
|
|
||||||
- rcu_read_unlock();
|
|
||||||
+ __ieee80211_rx_handle_packet(hw, pubsta, skb, list);
|
|
||||||
|
|
||||||
return;
|
|
||||||
drop:
|
|
||||||
kfree_skb(skb);
|
|
||||||
}
|
|
||||||
+EXPORT_SYMBOL(ieee80211_rx_list);
|
|
||||||
+
|
|
||||||
+void ieee80211_rx_napi(struct ieee80211_hw *hw, struct ieee80211_sta *pubsta,
|
|
||||||
+ struct sk_buff *skb, struct napi_struct *napi)
|
|
||||||
+{
|
|
||||||
+ struct sk_buff *tmp;
|
|
||||||
+ LIST_HEAD(list);
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * key references and virtual interfaces are protected using RCU
|
|
||||||
+ * and this requires that we are in a read-side RCU section during
|
|
||||||
+ * receive processing
|
|
||||||
+ */
|
|
||||||
+ rcu_read_lock();
|
|
||||||
+ ieee80211_rx_list(hw, pubsta, skb, &list);
|
|
||||||
+ rcu_read_unlock();
|
|
||||||
+
|
|
||||||
+ if (!napi) {
|
|
||||||
+ netif_receive_skb_list(&list);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ list_for_each_entry_safe(skb, tmp, &list, list) {
|
|
||||||
+ skb_list_del_init(skb);
|
|
||||||
+ napi_gro_receive(napi, skb);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
EXPORT_SYMBOL(ieee80211_rx_napi);
|
|
||||||
|
|
||||||
/* This is a version of the rx handler that can be called from hard irq
|
|
@ -1,55 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Sun, 26 Jul 2020 14:37:02 +0200
|
|
||||||
Subject: [PATCH] net/fq_impl: use skb_get_hash instead of
|
|
||||||
skb_get_hash_perturb
|
|
||||||
|
|
||||||
This avoids unnecessary regenerating of the skb flow hash
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/include/net/fq.h
|
|
||||||
+++ b/include/net/fq.h
|
|
||||||
@@ -69,15 +69,6 @@ struct fq {
|
|
||||||
struct list_head backlogs;
|
|
||||||
spinlock_t lock;
|
|
||||||
u32 flows_cnt;
|
|
||||||
-#if LINUX_VERSION_IS_GEQ(5,3,10) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,19,83, 4,20,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,14,153, 4,15,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,9,200, 4,10,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,4,200, 4,5,0)
|
|
||||||
- siphash_key_t perturbation;
|
|
||||||
-#else
|
|
||||||
- u32 perturbation;
|
|
||||||
-#endif
|
|
||||||
u32 limit;
|
|
||||||
u32 memory_limit;
|
|
||||||
u32 memory_usage;
|
|
||||||
--- a/include/net/fq_impl.h
|
|
||||||
+++ b/include/net/fq_impl.h
|
|
||||||
@@ -108,15 +108,7 @@ begin:
|
|
||||||
|
|
||||||
static u32 fq_flow_idx(struct fq *fq, struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
-#if LINUX_VERSION_IS_GEQ(5,3,10) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,19,83, 4,20,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,14,153, 4,15,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,9,200, 4,10,0) || \
|
|
||||||
- LINUX_VERSION_IN_RANGE(4,4,200, 4,5,0)
|
|
||||||
- u32 hash = skb_get_hash_perturb(skb, &fq->perturbation);
|
|
||||||
-#else
|
|
||||||
- u32 hash = skb_get_hash_perturb(skb, fq->perturbation);
|
|
||||||
-#endif
|
|
||||||
+ u32 hash = skb_get_hash(skb);
|
|
||||||
|
|
||||||
return reciprocal_scale(hash, fq->flows_cnt);
|
|
||||||
}
|
|
||||||
@@ -316,7 +308,6 @@ static int fq_init(struct fq *fq, int fl
|
|
||||||
INIT_LIST_HEAD(&fq->backlogs);
|
|
||||||
spin_lock_init(&fq->lock);
|
|
||||||
fq->flows_cnt = max_t(u32, flows_cnt, 1);
|
|
||||||
- get_random_bytes(&fq->perturbation, sizeof(fq->perturbation));
|
|
||||||
fq->quantum = 300;
|
|
||||||
fq->limit = 8192;
|
|
||||||
fq->memory_limit = 16 << 20; /* 16 MBytes */
|
|
@ -1,19 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Sun, 26 Jul 2020 14:42:58 +0200
|
|
||||||
Subject: [PATCH] mac80211: calculcate skb hash early when using itxq
|
|
||||||
|
|
||||||
This avoids flow separation issues when using software encryption
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -3937,6 +3937,7 @@ void __ieee80211_subif_start_xmit(struct
|
|
||||||
if (local->ops->wake_tx_queue) {
|
|
||||||
u16 queue = __ieee80211_select_queue(sdata, sta, skb);
|
|
||||||
skb_set_queue_mapping(skb, queue);
|
|
||||||
+ skb_get_hash(skb);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sta) {
|
|
@ -0,0 +1,95 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 25 Nov 2020 18:03:46 +0100
|
||||||
|
Subject: [PATCH] net/fq_impl: bulk-free packets from a flow on overmemory
|
||||||
|
|
||||||
|
This is similar to what sch_fq_codel does. It also amortizes the worst
|
||||||
|
case cost of a follow-up patch that changes the selection of the biggest
|
||||||
|
flow for dropping packets
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/include/net/fq_impl.h
|
||||||
|
+++ b/include/net/fq_impl.h
|
||||||
|
@@ -11,17 +11,25 @@
|
||||||
|
|
||||||
|
/* functions that are embedded into includer */
|
||||||
|
|
||||||
|
+
|
||||||
|
+static void
|
||||||
|
+__fq_adjust_removal(struct fq *fq, struct fq_flow *flow, unsigned int packets,
|
||||||
|
+ unsigned int bytes, unsigned int truesize)
|
||||||
|
+{
|
||||||
|
+ struct fq_tin *tin = flow->tin;
|
||||||
|
+
|
||||||
|
+ tin->backlog_bytes -= bytes;
|
||||||
|
+ tin->backlog_packets -= packets;
|
||||||
|
+ flow->backlog -= bytes;
|
||||||
|
+ fq->backlog -= packets;
|
||||||
|
+ fq->memory_usage -= truesize;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static void fq_adjust_removal(struct fq *fq,
|
||||||
|
struct fq_flow *flow,
|
||||||
|
struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
- struct fq_tin *tin = flow->tin;
|
||||||
|
-
|
||||||
|
- tin->backlog_bytes -= skb->len;
|
||||||
|
- tin->backlog_packets--;
|
||||||
|
- flow->backlog -= skb->len;
|
||||||
|
- fq->backlog--;
|
||||||
|
- fq->memory_usage -= skb->truesize;
|
||||||
|
+ __fq_adjust_removal(fq, flow, 1, skb->len, skb->truesize);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fq_rejigger_backlog(struct fq *fq, struct fq_flow *flow)
|
||||||
|
@@ -59,6 +67,34 @@ static struct sk_buff *fq_flow_dequeue(s
|
||||||
|
return skb;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static int fq_flow_drop(struct fq *fq, struct fq_flow *flow,
|
||||||
|
+ fq_skb_free_t free_func)
|
||||||
|
+{
|
||||||
|
+ unsigned int packets = 0, bytes = 0, truesize = 0;
|
||||||
|
+ struct fq_tin *tin = flow->tin;
|
||||||
|
+ struct sk_buff *skb;
|
||||||
|
+ int pending;
|
||||||
|
+
|
||||||
|
+ lockdep_assert_held(&fq->lock);
|
||||||
|
+
|
||||||
|
+ pending = min_t(int, 32, skb_queue_len(&flow->queue) / 2);
|
||||||
|
+ do {
|
||||||
|
+ skb = __skb_dequeue(&flow->queue);
|
||||||
|
+ if (!skb)
|
||||||
|
+ break;
|
||||||
|
+
|
||||||
|
+ packets++;
|
||||||
|
+ bytes += skb->len;
|
||||||
|
+ truesize += skb->truesize;
|
||||||
|
+ free_func(fq, tin, flow, skb);
|
||||||
|
+ } while (packets < pending);
|
||||||
|
+
|
||||||
|
+ __fq_adjust_removal(fq, flow, packets, bytes, truesize);
|
||||||
|
+ fq_rejigger_backlog(fq, flow);
|
||||||
|
+
|
||||||
|
+ return packets;
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static struct sk_buff *fq_tin_dequeue(struct fq *fq,
|
||||||
|
struct fq_tin *tin,
|
||||||
|
fq_tin_dequeue_t dequeue_func)
|
||||||
|
@@ -190,12 +226,9 @@ static void fq_tin_enqueue(struct fq *fq
|
||||||
|
if (!flow)
|
||||||
|
return;
|
||||||
|
|
||||||
|
- skb = fq_flow_dequeue(fq, flow);
|
||||||
|
- if (!skb)
|
||||||
|
+ if (!fq_flow_drop(fq, flow, free_func))
|
||||||
|
return;
|
||||||
|
|
||||||
|
- free_func(fq, flow->tin, flow, skb);
|
||||||
|
-
|
||||||
|
flow->tin->overlimit++;
|
||||||
|
fq->overlimit++;
|
||||||
|
if (oom) {
|
@ -1,151 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Wed, 12 Aug 2020 17:04:22 +0200
|
|
||||||
Subject: [PATCH] mac80211: use rate provided via status->rate on
|
|
||||||
ieee80211_tx_status_ext for AQL
|
|
||||||
|
|
||||||
Since ieee80211_tx_info does not have enough room to encode HE rates, HE
|
|
||||||
drivers use status->rate to provide rate info.
|
|
||||||
Store it in struct sta_info and use it for AQL.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/airtime.c
|
|
||||||
+++ b/net/mac80211/airtime.c
|
|
||||||
@@ -487,14 +487,61 @@ u32 ieee80211_calc_rx_airtime(struct iee
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(ieee80211_calc_rx_airtime);
|
|
||||||
|
|
||||||
+static bool ieee80211_fill_rate_info(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_rx_status *stat, u8 band,
|
|
||||||
+ struct rate_info *ri)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_supported_band *sband = hw->wiphy->bands[band];
|
|
||||||
+ int i;
|
|
||||||
+
|
|
||||||
+ if (!ri || !sband)
|
|
||||||
+ return false;
|
|
||||||
+
|
|
||||||
+ stat->bw = ri->bw;
|
|
||||||
+ stat->nss = ri->nss;
|
|
||||||
+ stat->rate_idx = ri->mcs;
|
|
||||||
+
|
|
||||||
+ if (ri->flags & RATE_INFO_FLAGS_HE_MCS)
|
|
||||||
+ stat->encoding = RX_ENC_HE;
|
|
||||||
+ else if (ri->flags & RATE_INFO_FLAGS_VHT_MCS)
|
|
||||||
+ stat->encoding = RX_ENC_VHT;
|
|
||||||
+ else if (ri->flags & RATE_INFO_FLAGS_MCS)
|
|
||||||
+ stat->encoding = RX_ENC_HT;
|
|
||||||
+ else
|
|
||||||
+ stat->encoding = RX_ENC_LEGACY;
|
|
||||||
+
|
|
||||||
+ if (ri->flags & RATE_INFO_FLAGS_SHORT_GI)
|
|
||||||
+ stat->enc_flags |= RX_ENC_FLAG_SHORT_GI;
|
|
||||||
+
|
|
||||||
+ stat->he_gi = ri->he_gi;
|
|
||||||
+
|
|
||||||
+ if (stat->encoding != RX_ENC_LEGACY)
|
|
||||||
+ return true;
|
|
||||||
+
|
|
||||||
+ stat->rate_idx = 0;
|
|
||||||
+ for (i = 0; i < sband->n_bitrates; i++) {
|
|
||||||
+ if (ri->legacy != sband->bitrates[i].bitrate)
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ stat->rate_idx = i;
|
|
||||||
+ return true;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return false;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static u32 ieee80211_calc_tx_airtime_rate(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_tx_rate *rate,
|
|
||||||
+ struct rate_info *ri,
|
|
||||||
u8 band, int len)
|
|
||||||
{
|
|
||||||
struct ieee80211_rx_status stat = {
|
|
||||||
.band = band,
|
|
||||||
};
|
|
||||||
|
|
||||||
+ if (ieee80211_fill_rate_info(hw, &stat, band, ri))
|
|
||||||
+ goto out;
|
|
||||||
+
|
|
||||||
if (rate->idx < 0 || !rate->count)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
@@ -522,6 +569,7 @@ static u32 ieee80211_calc_tx_airtime_rat
|
|
||||||
stat.encoding = RX_ENC_LEGACY;
|
|
||||||
}
|
|
||||||
|
|
||||||
+out:
|
|
||||||
return ieee80211_calc_rx_airtime(hw, &stat, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -536,7 +584,7 @@ u32 ieee80211_calc_tx_airtime(struct iee
|
|
||||||
struct ieee80211_tx_rate *rate = &info->status.rates[i];
|
|
||||||
u32 cur_duration;
|
|
||||||
|
|
||||||
- cur_duration = ieee80211_calc_tx_airtime_rate(hw, rate,
|
|
||||||
+ cur_duration = ieee80211_calc_tx_airtime_rate(hw, rate, NULL,
|
|
||||||
info->band, len);
|
|
||||||
if (!cur_duration)
|
|
||||||
break;
|
|
||||||
@@ -573,6 +621,7 @@ u32 ieee80211_calc_expected_tx_airtime(s
|
|
||||||
struct sta_info *sta = container_of(pubsta, struct sta_info,
|
|
||||||
sta);
|
|
||||||
struct ieee80211_tx_rate *rate = &sta->tx_stats.last_rate;
|
|
||||||
+ struct rate_info *ri = &sta->tx_stats.last_rate_info;
|
|
||||||
u32 airtime;
|
|
||||||
|
|
||||||
if (!(rate->flags & (IEEE80211_TX_RC_VHT_MCS |
|
|
||||||
@@ -586,7 +635,7 @@ u32 ieee80211_calc_expected_tx_airtime(s
|
|
||||||
* This will not be very accurate, but much better than simply
|
|
||||||
* assuming un-aggregated tx.
|
|
||||||
*/
|
|
||||||
- airtime = ieee80211_calc_tx_airtime_rate(hw, rate, band,
|
|
||||||
+ airtime = ieee80211_calc_tx_airtime_rate(hw, rate, ri, band,
|
|
||||||
ampdu ? len * 16 : len);
|
|
||||||
if (ampdu)
|
|
||||||
airtime /= 16;
|
|
||||||
--- a/net/mac80211/sta_info.h
|
|
||||||
+++ b/net/mac80211/sta_info.h
|
|
||||||
@@ -609,6 +609,7 @@ struct sta_info {
|
|
||||||
u64 packets[IEEE80211_NUM_ACS];
|
|
||||||
u64 bytes[IEEE80211_NUM_ACS];
|
|
||||||
struct ieee80211_tx_rate last_rate;
|
|
||||||
+ struct rate_info last_rate_info;
|
|
||||||
u64 msdu[IEEE80211_NUM_TIDS + 1];
|
|
||||||
} tx_stats;
|
|
||||||
u16 tid_seq[IEEE80211_QOS_CTL_TID_MASK + 1];
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -1147,9 +1147,17 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
struct ieee80211_tx_info *info = status->info;
|
|
||||||
struct ieee80211_sta *pubsta = status->sta;
|
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
+ struct sta_info *sta;
|
|
||||||
int retry_count;
|
|
||||||
bool acked, noack_success;
|
|
||||||
|
|
||||||
+ if (pubsta) {
|
|
||||||
+ sta = container_of(pubsta, struct sta_info, sta);
|
|
||||||
+
|
|
||||||
+ if (status->rate)
|
|
||||||
+ sta->tx_stats.last_rate_info = *status->rate;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
if (status->skb)
|
|
||||||
return __ieee80211_tx_status(hw, status);
|
|
||||||
|
|
||||||
@@ -1164,10 +1172,6 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
noack_success = !!(info->flags & IEEE80211_TX_STAT_NOACK_TRANSMITTED);
|
|
||||||
|
|
||||||
if (pubsta) {
|
|
||||||
- struct sta_info *sta;
|
|
||||||
-
|
|
||||||
- sta = container_of(pubsta, struct sta_info, sta);
|
|
||||||
-
|
|
||||||
if (!acked && !noack_success)
|
|
||||||
sta->status_stats.retry_failed++;
|
|
||||||
sta->status_stats.retry_count += retry_count;
|
|
@ -0,0 +1,144 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 25 Nov 2020 18:09:10 +0100
|
||||||
|
Subject: [PATCH] net/fq_impl: drop get_default_func, move default flow to
|
||||||
|
fq_tin
|
||||||
|
|
||||||
|
Simplifies the code and prepares for a rework of scanning for flows on
|
||||||
|
overmemory drop.
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/include/net/fq.h
|
||||||
|
+++ b/include/net/fq.h
|
||||||
|
@@ -47,6 +47,7 @@ struct fq_flow {
|
||||||
|
struct fq_tin {
|
||||||
|
struct list_head new_flows;
|
||||||
|
struct list_head old_flows;
|
||||||
|
+ struct fq_flow default_flow;
|
||||||
|
u32 backlog_bytes;
|
||||||
|
u32 backlog_packets;
|
||||||
|
u32 overlimit;
|
||||||
|
--- a/include/net/fq_impl.h
|
||||||
|
+++ b/include/net/fq_impl.h
|
||||||
|
@@ -151,8 +151,7 @@ static u32 fq_flow_idx(struct fq *fq, st
|
||||||
|
|
||||||
|
static struct fq_flow *fq_flow_classify(struct fq *fq,
|
||||||
|
struct fq_tin *tin, u32 idx,
|
||||||
|
- struct sk_buff *skb,
|
||||||
|
- fq_flow_get_default_t get_default_func)
|
||||||
|
+ struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
struct fq_flow *flow;
|
||||||
|
|
||||||
|
@@ -160,7 +159,7 @@ static struct fq_flow *fq_flow_classify(
|
||||||
|
|
||||||
|
flow = &fq->flows[idx];
|
||||||
|
if (flow->tin && flow->tin != tin) {
|
||||||
|
- flow = get_default_func(fq, tin, idx, skb);
|
||||||
|
+ flow = &tin->default_flow;
|
||||||
|
tin->collisions++;
|
||||||
|
fq->collisions++;
|
||||||
|
}
|
||||||
|
@@ -192,15 +191,14 @@ static void fq_recalc_backlog(struct fq
|
||||||
|
static void fq_tin_enqueue(struct fq *fq,
|
||||||
|
struct fq_tin *tin, u32 idx,
|
||||||
|
struct sk_buff *skb,
|
||||||
|
- fq_skb_free_t free_func,
|
||||||
|
- fq_flow_get_default_t get_default_func)
|
||||||
|
+ fq_skb_free_t free_func)
|
||||||
|
{
|
||||||
|
struct fq_flow *flow;
|
||||||
|
bool oom;
|
||||||
|
|
||||||
|
lockdep_assert_held(&fq->lock);
|
||||||
|
|
||||||
|
- flow = fq_flow_classify(fq, tin, idx, skb, get_default_func);
|
||||||
|
+ flow = fq_flow_classify(fq, tin, idx, skb);
|
||||||
|
|
||||||
|
flow->tin = tin;
|
||||||
|
flow->backlog += skb->len;
|
||||||
|
@@ -331,6 +329,7 @@ static void fq_tin_init(struct fq_tin *t
|
||||||
|
{
|
||||||
|
INIT_LIST_HEAD(&tin->new_flows);
|
||||||
|
INIT_LIST_HEAD(&tin->old_flows);
|
||||||
|
+ fq_flow_init(&tin->default_flow);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int fq_init(struct fq *fq, int flows_cnt)
|
||||||
|
--- a/net/mac80211/ieee80211_i.h
|
||||||
|
+++ b/net/mac80211/ieee80211_i.h
|
||||||
|
@@ -855,7 +855,6 @@ enum txq_info_flags {
|
||||||
|
*/
|
||||||
|
struct txq_info {
|
||||||
|
struct fq_tin tin;
|
||||||
|
- struct fq_flow def_flow;
|
||||||
|
struct codel_vars def_cvars;
|
||||||
|
struct codel_stats cstats;
|
||||||
|
struct sk_buff_head frags;
|
||||||
|
--- a/net/mac80211/tx.c
|
||||||
|
+++ b/net/mac80211/tx.c
|
||||||
|
@@ -1322,7 +1322,7 @@ static struct sk_buff *codel_dequeue_fun
|
||||||
|
fq = &local->fq;
|
||||||
|
|
||||||
|
if (cvars == &txqi->def_cvars)
|
||||||
|
- flow = &txqi->def_flow;
|
||||||
|
+ flow = &txqi->tin.default_flow;
|
||||||
|
else
|
||||||
|
flow = &fq->flows[cvars - local->cvars];
|
||||||
|
|
||||||
|
@@ -1365,7 +1365,7 @@ static struct sk_buff *fq_tin_dequeue_fu
|
||||||
|
cparams = &local->cparams;
|
||||||
|
}
|
||||||
|
|
||||||
|
- if (flow == &txqi->def_flow)
|
||||||
|
+ if (flow == &tin->default_flow)
|
||||||
|
cvars = &txqi->def_cvars;
|
||||||
|
else
|
||||||
|
cvars = &local->cvars[flow - fq->flows];
|
||||||
|
@@ -1392,17 +1392,6 @@ static void fq_skb_free_func(struct fq *
|
||||||
|
ieee80211_free_txskb(&local->hw, skb);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static struct fq_flow *fq_flow_get_default_func(struct fq *fq,
|
||||||
|
- struct fq_tin *tin,
|
||||||
|
- int idx,
|
||||||
|
- struct sk_buff *skb)
|
||||||
|
-{
|
||||||
|
- struct txq_info *txqi;
|
||||||
|
-
|
||||||
|
- txqi = container_of(tin, struct txq_info, tin);
|
||||||
|
- return &txqi->def_flow;
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
static void ieee80211_txq_enqueue(struct ieee80211_local *local,
|
||||||
|
struct txq_info *txqi,
|
||||||
|
struct sk_buff *skb)
|
||||||
|
@@ -1415,8 +1404,7 @@ static void ieee80211_txq_enqueue(struct
|
||||||
|
|
||||||
|
spin_lock_bh(&fq->lock);
|
||||||
|
fq_tin_enqueue(fq, tin, flow_idx, skb,
|
||||||
|
- fq_skb_free_func,
|
||||||
|
- fq_flow_get_default_func);
|
||||||
|
+ fq_skb_free_func);
|
||||||
|
spin_unlock_bh(&fq->lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1459,7 +1447,6 @@ void ieee80211_txq_init(struct ieee80211
|
||||||
|
struct txq_info *txqi, int tid)
|
||||||
|
{
|
||||||
|
fq_tin_init(&txqi->tin);
|
||||||
|
- fq_flow_init(&txqi->def_flow);
|
||||||
|
codel_vars_init(&txqi->def_cvars);
|
||||||
|
codel_stats_init(&txqi->cstats);
|
||||||
|
__skb_queue_head_init(&txqi->frags);
|
||||||
|
@@ -3310,8 +3297,7 @@ static bool ieee80211_amsdu_aggregate(st
|
||||||
|
*/
|
||||||
|
|
||||||
|
tin = &txqi->tin;
|
||||||
|
- flow = fq_flow_classify(fq, tin, flow_idx, skb,
|
||||||
|
- fq_flow_get_default_func);
|
||||||
|
+ flow = fq_flow_classify(fq, tin, flow_idx, skb);
|
||||||
|
head = skb_peek_tail(&flow->queue);
|
||||||
|
if (!head || skb_is_gso(head))
|
||||||
|
goto out;
|
@ -1,187 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Wed, 12 Aug 2020 17:06:12 +0200
|
|
||||||
Subject: [PATCH] mac80211: factor out code to look up the average packet
|
|
||||||
length duration for a rate
|
|
||||||
|
|
||||||
This will be used to enhance AQL estimated aggregation length
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/airtime.c
|
|
||||||
+++ b/net/mac80211/airtime.c
|
|
||||||
@@ -405,18 +405,14 @@ ieee80211_calc_legacy_rate_duration(u16
|
|
||||||
return duration;
|
|
||||||
}
|
|
||||||
|
|
||||||
-u32 ieee80211_calc_rx_airtime(struct ieee80211_hw *hw,
|
|
||||||
- struct ieee80211_rx_status *status,
|
|
||||||
- int len)
|
|
||||||
+static u32 ieee80211_get_rate_duration(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_rx_status *status,
|
|
||||||
+ u32 *overhead)
|
|
||||||
{
|
|
||||||
- struct ieee80211_supported_band *sband;
|
|
||||||
- const struct ieee80211_rate *rate;
|
|
||||||
bool sgi = status->enc_flags & RX_ENC_FLAG_SHORT_GI;
|
|
||||||
- bool sp = status->enc_flags & RX_ENC_FLAG_SHORTPRE;
|
|
||||||
int bw, streams;
|
|
||||||
int group, idx;
|
|
||||||
u32 duration;
|
|
||||||
- bool cck;
|
|
||||||
|
|
||||||
switch (status->bw) {
|
|
||||||
case RATE_INFO_BW_20:
|
|
||||||
@@ -437,20 +433,6 @@ u32 ieee80211_calc_rx_airtime(struct iee
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (status->encoding) {
|
|
||||||
- case RX_ENC_LEGACY:
|
|
||||||
- if (WARN_ON_ONCE(status->band > NL80211_BAND_5GHZ))
|
|
||||||
- return 0;
|
|
||||||
-
|
|
||||||
- sband = hw->wiphy->bands[status->band];
|
|
||||||
- if (!sband || status->rate_idx >= sband->n_bitrates)
|
|
||||||
- return 0;
|
|
||||||
-
|
|
||||||
- rate = &sband->bitrates[status->rate_idx];
|
|
||||||
- cck = rate->flags & IEEE80211_RATE_MANDATORY_B;
|
|
||||||
-
|
|
||||||
- return ieee80211_calc_legacy_rate_duration(rate->bitrate, sp,
|
|
||||||
- cck, len);
|
|
||||||
-
|
|
||||||
case RX_ENC_VHT:
|
|
||||||
streams = status->nss;
|
|
||||||
idx = status->rate_idx;
|
|
||||||
@@ -477,13 +459,47 @@ u32 ieee80211_calc_rx_airtime(struct iee
|
|
||||||
|
|
||||||
duration = airtime_mcs_groups[group].duration[idx];
|
|
||||||
duration <<= airtime_mcs_groups[group].shift;
|
|
||||||
+ *overhead = 36 + (streams << 2);
|
|
||||||
+
|
|
||||||
+ return duration;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+u32 ieee80211_calc_rx_airtime(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_rx_status *status,
|
|
||||||
+ int len)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_supported_band *sband;
|
|
||||||
+ u32 duration, overhead = 0;
|
|
||||||
+
|
|
||||||
+ if (status->encoding == RX_ENC_LEGACY) {
|
|
||||||
+ const struct ieee80211_rate *rate;
|
|
||||||
+ bool sp = status->enc_flags & RX_ENC_FLAG_SHORTPRE;
|
|
||||||
+ bool cck;
|
|
||||||
+
|
|
||||||
+ if (WARN_ON_ONCE(status->band > NL80211_BAND_5GHZ))
|
|
||||||
+ return 0;
|
|
||||||
+
|
|
||||||
+ sband = hw->wiphy->bands[status->band];
|
|
||||||
+ if (!sband || status->rate_idx >= sband->n_bitrates)
|
|
||||||
+ return 0;
|
|
||||||
+
|
|
||||||
+ rate = &sband->bitrates[status->rate_idx];
|
|
||||||
+ cck = rate->flags & IEEE80211_RATE_MANDATORY_B;
|
|
||||||
+
|
|
||||||
+ return ieee80211_calc_legacy_rate_duration(rate->bitrate, sp,
|
|
||||||
+ cck, len);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ duration = ieee80211_get_rate_duration(hw, status, &overhead);
|
|
||||||
+ if (!duration)
|
|
||||||
+ return 0;
|
|
||||||
+
|
|
||||||
duration *= len;
|
|
||||||
duration /= AVG_PKT_SIZE;
|
|
||||||
duration /= 1024;
|
|
||||||
|
|
||||||
- duration += 36 + (streams << 2);
|
|
||||||
-
|
|
||||||
- return duration;
|
|
||||||
+ return duration + overhead;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(ieee80211_calc_rx_airtime);
|
|
||||||
|
|
||||||
@@ -530,46 +546,57 @@ static bool ieee80211_fill_rate_info(str
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
-static u32 ieee80211_calc_tx_airtime_rate(struct ieee80211_hw *hw,
|
|
||||||
- struct ieee80211_tx_rate *rate,
|
|
||||||
- struct rate_info *ri,
|
|
||||||
- u8 band, int len)
|
|
||||||
+static int ieee80211_fill_rx_status(struct ieee80211_rx_status *stat,
|
|
||||||
+ struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_tx_rate *rate,
|
|
||||||
+ struct rate_info *ri, u8 band, int len)
|
|
||||||
{
|
|
||||||
- struct ieee80211_rx_status stat = {
|
|
||||||
- .band = band,
|
|
||||||
- };
|
|
||||||
+ memset(stat, 0, sizeof(*stat));
|
|
||||||
+ stat->band = band;
|
|
||||||
|
|
||||||
- if (ieee80211_fill_rate_info(hw, &stat, band, ri))
|
|
||||||
- goto out;
|
|
||||||
+ if (ieee80211_fill_rate_info(hw, stat, band, ri))
|
|
||||||
+ return 0;
|
|
||||||
|
|
||||||
if (rate->idx < 0 || !rate->count)
|
|
||||||
- return 0;
|
|
||||||
+ return -1;
|
|
||||||
|
|
||||||
if (rate->flags & IEEE80211_TX_RC_80_MHZ_WIDTH)
|
|
||||||
- stat.bw = RATE_INFO_BW_80;
|
|
||||||
+ stat->bw = RATE_INFO_BW_80;
|
|
||||||
else if (rate->flags & IEEE80211_TX_RC_40_MHZ_WIDTH)
|
|
||||||
- stat.bw = RATE_INFO_BW_40;
|
|
||||||
+ stat->bw = RATE_INFO_BW_40;
|
|
||||||
else
|
|
||||||
- stat.bw = RATE_INFO_BW_20;
|
|
||||||
+ stat->bw = RATE_INFO_BW_20;
|
|
||||||
|
|
||||||
- stat.enc_flags = 0;
|
|
||||||
+ stat->enc_flags = 0;
|
|
||||||
if (rate->flags & IEEE80211_TX_RC_USE_SHORT_PREAMBLE)
|
|
||||||
- stat.enc_flags |= RX_ENC_FLAG_SHORTPRE;
|
|
||||||
+ stat->enc_flags |= RX_ENC_FLAG_SHORTPRE;
|
|
||||||
if (rate->flags & IEEE80211_TX_RC_SHORT_GI)
|
|
||||||
- stat.enc_flags |= RX_ENC_FLAG_SHORT_GI;
|
|
||||||
+ stat->enc_flags |= RX_ENC_FLAG_SHORT_GI;
|
|
||||||
|
|
||||||
- stat.rate_idx = rate->idx;
|
|
||||||
+ stat->rate_idx = rate->idx;
|
|
||||||
if (rate->flags & IEEE80211_TX_RC_VHT_MCS) {
|
|
||||||
- stat.encoding = RX_ENC_VHT;
|
|
||||||
- stat.rate_idx = ieee80211_rate_get_vht_mcs(rate);
|
|
||||||
- stat.nss = ieee80211_rate_get_vht_nss(rate);
|
|
||||||
+ stat->encoding = RX_ENC_VHT;
|
|
||||||
+ stat->rate_idx = ieee80211_rate_get_vht_mcs(rate);
|
|
||||||
+ stat->nss = ieee80211_rate_get_vht_nss(rate);
|
|
||||||
} else if (rate->flags & IEEE80211_TX_RC_MCS) {
|
|
||||||
- stat.encoding = RX_ENC_HT;
|
|
||||||
+ stat->encoding = RX_ENC_HT;
|
|
||||||
} else {
|
|
||||||
- stat.encoding = RX_ENC_LEGACY;
|
|
||||||
+ stat->encoding = RX_ENC_LEGACY;
|
|
||||||
}
|
|
||||||
|
|
||||||
-out:
|
|
||||||
+ return 0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+static u32 ieee80211_calc_tx_airtime_rate(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_tx_rate *rate,
|
|
||||||
+ struct rate_info *ri,
|
|
||||||
+ u8 band, int len)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_rx_status stat;
|
|
||||||
+
|
|
||||||
+ if (ieee80211_fill_rx_status(&stat, hw, rate, ri, band, len))
|
|
||||||
+ return 0;
|
|
||||||
+
|
|
||||||
return ieee80211_calc_rx_airtime(hw, &stat, len);
|
|
||||||
}
|
|
||||||
|
|
@ -0,0 +1,314 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 25 Nov 2020 18:10:34 +0100
|
||||||
|
Subject: [PATCH] net/fq_impl: do not maintain a backlog-sorted list of
|
||||||
|
flows
|
||||||
|
|
||||||
|
A sorted flow list is only needed to drop packets in the biggest flow when
|
||||||
|
hitting the overmemory condition.
|
||||||
|
By scanning flows only when needed, we can avoid paying the cost of
|
||||||
|
maintaining the list under normal conditions
|
||||||
|
In order to avoid scanning lots of empty flows and touching too many cold
|
||||||
|
cache lines, a bitmap of flows with backlog is maintained
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/include/net/fq.h
|
||||||
|
+++ b/include/net/fq.h
|
||||||
|
@@ -19,8 +19,6 @@ struct fq_tin;
|
||||||
|
* @flowchain: can be linked to fq_tin's new_flows or old_flows. Used for DRR++
|
||||||
|
* (deficit round robin) based round robin queuing similar to the one
|
||||||
|
* found in net/sched/sch_fq_codel.c
|
||||||
|
- * @backlogchain: can be linked to other fq_flow and fq. Used to keep track of
|
||||||
|
- * fat flows and efficient head-dropping if packet limit is reached
|
||||||
|
* @queue: sk_buff queue to hold packets
|
||||||
|
* @backlog: number of bytes pending in the queue. The number of packets can be
|
||||||
|
* found in @queue.qlen
|
||||||
|
@@ -29,7 +27,6 @@ struct fq_tin;
|
||||||
|
struct fq_flow {
|
||||||
|
struct fq_tin *tin;
|
||||||
|
struct list_head flowchain;
|
||||||
|
- struct list_head backlogchain;
|
||||||
|
struct sk_buff_head queue;
|
||||||
|
u32 backlog;
|
||||||
|
int deficit;
|
||||||
|
@@ -47,6 +44,7 @@ struct fq_flow {
|
||||||
|
struct fq_tin {
|
||||||
|
struct list_head new_flows;
|
||||||
|
struct list_head old_flows;
|
||||||
|
+ struct list_head tin_list;
|
||||||
|
struct fq_flow default_flow;
|
||||||
|
u32 backlog_bytes;
|
||||||
|
u32 backlog_packets;
|
||||||
|
@@ -60,14 +58,14 @@ struct fq_tin {
|
||||||
|
/**
|
||||||
|
* struct fq - main container for fair queuing purposes
|
||||||
|
*
|
||||||
|
- * @backlogs: linked to fq_flows. Used to maintain fat flows for efficient
|
||||||
|
- * head-dropping when @backlog reaches @limit
|
||||||
|
* @limit: max number of packets that can be queued across all flows
|
||||||
|
* @backlog: number of packets queued across all flows
|
||||||
|
*/
|
||||||
|
struct fq {
|
||||||
|
struct fq_flow *flows;
|
||||||
|
- struct list_head backlogs;
|
||||||
|
+ unsigned long *flows_bitmap;
|
||||||
|
+
|
||||||
|
+ struct list_head tin_backlog;
|
||||||
|
spinlock_t lock;
|
||||||
|
u32 flows_cnt;
|
||||||
|
u32 limit;
|
||||||
|
--- a/include/net/fq_impl.h
|
||||||
|
+++ b/include/net/fq_impl.h
|
||||||
|
@@ -17,12 +17,24 @@ __fq_adjust_removal(struct fq *fq, struc
|
||||||
|
unsigned int bytes, unsigned int truesize)
|
||||||
|
{
|
||||||
|
struct fq_tin *tin = flow->tin;
|
||||||
|
+ int idx;
|
||||||
|
|
||||||
|
tin->backlog_bytes -= bytes;
|
||||||
|
tin->backlog_packets -= packets;
|
||||||
|
flow->backlog -= bytes;
|
||||||
|
fq->backlog -= packets;
|
||||||
|
fq->memory_usage -= truesize;
|
||||||
|
+
|
||||||
|
+ if (flow->backlog)
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
+ if (flow == &tin->default_flow) {
|
||||||
|
+ list_del_init(&tin->tin_list);
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ idx = flow - fq->flows;
|
||||||
|
+ __clear_bit(idx, fq->flows_bitmap);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fq_adjust_removal(struct fq *fq,
|
||||||
|
@@ -32,24 +44,6 @@ static void fq_adjust_removal(struct fq
|
||||||
|
__fq_adjust_removal(fq, flow, 1, skb->len, skb->truesize);
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void fq_rejigger_backlog(struct fq *fq, struct fq_flow *flow)
|
||||||
|
-{
|
||||||
|
- struct fq_flow *i;
|
||||||
|
-
|
||||||
|
- if (flow->backlog == 0) {
|
||||||
|
- list_del_init(&flow->backlogchain);
|
||||||
|
- } else {
|
||||||
|
- i = flow;
|
||||||
|
-
|
||||||
|
- list_for_each_entry_continue(i, &fq->backlogs, backlogchain)
|
||||||
|
- if (i->backlog < flow->backlog)
|
||||||
|
- break;
|
||||||
|
-
|
||||||
|
- list_move_tail(&flow->backlogchain,
|
||||||
|
- &i->backlogchain);
|
||||||
|
- }
|
||||||
|
-}
|
||||||
|
-
|
||||||
|
static struct sk_buff *fq_flow_dequeue(struct fq *fq,
|
||||||
|
struct fq_flow *flow)
|
||||||
|
{
|
||||||
|
@@ -62,7 +56,6 @@ static struct sk_buff *fq_flow_dequeue(s
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
fq_adjust_removal(fq, flow, skb);
|
||||||
|
- fq_rejigger_backlog(fq, flow);
|
||||||
|
|
||||||
|
return skb;
|
||||||
|
}
|
||||||
|
@@ -90,7 +83,6 @@ static int fq_flow_drop(struct fq *fq, s
|
||||||
|
} while (packets < pending);
|
||||||
|
|
||||||
|
__fq_adjust_removal(fq, flow, packets, bytes, truesize);
|
||||||
|
- fq_rejigger_backlog(fq, flow);
|
||||||
|
|
||||||
|
return packets;
|
||||||
|
}
|
||||||
|
@@ -170,22 +162,36 @@ static struct fq_flow *fq_flow_classify(
|
||||||
|
return flow;
|
||||||
|
}
|
||||||
|
|
||||||
|
-static void fq_recalc_backlog(struct fq *fq,
|
||||||
|
- struct fq_tin *tin,
|
||||||
|
- struct fq_flow *flow)
|
||||||
|
+static struct fq_flow *fq_find_fattest_flow(struct fq *fq)
|
||||||
|
{
|
||||||
|
- struct fq_flow *i;
|
||||||
|
+ struct fq_tin *tin;
|
||||||
|
+ struct fq_flow *flow = NULL;
|
||||||
|
+ u32 len = 0;
|
||||||
|
+ int i;
|
||||||
|
|
||||||
|
- if (list_empty(&flow->backlogchain))
|
||||||
|
- list_add_tail(&flow->backlogchain, &fq->backlogs);
|
||||||
|
+ for_each_set_bit(i, fq->flows_bitmap, fq->flows_cnt) {
|
||||||
|
+ struct fq_flow *cur = &fq->flows[i];
|
||||||
|
+ unsigned int cur_len;
|
||||||
|
|
||||||
|
- i = flow;
|
||||||
|
- list_for_each_entry_continue_reverse(i, &fq->backlogs,
|
||||||
|
- backlogchain)
|
||||||
|
- if (i->backlog > flow->backlog)
|
||||||
|
- break;
|
||||||
|
+ cur_len = cur->backlog;
|
||||||
|
+ if (cur_len <= len)
|
||||||
|
+ continue;
|
||||||
|
|
||||||
|
- list_move(&flow->backlogchain, &i->backlogchain);
|
||||||
|
+ flow = cur;
|
||||||
|
+ len = cur_len;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ list_for_each_entry(tin, &fq->tin_backlog, tin_list) {
|
||||||
|
+ unsigned int cur_len = tin->default_flow.backlog;
|
||||||
|
+
|
||||||
|
+ if (cur_len <= len)
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
|
+ flow = &tin->default_flow;
|
||||||
|
+ len = cur_len;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ return flow;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fq_tin_enqueue(struct fq *fq,
|
||||||
|
@@ -200,6 +206,13 @@ static void fq_tin_enqueue(struct fq *fq
|
||||||
|
|
||||||
|
flow = fq_flow_classify(fq, tin, idx, skb);
|
||||||
|
|
||||||
|
+ if (!flow->backlog) {
|
||||||
|
+ if (flow != &tin->default_flow)
|
||||||
|
+ __set_bit(idx, fq->flows_bitmap);
|
||||||
|
+ else if (list_empty(&tin->tin_list))
|
||||||
|
+ list_add(&tin->tin_list, &fq->tin_backlog);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
flow->tin = tin;
|
||||||
|
flow->backlog += skb->len;
|
||||||
|
tin->backlog_bytes += skb->len;
|
||||||
|
@@ -207,8 +220,6 @@ static void fq_tin_enqueue(struct fq *fq
|
||||||
|
fq->memory_usage += skb->truesize;
|
||||||
|
fq->backlog++;
|
||||||
|
|
||||||
|
- fq_recalc_backlog(fq, tin, flow);
|
||||||
|
-
|
||||||
|
if (list_empty(&flow->flowchain)) {
|
||||||
|
flow->deficit = fq->quantum;
|
||||||
|
list_add_tail(&flow->flowchain,
|
||||||
|
@@ -218,9 +229,7 @@ static void fq_tin_enqueue(struct fq *fq
|
||||||
|
__skb_queue_tail(&flow->queue, skb);
|
||||||
|
oom = (fq->memory_usage > fq->memory_limit);
|
||||||
|
while (fq->backlog > fq->limit || oom) {
|
||||||
|
- flow = list_first_entry_or_null(&fq->backlogs,
|
||||||
|
- struct fq_flow,
|
||||||
|
- backlogchain);
|
||||||
|
+ flow = fq_find_fattest_flow(fq);
|
||||||
|
if (!flow)
|
||||||
|
return;
|
||||||
|
|
||||||
|
@@ -255,8 +264,6 @@ static void fq_flow_filter(struct fq *fq
|
||||||
|
fq_adjust_removal(fq, flow, skb);
|
||||||
|
free_func(fq, tin, flow, skb);
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- fq_rejigger_backlog(fq, flow);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void fq_tin_filter(struct fq *fq,
|
||||||
|
@@ -279,16 +286,18 @@ static void fq_flow_reset(struct fq *fq,
|
||||||
|
struct fq_flow *flow,
|
||||||
|
fq_skb_free_t free_func)
|
||||||
|
{
|
||||||
|
+ struct fq_tin *tin = flow->tin;
|
||||||
|
struct sk_buff *skb;
|
||||||
|
|
||||||
|
while ((skb = fq_flow_dequeue(fq, flow)))
|
||||||
|
- free_func(fq, flow->tin, flow, skb);
|
||||||
|
+ free_func(fq, tin, flow, skb);
|
||||||
|
|
||||||
|
- if (!list_empty(&flow->flowchain))
|
||||||
|
+ if (!list_empty(&flow->flowchain)) {
|
||||||
|
list_del_init(&flow->flowchain);
|
||||||
|
-
|
||||||
|
- if (!list_empty(&flow->backlogchain))
|
||||||
|
- list_del_init(&flow->backlogchain);
|
||||||
|
+ if (list_empty(&tin->new_flows) &&
|
||||||
|
+ list_empty(&tin->old_flows))
|
||||||
|
+ list_del_init(&tin->tin_list);
|
||||||
|
+ }
|
||||||
|
|
||||||
|
flow->tin = NULL;
|
||||||
|
|
||||||
|
@@ -314,6 +323,7 @@ static void fq_tin_reset(struct fq *fq,
|
||||||
|
fq_flow_reset(fq, flow, free_func);
|
||||||
|
}
|
||||||
|
|
||||||
|
+ WARN_ON_ONCE(!list_empty(&tin->tin_list));
|
||||||
|
WARN_ON_ONCE(tin->backlog_bytes);
|
||||||
|
WARN_ON_ONCE(tin->backlog_packets);
|
||||||
|
}
|
||||||
|
@@ -321,7 +331,6 @@ static void fq_tin_reset(struct fq *fq,
|
||||||
|
static void fq_flow_init(struct fq_flow *flow)
|
||||||
|
{
|
||||||
|
INIT_LIST_HEAD(&flow->flowchain);
|
||||||
|
- INIT_LIST_HEAD(&flow->backlogchain);
|
||||||
|
__skb_queue_head_init(&flow->queue);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -329,6 +338,7 @@ static void fq_tin_init(struct fq_tin *t
|
||||||
|
{
|
||||||
|
INIT_LIST_HEAD(&tin->new_flows);
|
||||||
|
INIT_LIST_HEAD(&tin->old_flows);
|
||||||
|
+ INIT_LIST_HEAD(&tin->tin_list);
|
||||||
|
fq_flow_init(&tin->default_flow);
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -337,8 +347,8 @@ static int fq_init(struct fq *fq, int fl
|
||||||
|
int i;
|
||||||
|
|
||||||
|
memset(fq, 0, sizeof(fq[0]));
|
||||||
|
- INIT_LIST_HEAD(&fq->backlogs);
|
||||||
|
spin_lock_init(&fq->lock);
|
||||||
|
+ INIT_LIST_HEAD(&fq->tin_backlog);
|
||||||
|
fq->flows_cnt = max_t(u32, flows_cnt, 1);
|
||||||
|
fq->quantum = 300;
|
||||||
|
fq->limit = 8192;
|
||||||
|
@@ -348,6 +358,14 @@ static int fq_init(struct fq *fq, int fl
|
||||||
|
if (!fq->flows)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
+ fq->flows_bitmap = kcalloc(BITS_TO_LONGS(fq->flows_cnt), sizeof(long),
|
||||||
|
+ GFP_KERNEL);
|
||||||
|
+ if (!fq->flows_bitmap) {
|
||||||
|
+ kvfree(fq->flows);
|
||||||
|
+ fq->flows = NULL;
|
||||||
|
+ return -ENOMEM;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
for (i = 0; i < fq->flows_cnt; i++)
|
||||||
|
fq_flow_init(&fq->flows[i]);
|
||||||
|
|
||||||
|
@@ -364,6 +382,9 @@ static void fq_reset(struct fq *fq,
|
||||||
|
|
||||||
|
kvfree(fq->flows);
|
||||||
|
fq->flows = NULL;
|
||||||
|
+
|
||||||
|
+ kfree(fq->flows_bitmap);
|
||||||
|
+ fq->flows_bitmap = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
--- a/net/mac80211/tx.c
|
||||||
|
+++ b/net/mac80211/tx.c
|
||||||
|
@@ -3364,8 +3364,6 @@ out_recalc:
|
||||||
|
if (head->len != orig_len) {
|
||||||
|
flow->backlog += head->len - orig_len;
|
||||||
|
tin->backlog_bytes += head->len - orig_len;
|
||||||
|
-
|
||||||
|
- fq_recalc_backlog(fq, tin, flow);
|
||||||
|
}
|
||||||
|
out:
|
||||||
|
spin_unlock_bh(&fq->lock);
|
@ -0,0 +1,53 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 16 Dec 2020 21:23:24 +0100
|
||||||
|
Subject: [PATCH] mac80211: fix encryption key selection for 802.3 xmit
|
||||||
|
|
||||||
|
When using WEP, the default unicast key needs to be selected, instead of
|
||||||
|
the STA PTK.
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/net/mac80211/tx.c
|
||||||
|
+++ b/net/mac80211/tx.c
|
||||||
|
@@ -4262,7 +4262,6 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
||||||
|
struct ethhdr *ehdr = (struct ethhdr *)skb->data;
|
||||||
|
struct ieee80211_key *key;
|
||||||
|
struct sta_info *sta;
|
||||||
|
- bool offload = true;
|
||||||
|
|
||||||
|
if (unlikely(skb->len < ETH_HLEN)) {
|
||||||
|
kfree_skb(skb);
|
||||||
|
@@ -4278,18 +4277,22 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
||||||
|
|
||||||
|
if (unlikely(IS_ERR_OR_NULL(sta) || !sta->uploaded ||
|
||||||
|
!test_sta_flag(sta, WLAN_STA_AUTHORIZED) ||
|
||||||
|
- sdata->control_port_protocol == ehdr->h_proto))
|
||||||
|
- offload = false;
|
||||||
|
- else if ((key = rcu_dereference(sta->ptk[sta->ptk_idx])) &&
|
||||||
|
- (!(key->flags & KEY_FLAG_UPLOADED_TO_HARDWARE) ||
|
||||||
|
- key->conf.cipher == WLAN_CIPHER_SUITE_TKIP))
|
||||||
|
- offload = false;
|
||||||
|
+ sdata->control_port_protocol == ehdr->h_proto))
|
||||||
|
+ goto skip_offload;
|
||||||
|
|
||||||
|
- if (offload)
|
||||||
|
- ieee80211_8023_xmit(sdata, dev, sta, key, skb);
|
||||||
|
- else
|
||||||
|
- ieee80211_subif_start_xmit(skb, dev);
|
||||||
|
+ key = rcu_dereference(sta->ptk[sta->ptk_idx]);
|
||||||
|
+ if (!key)
|
||||||
|
+ key = rcu_dereference(sdata->default_unicast_key);
|
||||||
|
+
|
||||||
|
+ if (key && (!(key->flags & KEY_FLAG_UPLOADED_TO_HARDWARE) ||
|
||||||
|
+ key->conf.cipher == WLAN_CIPHER_SUITE_TKIP))
|
||||||
|
+ goto skip_offload;
|
||||||
|
+
|
||||||
|
+ ieee80211_8023_xmit(sdata, dev, sta, key, skb);
|
||||||
|
+ goto out;
|
||||||
|
|
||||||
|
+skip_offload:
|
||||||
|
+ ieee80211_subif_start_xmit(skb, dev);
|
||||||
|
out:
|
||||||
|
rcu_read_unlock();
|
||||||
|
|
@ -1,67 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Wed, 12 Aug 2020 17:07:10 +0200
|
|
||||||
Subject: [PATCH] mac80211: improve AQL aggregation estimation for low data
|
|
||||||
rates
|
|
||||||
|
|
||||||
Links with low data rates use much smaller aggregates and are much more
|
|
||||||
sensitive to latency added by bufferbloat.
|
|
||||||
Tune the assumed aggregation length based on the tx rate duration.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/airtime.c
|
|
||||||
+++ b/net/mac80211/airtime.c
|
|
||||||
@@ -647,27 +647,41 @@ u32 ieee80211_calc_expected_tx_airtime(s
|
|
||||||
if (pubsta) {
|
|
||||||
struct sta_info *sta = container_of(pubsta, struct sta_info,
|
|
||||||
sta);
|
|
||||||
+ struct ieee80211_rx_status stat;
|
|
||||||
struct ieee80211_tx_rate *rate = &sta->tx_stats.last_rate;
|
|
||||||
struct rate_info *ri = &sta->tx_stats.last_rate_info;
|
|
||||||
- u32 airtime;
|
|
||||||
+ u32 duration, overhead;
|
|
||||||
+ u8 agg_shift;
|
|
||||||
|
|
||||||
- if (!(rate->flags & (IEEE80211_TX_RC_VHT_MCS |
|
|
||||||
- IEEE80211_TX_RC_MCS)))
|
|
||||||
- ampdu = false;
|
|
||||||
+ if (ieee80211_fill_rx_status(&stat, hw, rate, ri, band, len))
|
|
||||||
+ return 0;
|
|
||||||
|
|
||||||
+ if (stat.encoding == RX_ENC_LEGACY || !ampdu)
|
|
||||||
+ return ieee80211_calc_rx_airtime(hw, &stat, len);
|
|
||||||
+
|
|
||||||
+ duration = ieee80211_get_rate_duration(hw, &stat, &overhead);
|
|
||||||
/*
|
|
||||||
* Assume that HT/VHT transmission on any AC except VO will
|
|
||||||
* use aggregation. Since we don't have reliable reporting
|
|
||||||
- * of aggregation length, assume an average of 16.
|
|
||||||
+ * of aggregation length, assume an average size based on the
|
|
||||||
+ * tx rate.
|
|
||||||
* This will not be very accurate, but much better than simply
|
|
||||||
- * assuming un-aggregated tx.
|
|
||||||
+ * assuming un-aggregated tx in all cases.
|
|
||||||
*/
|
|
||||||
- airtime = ieee80211_calc_tx_airtime_rate(hw, rate, ri, band,
|
|
||||||
- ampdu ? len * 16 : len);
|
|
||||||
- if (ampdu)
|
|
||||||
- airtime /= 16;
|
|
||||||
+ if (duration > 400) /* <= VHT20 MCS2 1S */
|
|
||||||
+ agg_shift = 1;
|
|
||||||
+ else if (duration > 250) /* <= VHT20 MCS3 1S or MCS1 2S */
|
|
||||||
+ agg_shift = 2;
|
|
||||||
+ else if (duration > 150) /* <= VHT20 MCS5 1S or MCS3 2S */
|
|
||||||
+ agg_shift = 3;
|
|
||||||
+ else
|
|
||||||
+ agg_shift = 4;
|
|
||||||
+
|
|
||||||
+ duration *= len;
|
|
||||||
+ duration /= AVG_PKT_SIZE;
|
|
||||||
+ duration /= 1024;
|
|
||||||
|
|
||||||
- return airtime;
|
|
||||||
+ return duration + (overhead >> agg_shift);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!conf)
|
|
@ -1,25 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:55:56 +0200
|
|
||||||
Subject: [PATCH] mac80211: add missing queue/hash initialization to
|
|
||||||
802.3 xmit
|
|
||||||
|
|
||||||
Fixes AQL for encap-offloaded tx
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -4200,6 +4200,12 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
if (is_zero_ether_addr(ra))
|
|
||||||
goto out_free;
|
|
||||||
|
|
||||||
+ if (local->ops->wake_tx_queue) {
|
|
||||||
+ u16 queue = __ieee80211_select_queue(sdata, sta, skb);
|
|
||||||
+ skb_set_queue_mapping(skb, queue);
|
|
||||||
+ skb_get_hash(skb);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
multicast = is_multicast_ether_addr(ra);
|
|
||||||
|
|
||||||
if (sta)
|
|
@ -0,0 +1,21 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 16 Dec 2020 21:24:19 +0100
|
||||||
|
Subject: [PATCH] mac80211: fix fast-rx encryption check
|
||||||
|
|
||||||
|
When using WEP, the default unicast key needs to be selected, instead of
|
||||||
|
the STA PTK.
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/net/mac80211/rx.c
|
||||||
|
+++ b/net/mac80211/rx.c
|
||||||
|
@@ -4195,6 +4195,8 @@ void ieee80211_check_fast_rx(struct sta_
|
||||||
|
|
||||||
|
rcu_read_lock();
|
||||||
|
key = rcu_dereference(sta->ptk[sta->ptk_idx]);
|
||||||
|
+ if (!key)
|
||||||
|
+ key = rcu_dereference(sdata->default_unicast_key);
|
||||||
|
if (key) {
|
||||||
|
switch (key->conf.cipher) {
|
||||||
|
case WLAN_CIPHER_SUITE_TKIP:
|
@ -0,0 +1,570 @@
|
|||||||
|
From: Felix Fietkau <nbd@nbd.name>
|
||||||
|
Date: Wed, 16 Dec 2020 21:34:03 +0100
|
||||||
|
Subject: [PATCH] mac80211: add rx decapsulation offload support
|
||||||
|
|
||||||
|
This allows drivers to pass 802.3 frames to mac80211, with some restrictions:
|
||||||
|
|
||||||
|
- the skb must be passed with a valid sta
|
||||||
|
- fast-rx needs to be active for the sta
|
||||||
|
- monitor mode needs to be disabled
|
||||||
|
|
||||||
|
mac80211 will tell the driver when it is safe to enable rx decap offload for
|
||||||
|
a particular station.
|
||||||
|
|
||||||
|
In order to implement support, a driver must:
|
||||||
|
|
||||||
|
- call ieee80211_hw_set(hw, SUPPORTS_RX_DECAP_OFFLOAD)
|
||||||
|
- implement ops->sta_set_decap_offload
|
||||||
|
- mark 802.3 frames with RX_FLAG_8023
|
||||||
|
|
||||||
|
If it doesn't want to enable offload for some vif types, it can mask out
|
||||||
|
IEEE80211_OFFLOAD_DECAP_ENABLED in vif->offload_flags from within the
|
||||||
|
.add_interface or .update_vif_offload driver ops
|
||||||
|
|
||||||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/include/net/mac80211.h
|
||||||
|
+++ b/include/net/mac80211.h
|
||||||
|
@@ -1297,6 +1297,8 @@ ieee80211_tx_info_clear_status(struct ie
|
||||||
|
* the "0-length PSDU" field included there. The value for it is
|
||||||
|
* in &struct ieee80211_rx_status. Note that if this value isn't
|
||||||
|
* known the frame shouldn't be reported.
|
||||||
|
+ * @RX_FLAG_8023: the frame has an 802.3 header (decap offload performed by
|
||||||
|
+ * hardware or driver)
|
||||||
|
*/
|
||||||
|
enum mac80211_rx_flags {
|
||||||
|
RX_FLAG_MMIC_ERROR = BIT(0),
|
||||||
|
@@ -1329,6 +1331,7 @@ enum mac80211_rx_flags {
|
||||||
|
RX_FLAG_RADIOTAP_HE_MU = BIT(27),
|
||||||
|
RX_FLAG_RADIOTAP_LSIG = BIT(28),
|
||||||
|
RX_FLAG_NO_PSDU = BIT(29),
|
||||||
|
+ RX_FLAG_8023 = BIT(30),
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
@@ -1650,11 +1653,15 @@ enum ieee80211_vif_flags {
|
||||||
|
* The driver supports sending frames passed as 802.3 frames by mac80211.
|
||||||
|
* It must also support sending 802.11 packets for the same interface.
|
||||||
|
* @IEEE80211_OFFLOAD_ENCAP_4ADDR: support 4-address mode encapsulation offload
|
||||||
|
+ * @IEEE80211_OFFLOAD_DECAP_ENABLED: rx encapsulation offload is enabled
|
||||||
|
+ * The driver supports passing received 802.11 frames as 802.3 frames to
|
||||||
|
+ * mac80211.
|
||||||
|
*/
|
||||||
|
|
||||||
|
enum ieee80211_offload_flags {
|
||||||
|
IEEE80211_OFFLOAD_ENCAP_ENABLED = BIT(0),
|
||||||
|
IEEE80211_OFFLOAD_ENCAP_4ADDR = BIT(1),
|
||||||
|
+ IEEE80211_OFFLOAD_DECAP_ENABLED = BIT(2),
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
@@ -2390,6 +2397,9 @@ struct ieee80211_txq {
|
||||||
|
* @IEEE80211_HW_SUPPORTS_TX_ENCAP_OFFLOAD: Hardware supports tx encapsulation
|
||||||
|
* offload
|
||||||
|
*
|
||||||
|
+ * @IEEE80211_HW_SUPPORTS_RX_DECAP_OFFLOAD: Hardware supports rx decapsulation
|
||||||
|
+ * offload
|
||||||
|
+ *
|
||||||
|
* @NUM_IEEE80211_HW_FLAGS: number of hardware flags, used for sizing arrays
|
||||||
|
*/
|
||||||
|
enum ieee80211_hw_flags {
|
||||||
|
@@ -2443,6 +2453,7 @@ enum ieee80211_hw_flags {
|
||||||
|
IEEE80211_HW_SUPPORTS_ONLY_HE_MULTI_BSSID,
|
||||||
|
IEEE80211_HW_AMPDU_KEYBORDER_SUPPORT,
|
||||||
|
IEEE80211_HW_SUPPORTS_TX_ENCAP_OFFLOAD,
|
||||||
|
+ IEEE80211_HW_SUPPORTS_RX_DECAP_OFFLOAD,
|
||||||
|
|
||||||
|
/* keep last, obviously */
|
||||||
|
NUM_IEEE80211_HW_FLAGS
|
||||||
|
@@ -4196,6 +4207,9 @@ struct ieee80211_ops {
|
||||||
|
struct ieee80211_vif *vif);
|
||||||
|
void (*sta_set_4addr)(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
||||||
|
struct ieee80211_sta *sta, bool enabled);
|
||||||
|
+ void (*sta_set_decap_offload)(struct ieee80211_hw *hw,
|
||||||
|
+ struct ieee80211_vif *vif,
|
||||||
|
+ struct ieee80211_sta *sta, bool enabled);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
--- a/net/mac80211/debugfs.c
|
||||||
|
+++ b/net/mac80211/debugfs.c
|
||||||
|
@@ -409,6 +409,7 @@ static const char *hw_flag_names[] = {
|
||||||
|
FLAG(SUPPORTS_ONLY_HE_MULTI_BSSID),
|
||||||
|
FLAG(AMPDU_KEYBORDER_SUPPORT),
|
||||||
|
FLAG(SUPPORTS_TX_ENCAP_OFFLOAD),
|
||||||
|
+ FLAG(SUPPORTS_RX_DECAP_OFFLOAD),
|
||||||
|
#undef FLAG
|
||||||
|
};
|
||||||
|
|
||||||
|
--- a/net/mac80211/debugfs_sta.c
|
||||||
|
+++ b/net/mac80211/debugfs_sta.c
|
||||||
|
@@ -79,6 +79,7 @@ static const char * const sta_flag_names
|
||||||
|
FLAG(MPSP_RECIPIENT),
|
||||||
|
FLAG(PS_DELIVER),
|
||||||
|
FLAG(USES_ENCRYPTION),
|
||||||
|
+ FLAG(DECAP_OFFLOAD),
|
||||||
|
#undef FLAG
|
||||||
|
};
|
||||||
|
|
||||||
|
--- a/net/mac80211/driver-ops.h
|
||||||
|
+++ b/net/mac80211/driver-ops.h
|
||||||
|
@@ -1413,4 +1413,20 @@ static inline void drv_sta_set_4addr(str
|
||||||
|
trace_drv_return_void(local);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static inline void drv_sta_set_decap_offload(struct ieee80211_local *local,
|
||||||
|
+ struct ieee80211_sub_if_data *sdata,
|
||||||
|
+ struct ieee80211_sta *sta,
|
||||||
|
+ bool enabled)
|
||||||
|
+{
|
||||||
|
+ sdata = get_bss_sdata(sdata);
|
||||||
|
+ if (!check_sdata_in_driver(sdata))
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
+ trace_drv_sta_set_decap_offload(local, sdata, sta, enabled);
|
||||||
|
+ if (local->ops->sta_set_decap_offload)
|
||||||
|
+ local->ops->sta_set_decap_offload(&local->hw, &sdata->vif, sta,
|
||||||
|
+ enabled);
|
||||||
|
+ trace_drv_return_void(local);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
#endif /* __MAC80211_DRIVER_OPS */
|
||||||
|
--- a/net/mac80211/iface.c
|
||||||
|
+++ b/net/mac80211/iface.c
|
||||||
|
@@ -839,7 +839,7 @@ static const struct net_device_ops ieee8
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
-static bool ieee80211_iftype_supports_encap_offload(enum nl80211_iftype iftype)
|
||||||
|
+static bool ieee80211_iftype_supports_hdr_offload(enum nl80211_iftype iftype)
|
||||||
|
{
|
||||||
|
switch (iftype) {
|
||||||
|
/* P2P GO and client are mapped to AP/STATION types */
|
||||||
|
@@ -859,7 +859,7 @@ static bool ieee80211_set_sdata_offload_
|
||||||
|
flags = sdata->vif.offload_flags;
|
||||||
|
|
||||||
|
if (ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) &&
|
||||||
|
- ieee80211_iftype_supports_encap_offload(sdata->vif.type)) {
|
||||||
|
+ ieee80211_iftype_supports_hdr_offload(sdata->vif.type)) {
|
||||||
|
flags |= IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
||||||
|
|
||||||
|
if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_FRAG) &&
|
||||||
|
@@ -872,10 +872,21 @@ static bool ieee80211_set_sdata_offload_
|
||||||
|
flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
||||||
|
}
|
||||||
|
|
||||||
|
+ if (ieee80211_hw_check(&local->hw, SUPPORTS_RX_DECAP_OFFLOAD) &&
|
||||||
|
+ ieee80211_iftype_supports_hdr_offload(sdata->vif.type)) {
|
||||||
|
+ flags |= IEEE80211_OFFLOAD_DECAP_ENABLED;
|
||||||
|
+
|
||||||
|
+ if (local->monitors)
|
||||||
|
+ flags &= ~IEEE80211_OFFLOAD_DECAP_ENABLED;
|
||||||
|
+ } else {
|
||||||
|
+ flags &= ~IEEE80211_OFFLOAD_DECAP_ENABLED;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
if (sdata->vif.offload_flags == flags)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
sdata->vif.offload_flags = flags;
|
||||||
|
+ ieee80211_check_fast_rx_iface(sdata);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -893,7 +904,7 @@ static void ieee80211_set_vif_encap_ops(
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) ||
|
||||||
|
- !ieee80211_iftype_supports_encap_offload(bss->vif.type))
|
||||||
|
+ !ieee80211_iftype_supports_hdr_offload(bss->vif.type))
|
||||||
|
return;
|
||||||
|
|
||||||
|
enabled = bss->vif.offload_flags & IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
||||||
|
--- a/net/mac80211/rx.c
|
||||||
|
+++ b/net/mac80211/rx.c
|
||||||
|
@@ -4114,7 +4114,9 @@ void ieee80211_check_fast_rx(struct sta_
|
||||||
|
.vif_type = sdata->vif.type,
|
||||||
|
.control_port_protocol = sdata->control_port_protocol,
|
||||||
|
}, *old, *new = NULL;
|
||||||
|
+ bool set_offload = false;
|
||||||
|
bool assign = false;
|
||||||
|
+ bool offload;
|
||||||
|
|
||||||
|
/* use sparse to check that we don't return without updating */
|
||||||
|
__acquire(check_fast_rx);
|
||||||
|
@@ -4227,6 +4229,17 @@ void ieee80211_check_fast_rx(struct sta_
|
||||||
|
if (assign)
|
||||||
|
new = kmemdup(&fastrx, sizeof(fastrx), GFP_KERNEL);
|
||||||
|
|
||||||
|
+ offload = assign &&
|
||||||
|
+ (sdata->vif.offload_flags & IEEE80211_OFFLOAD_DECAP_ENABLED);
|
||||||
|
+
|
||||||
|
+ if (offload)
|
||||||
|
+ set_offload = !test_and_set_sta_flag(sta, WLAN_STA_DECAP_OFFLOAD);
|
||||||
|
+ else
|
||||||
|
+ set_offload = test_and_clear_sta_flag(sta, WLAN_STA_DECAP_OFFLOAD);
|
||||||
|
+
|
||||||
|
+ if (set_offload)
|
||||||
|
+ drv_sta_set_decap_offload(local, sdata, &sta->sta, assign);
|
||||||
|
+
|
||||||
|
spin_lock_bh(&sta->lock);
|
||||||
|
old = rcu_dereference_protected(sta->fast_rx, true);
|
||||||
|
rcu_assign_pointer(sta->fast_rx, new);
|
||||||
|
@@ -4273,6 +4286,108 @@ void ieee80211_check_fast_rx_iface(struc
|
||||||
|
mutex_unlock(&local->sta_mtx);
|
||||||
|
}
|
||||||
|
|
||||||
|
+static void ieee80211_rx_8023(struct ieee80211_rx_data *rx,
|
||||||
|
+ struct ieee80211_fast_rx *fast_rx,
|
||||||
|
+ int orig_len)
|
||||||
|
+{
|
||||||
|
+ struct ieee80211_sta_rx_stats *stats;
|
||||||
|
+ struct ieee80211_rx_status *status = IEEE80211_SKB_RXCB(rx->skb);
|
||||||
|
+ struct sta_info *sta = rx->sta;
|
||||||
|
+ struct sk_buff *skb = rx->skb;
|
||||||
|
+ void *sa = skb->data + ETH_ALEN;
|
||||||
|
+ void *da = skb->data;
|
||||||
|
+
|
||||||
|
+ stats = &sta->rx_stats;
|
||||||
|
+ if (fast_rx->uses_rss)
|
||||||
|
+ stats = this_cpu_ptr(sta->pcpu_rx_stats);
|
||||||
|
+
|
||||||
|
+ /* statistics part of ieee80211_rx_h_sta_process() */
|
||||||
|
+ if (!(status->flag & RX_FLAG_NO_SIGNAL_VAL)) {
|
||||||
|
+ stats->last_signal = status->signal;
|
||||||
|
+ if (!fast_rx->uses_rss)
|
||||||
|
+ ewma_signal_add(&sta->rx_stats_avg.signal,
|
||||||
|
+ -status->signal);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (status->chains) {
|
||||||
|
+ int i;
|
||||||
|
+
|
||||||
|
+ stats->chains = status->chains;
|
||||||
|
+ for (i = 0; i < ARRAY_SIZE(status->chain_signal); i++) {
|
||||||
|
+ int signal = status->chain_signal[i];
|
||||||
|
+
|
||||||
|
+ if (!(status->chains & BIT(i)))
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
|
+ stats->chain_signal_last[i] = signal;
|
||||||
|
+ if (!fast_rx->uses_rss)
|
||||||
|
+ ewma_signal_add(&sta->rx_stats_avg.chain_signal[i],
|
||||||
|
+ -signal);
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ /* end of statistics */
|
||||||
|
+
|
||||||
|
+ stats->last_rx = jiffies;
|
||||||
|
+ stats->last_rate = sta_stats_encode_rate(status);
|
||||||
|
+
|
||||||
|
+ stats->fragments++;
|
||||||
|
+ stats->packets++;
|
||||||
|
+
|
||||||
|
+ skb->dev = fast_rx->dev;
|
||||||
|
+
|
||||||
|
+ ieee80211_rx_stats(fast_rx->dev, skb->len);
|
||||||
|
+
|
||||||
|
+ /* The seqno index has the same property as needed
|
||||||
|
+ * for the rx_msdu field, i.e. it is IEEE80211_NUM_TIDS
|
||||||
|
+ * for non-QoS-data frames. Here we know it's a data
|
||||||
|
+ * frame, so count MSDUs.
|
||||||
|
+ */
|
||||||
|
+ u64_stats_update_begin(&stats->syncp);
|
||||||
|
+ stats->msdu[rx->seqno_idx]++;
|
||||||
|
+ stats->bytes += orig_len;
|
||||||
|
+ u64_stats_update_end(&stats->syncp);
|
||||||
|
+
|
||||||
|
+ if (fast_rx->internal_forward) {
|
||||||
|
+ struct sk_buff *xmit_skb = NULL;
|
||||||
|
+ if (is_multicast_ether_addr(da)) {
|
||||||
|
+ xmit_skb = skb_copy(skb, GFP_ATOMIC);
|
||||||
|
+ } else if (!ether_addr_equal(da, sa) &&
|
||||||
|
+ sta_info_get(rx->sdata, da)) {
|
||||||
|
+ xmit_skb = skb;
|
||||||
|
+ skb = NULL;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (xmit_skb) {
|
||||||
|
+ /*
|
||||||
|
+ * Send to wireless media and increase priority by 256
|
||||||
|
+ * to keep the received priority instead of
|
||||||
|
+ * reclassifying the frame (see cfg80211_classify8021d).
|
||||||
|
+ */
|
||||||
|
+ xmit_skb->priority += 256;
|
||||||
|
+ xmit_skb->protocol = htons(ETH_P_802_3);
|
||||||
|
+ skb_reset_network_header(xmit_skb);
|
||||||
|
+ skb_reset_mac_header(xmit_skb);
|
||||||
|
+ dev_queue_xmit(xmit_skb);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ if (!skb)
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ /* deliver to local stack */
|
||||||
|
+ skb->protocol = eth_type_trans(skb, fast_rx->dev);
|
||||||
|
+ memset(skb->cb, 0, sizeof(skb->cb));
|
||||||
|
+ if (rx->list)
|
||||||
|
+#if LINUX_VERSION_IS_GEQ(4,19,0)
|
||||||
|
+ list_add_tail(&skb->list, rx->list);
|
||||||
|
+#else
|
||||||
|
+ __skb_queue_tail(rx->list, skb);
|
||||||
|
+#endif
|
||||||
|
+ else
|
||||||
|
+ netif_receive_skb(skb);
|
||||||
|
+
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
static bool ieee80211_invoke_fast_rx(struct ieee80211_rx_data *rx,
|
||||||
|
struct ieee80211_fast_rx *fast_rx)
|
||||||
|
{
|
||||||
|
@@ -4293,9 +4408,6 @@ static bool ieee80211_invoke_fast_rx(str
|
||||||
|
} addrs __aligned(2);
|
||||||
|
struct ieee80211_sta_rx_stats *stats = &sta->rx_stats;
|
||||||
|
|
||||||
|
- if (fast_rx->uses_rss)
|
||||||
|
- stats = this_cpu_ptr(sta->pcpu_rx_stats);
|
||||||
|
-
|
||||||
|
/* for parallel-rx, we need to have DUP_VALIDATED, otherwise we write
|
||||||
|
* to a common data structure; drivers can implement that per queue
|
||||||
|
* but we don't have that information in mac80211
|
||||||
|
@@ -4369,32 +4481,6 @@ static bool ieee80211_invoke_fast_rx(str
|
||||||
|
pskb_trim(skb, skb->len - fast_rx->icv_len))
|
||||||
|
goto drop;
|
||||||
|
|
||||||
|
- /* statistics part of ieee80211_rx_h_sta_process() */
|
||||||
|
- if (!(status->flag & RX_FLAG_NO_SIGNAL_VAL)) {
|
||||||
|
- stats->last_signal = status->signal;
|
||||||
|
- if (!fast_rx->uses_rss)
|
||||||
|
- ewma_signal_add(&sta->rx_stats_avg.signal,
|
||||||
|
- -status->signal);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (status->chains) {
|
||||||
|
- int i;
|
||||||
|
-
|
||||||
|
- stats->chains = status->chains;
|
||||||
|
- for (i = 0; i < ARRAY_SIZE(status->chain_signal); i++) {
|
||||||
|
- int signal = status->chain_signal[i];
|
||||||
|
-
|
||||||
|
- if (!(status->chains & BIT(i)))
|
||||||
|
- continue;
|
||||||
|
-
|
||||||
|
- stats->chain_signal_last[i] = signal;
|
||||||
|
- if (!fast_rx->uses_rss)
|
||||||
|
- ewma_signal_add(&sta->rx_stats_avg.chain_signal[i],
|
||||||
|
- -signal);
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- /* end of statistics */
|
||||||
|
-
|
||||||
|
if (rx->key && !ieee80211_has_protected(hdr->frame_control))
|
||||||
|
goto drop;
|
||||||
|
|
||||||
|
@@ -4406,12 +4492,6 @@ static bool ieee80211_invoke_fast_rx(str
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
- stats->last_rx = jiffies;
|
||||||
|
- stats->last_rate = sta_stats_encode_rate(status);
|
||||||
|
-
|
||||||
|
- stats->fragments++;
|
||||||
|
- stats->packets++;
|
||||||
|
-
|
||||||
|
/* do the header conversion - first grab the addresses */
|
||||||
|
ether_addr_copy(addrs.da, skb->data + fast_rx->da_offs);
|
||||||
|
ether_addr_copy(addrs.sa, skb->data + fast_rx->sa_offs);
|
||||||
|
@@ -4420,62 +4500,14 @@ static bool ieee80211_invoke_fast_rx(str
|
||||||
|
/* push the addresses in front */
|
||||||
|
memcpy(skb_push(skb, sizeof(addrs)), &addrs, sizeof(addrs));
|
||||||
|
|
||||||
|
- skb->dev = fast_rx->dev;
|
||||||
|
-
|
||||||
|
- ieee80211_rx_stats(fast_rx->dev, skb->len);
|
||||||
|
-
|
||||||
|
- /* The seqno index has the same property as needed
|
||||||
|
- * for the rx_msdu field, i.e. it is IEEE80211_NUM_TIDS
|
||||||
|
- * for non-QoS-data frames. Here we know it's a data
|
||||||
|
- * frame, so count MSDUs.
|
||||||
|
- */
|
||||||
|
- u64_stats_update_begin(&stats->syncp);
|
||||||
|
- stats->msdu[rx->seqno_idx]++;
|
||||||
|
- stats->bytes += orig_len;
|
||||||
|
- u64_stats_update_end(&stats->syncp);
|
||||||
|
-
|
||||||
|
- if (fast_rx->internal_forward) {
|
||||||
|
- struct sk_buff *xmit_skb = NULL;
|
||||||
|
- if (is_multicast_ether_addr(addrs.da)) {
|
||||||
|
- xmit_skb = skb_copy(skb, GFP_ATOMIC);
|
||||||
|
- } else if (!ether_addr_equal(addrs.da, addrs.sa) &&
|
||||||
|
- sta_info_get(rx->sdata, addrs.da)) {
|
||||||
|
- xmit_skb = skb;
|
||||||
|
- skb = NULL;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (xmit_skb) {
|
||||||
|
- /*
|
||||||
|
- * Send to wireless media and increase priority by 256
|
||||||
|
- * to keep the received priority instead of
|
||||||
|
- * reclassifying the frame (see cfg80211_classify8021d).
|
||||||
|
- */
|
||||||
|
- xmit_skb->priority += 256;
|
||||||
|
- xmit_skb->protocol = htons(ETH_P_802_3);
|
||||||
|
- skb_reset_network_header(xmit_skb);
|
||||||
|
- skb_reset_mac_header(xmit_skb);
|
||||||
|
- dev_queue_xmit(xmit_skb);
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- if (!skb)
|
||||||
|
- return true;
|
||||||
|
- }
|
||||||
|
-
|
||||||
|
- /* deliver to local stack */
|
||||||
|
- skb->protocol = eth_type_trans(skb, fast_rx->dev);
|
||||||
|
- memset(skb->cb, 0, sizeof(skb->cb));
|
||||||
|
- if (rx->list)
|
||||||
|
-#if LINUX_VERSION_IS_GEQ(4,19,0)
|
||||||
|
- list_add_tail(&skb->list, rx->list);
|
||||||
|
-#else
|
||||||
|
- __skb_queue_tail(rx->list, skb);
|
||||||
|
-#endif
|
||||||
|
- else
|
||||||
|
- netif_receive_skb(skb);
|
||||||
|
+ ieee80211_rx_8023(rx, fast_rx, orig_len);
|
||||||
|
|
||||||
|
return true;
|
||||||
|
drop:
|
||||||
|
dev_kfree_skb(skb);
|
||||||
|
+ if (fast_rx->uses_rss)
|
||||||
|
+ stats = this_cpu_ptr(sta->pcpu_rx_stats);
|
||||||
|
+
|
||||||
|
stats->dropped++;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
@@ -4529,6 +4561,47 @@ static bool ieee80211_prepare_and_rx_han
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
+static void __ieee80211_rx_handle_8023(struct ieee80211_hw *hw,
|
||||||
|
+ struct ieee80211_sta *pubsta,
|
||||||
|
+ struct sk_buff *skb,
|
||||||
|
+#if LINUX_VERSION_IS_GEQ(4,19,0)
|
||||||
|
+ struct list_head *list)
|
||||||
|
+#else
|
||||||
|
+ struct sk_buff_head *list)
|
||||||
|
+#endif
|
||||||
|
+{
|
||||||
|
+ struct ieee80211_local *local = hw_to_local(hw);
|
||||||
|
+ struct ieee80211_fast_rx *fast_rx;
|
||||||
|
+ struct ieee80211_rx_data rx;
|
||||||
|
+
|
||||||
|
+ memset(&rx, 0, sizeof(rx));
|
||||||
|
+ rx.skb = skb;
|
||||||
|
+ rx.local = local;
|
||||||
|
+ rx.list = list;
|
||||||
|
+
|
||||||
|
+ I802_DEBUG_INC(local->dot11ReceivedFragmentCount);
|
||||||
|
+
|
||||||
|
+ /* drop frame if too short for header */
|
||||||
|
+ if (skb->len < sizeof(struct ethhdr))
|
||||||
|
+ goto drop;
|
||||||
|
+
|
||||||
|
+ if (!pubsta)
|
||||||
|
+ goto drop;
|
||||||
|
+
|
||||||
|
+ rx.sta = container_of(pubsta, struct sta_info, sta);
|
||||||
|
+ rx.sdata = rx.sta->sdata;
|
||||||
|
+
|
||||||
|
+ fast_rx = rcu_dereference(rx.sta->fast_rx);
|
||||||
|
+ if (!fast_rx)
|
||||||
|
+ goto drop;
|
||||||
|
+
|
||||||
|
+ ieee80211_rx_8023(&rx, fast_rx, skb->len);
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
+drop:
|
||||||
|
+ dev_kfree_skb(skb);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
/*
|
||||||
|
* This is the actual Rx frames handler. as it belongs to Rx path it must
|
||||||
|
* be called with rcu_read_lock protection.
|
||||||
|
@@ -4766,15 +4839,20 @@ void ieee80211_rx_list(struct ieee80211_
|
||||||
|
* if it was previously present.
|
||||||
|
* Also, frames with less than 16 bytes are dropped.
|
||||||
|
*/
|
||||||
|
- skb = ieee80211_rx_monitor(local, skb, rate);
|
||||||
|
- if (!skb)
|
||||||
|
- return;
|
||||||
|
+ if (!(status->flag & RX_FLAG_8023)) {
|
||||||
|
+ skb = ieee80211_rx_monitor(local, skb, rate);
|
||||||
|
+ if (!skb)
|
||||||
|
+ return;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
ieee80211_tpt_led_trig_rx(local,
|
||||||
|
((struct ieee80211_hdr *)skb->data)->frame_control,
|
||||||
|
skb->len);
|
||||||
|
|
||||||
|
- __ieee80211_rx_handle_packet(hw, pubsta, skb, list);
|
||||||
|
+ if (status->flag & RX_FLAG_8023)
|
||||||
|
+ __ieee80211_rx_handle_8023(hw, pubsta, skb, list);
|
||||||
|
+ else
|
||||||
|
+ __ieee80211_rx_handle_packet(hw, pubsta, skb, list);
|
||||||
|
|
||||||
|
return;
|
||||||
|
drop:
|
||||||
|
--- a/net/mac80211/sta_info.h
|
||||||
|
+++ b/net/mac80211/sta_info.h
|
||||||
|
@@ -71,6 +71,7 @@
|
||||||
|
* until pending frames are delivered
|
||||||
|
* @WLAN_STA_USES_ENCRYPTION: This station was configured for encryption,
|
||||||
|
* so drop all packets without a key later.
|
||||||
|
+ * @WLAN_STA_DECAP_OFFLOAD: This station uses rx decap offload
|
||||||
|
*
|
||||||
|
* @NUM_WLAN_STA_FLAGS: number of defined flags
|
||||||
|
*/
|
||||||
|
@@ -102,6 +103,7 @@ enum ieee80211_sta_info_flags {
|
||||||
|
WLAN_STA_MPSP_RECIPIENT,
|
||||||
|
WLAN_STA_PS_DELIVER,
|
||||||
|
WLAN_STA_USES_ENCRYPTION,
|
||||||
|
+ WLAN_STA_DECAP_OFFLOAD,
|
||||||
|
|
||||||
|
NUM_WLAN_STA_FLAGS,
|
||||||
|
};
|
||||||
|
--- a/net/mac80211/trace.h
|
||||||
|
+++ b/net/mac80211/trace.h
|
||||||
|
@@ -2740,7 +2740,7 @@ DEFINE_EVENT(local_sdata_addr_evt, drv_u
|
||||||
|
TP_ARGS(local, sdata)
|
||||||
|
);
|
||||||
|
|
||||||
|
-TRACE_EVENT(drv_sta_set_4addr,
|
||||||
|
+DECLARE_EVENT_CLASS(sta_flag_evt,
|
||||||
|
TP_PROTO(struct ieee80211_local *local,
|
||||||
|
struct ieee80211_sub_if_data *sdata,
|
||||||
|
struct ieee80211_sta *sta, bool enabled),
|
||||||
|
@@ -2767,6 +2767,22 @@ TRACE_EVENT(drv_sta_set_4addr,
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
+DEFINE_EVENT(sta_flag_evt, drv_sta_set_4addr,
|
||||||
|
+ TP_PROTO(struct ieee80211_local *local,
|
||||||
|
+ struct ieee80211_sub_if_data *sdata,
|
||||||
|
+ struct ieee80211_sta *sta, bool enabled),
|
||||||
|
+
|
||||||
|
+ TP_ARGS(local, sdata, sta, enabled)
|
||||||
|
+);
|
||||||
|
+
|
||||||
|
+DEFINE_EVENT(sta_flag_evt, drv_sta_set_decap_offload,
|
||||||
|
+ TP_PROTO(struct ieee80211_local *local,
|
||||||
|
+ struct ieee80211_sub_if_data *sdata,
|
||||||
|
+ struct ieee80211_sta *sta, bool enabled),
|
||||||
|
+
|
||||||
|
+ TP_ARGS(local, sdata, sta, enabled)
|
||||||
|
+);
|
||||||
|
+
|
||||||
|
#endif /* !__MAC80211_DRIVER_TRACE || TRACE_HEADER_MULTI_READ */
|
||||||
|
|
||||||
|
#undef TRACE_INCLUDE_PATH
|
@ -1,45 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 21:11:25 +0200
|
|
||||||
Subject: [PATCH] mac80211: check and refresh aggregation session in
|
|
||||||
encap offload tx
|
|
||||||
|
|
||||||
Update the last_tx timestamp to avoid tearing down the aggregation session
|
|
||||||
early. Fall back to the slow path if the session setup is still running
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -4189,6 +4189,8 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
bool authorized = false;
|
|
||||||
bool multicast;
|
|
||||||
unsigned char *ra = ehdr->h_dest;
|
|
||||||
+ struct tid_ampdu_tx *tid_tx;
|
|
||||||
+ u8 tid;
|
|
||||||
|
|
||||||
if (IS_ERR(sta) || (sta && !sta->uploaded))
|
|
||||||
sta = NULL;
|
|
||||||
@@ -4226,6 +4228,22 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
|
|
||||||
memset(info, 0, sizeof(*info));
|
|
||||||
|
|
||||||
+ if (sta) {
|
|
||||||
+ tid = skb->priority & IEEE80211_QOS_CTL_TAG1D_MASK;
|
|
||||||
+ tid_tx = rcu_dereference(sta->ampdu_mlme.tid_tx[tid]);
|
|
||||||
+ if (tid_tx) {
|
|
||||||
+ if (!test_bit(HT_AGG_STATE_OPERATIONAL, &tid_tx->state)) {
|
|
||||||
+ /* fall back to non-offload slow path */
|
|
||||||
+ __ieee80211_subif_start_xmit(skb, dev, 0, 0, NULL);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ info->flags |= IEEE80211_TX_CTL_AMPDU;
|
|
||||||
+ if (tid_tx->timeout)
|
|
||||||
+ tid_tx->last_tx = jiffies;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
if (unlikely(!multicast && skb->sk &&
|
|
||||||
skb_shinfo(skb)->tx_flags & SKBTX_WIFI_STATUS))
|
|
||||||
info->ack_frame_id = ieee80211_store_ack_skb(local, skb,
|
|
@ -0,0 +1,28 @@
|
|||||||
|
From: Wen Gong <wgong@codeaurora.org>
|
||||||
|
Date: Wed, 9 Dec 2020 11:06:29 +0800
|
||||||
|
Subject: [PATCH] mac80211: fix a mistake check for rx_stats update
|
||||||
|
|
||||||
|
It should be !is_multicast_ether_addr() in ieee80211_rx_h_sta_process()
|
||||||
|
for the rx_stats update, below commit remove the !, this patch is to
|
||||||
|
change it back.
|
||||||
|
|
||||||
|
It lead the rx rate "iw wlan0 station dump" become invalid for some
|
||||||
|
scenario when IEEE80211_HW_USES_RSS is set.
|
||||||
|
|
||||||
|
Fixes: 09a740ce352e ("mac80211: receive and process S1G beacons")
|
||||||
|
Signed-off-by: Wen Gong <wgong@codeaurora.org>
|
||||||
|
Link: https://lore.kernel.org/r/1607483189-3891-1-git-send-email-wgong@codeaurora.org
|
||||||
|
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
||||||
|
---
|
||||||
|
|
||||||
|
--- a/net/mac80211/rx.c
|
||||||
|
+++ b/net/mac80211/rx.c
|
||||||
|
@@ -1758,7 +1758,7 @@ ieee80211_rx_h_sta_process(struct ieee80
|
||||||
|
} else if (rx->sdata->vif.type == NL80211_IFTYPE_OCB) {
|
||||||
|
sta->rx_stats.last_rx = jiffies;
|
||||||
|
} else if (!ieee80211_is_s1g_beacon(hdr->frame_control) &&
|
||||||
|
- is_multicast_ether_addr(hdr->addr1)) {
|
||||||
|
+ !is_multicast_ether_addr(hdr->addr1)) {
|
||||||
|
/*
|
||||||
|
* Mesh beacons will update last_rx when if they are found to
|
||||||
|
* match the current local configuration when processed.
|
@ -1,136 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 21 Aug 2020 05:54:10 +0200
|
|
||||||
Subject: [PATCH] mac80211: skip encap offload for tx multicast/control
|
|
||||||
packets
|
|
||||||
|
|
||||||
This simplifies the checks in the encap offload tx handler and allows using
|
|
||||||
it in cases where software crypto is used for multicast packets, e.g. when
|
|
||||||
using an AP_VLAN.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -4184,88 +4184,47 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
- struct ethhdr *ehdr = (struct ethhdr *)skb->data;
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
- bool authorized = false;
|
|
||||||
- bool multicast;
|
|
||||||
- unsigned char *ra = ehdr->h_dest;
|
|
||||||
struct tid_ampdu_tx *tid_tx;
|
|
||||||
u8 tid;
|
|
||||||
|
|
||||||
- if (IS_ERR(sta) || (sta && !sta->uploaded))
|
|
||||||
- sta = NULL;
|
|
||||||
-
|
|
||||||
- if (sdata->vif.type == NL80211_IFTYPE_STATION &&
|
|
||||||
- (!sta || !test_sta_flag(sta, WLAN_STA_TDLS_PEER)))
|
|
||||||
- ra = sdata->u.mgd.bssid;
|
|
||||||
-
|
|
||||||
- if (is_zero_ether_addr(ra))
|
|
||||||
- goto out_free;
|
|
||||||
-
|
|
||||||
if (local->ops->wake_tx_queue) {
|
|
||||||
u16 queue = __ieee80211_select_queue(sdata, sta, skb);
|
|
||||||
skb_set_queue_mapping(skb, queue);
|
|
||||||
skb_get_hash(skb);
|
|
||||||
}
|
|
||||||
|
|
||||||
- multicast = is_multicast_ether_addr(ra);
|
|
||||||
-
|
|
||||||
- if (sta)
|
|
||||||
- authorized = test_sta_flag(sta, WLAN_STA_AUTHORIZED);
|
|
||||||
-
|
|
||||||
- if (!multicast && !authorized &&
|
|
||||||
- (ehdr->h_proto != sdata->control_port_protocol ||
|
|
||||||
- !ether_addr_equal(sdata->vif.addr, ehdr->h_source)))
|
|
||||||
- goto out_free;
|
|
||||||
-
|
|
||||||
- if (multicast && sdata->vif.type == NL80211_IFTYPE_AP &&
|
|
||||||
- !atomic_read(&sdata->u.ap.num_mcast_sta))
|
|
||||||
- goto out_free;
|
|
||||||
-
|
|
||||||
if (unlikely(test_bit(SCAN_SW_SCANNING, &local->scanning)) &&
|
|
||||||
test_bit(SDATA_STATE_OFFCHANNEL, &sdata->state))
|
|
||||||
goto out_free;
|
|
||||||
|
|
||||||
memset(info, 0, sizeof(*info));
|
|
||||||
|
|
||||||
- if (sta) {
|
|
||||||
- tid = skb->priority & IEEE80211_QOS_CTL_TAG1D_MASK;
|
|
||||||
- tid_tx = rcu_dereference(sta->ampdu_mlme.tid_tx[tid]);
|
|
||||||
- if (tid_tx) {
|
|
||||||
- if (!test_bit(HT_AGG_STATE_OPERATIONAL, &tid_tx->state)) {
|
|
||||||
- /* fall back to non-offload slow path */
|
|
||||||
- __ieee80211_subif_start_xmit(skb, dev, 0, 0, NULL);
|
|
||||||
- return;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- info->flags |= IEEE80211_TX_CTL_AMPDU;
|
|
||||||
- if (tid_tx->timeout)
|
|
||||||
- tid_tx->last_tx = jiffies;
|
|
||||||
+ tid = skb->priority & IEEE80211_QOS_CTL_TAG1D_MASK;
|
|
||||||
+ tid_tx = rcu_dereference(sta->ampdu_mlme.tid_tx[tid]);
|
|
||||||
+ if (tid_tx) {
|
|
||||||
+ if (!test_bit(HT_AGG_STATE_OPERATIONAL, &tid_tx->state)) {
|
|
||||||
+ /* fall back to non-offload slow path */
|
|
||||||
+ __ieee80211_subif_start_xmit(skb, dev, 0, 0, NULL);
|
|
||||||
+ return;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ info->flags |= IEEE80211_TX_CTL_AMPDU;
|
|
||||||
+ if (tid_tx->timeout)
|
|
||||||
+ tid_tx->last_tx = jiffies;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (unlikely(!multicast && skb->sk &&
|
|
||||||
+ if (unlikely(skb->sk &&
|
|
||||||
skb_shinfo(skb)->tx_flags & SKBTX_WIFI_STATUS))
|
|
||||||
info->ack_frame_id = ieee80211_store_ack_skb(local, skb,
|
|
||||||
&info->flags, NULL);
|
|
||||||
|
|
||||||
- if (unlikely(sdata->control_port_protocol == ehdr->h_proto)) {
|
|
||||||
- if (sdata->control_port_no_encrypt)
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_DONT_ENCRYPT;
|
|
||||||
- info->control.flags |= IEEE80211_TX_CTRL_PORT_CTRL_PROTO;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (multicast)
|
|
||||||
- info->flags |= IEEE80211_TX_CTL_NO_ACK;
|
|
||||||
-
|
|
||||||
info->hw_queue = sdata->vif.hw_queue[skb_get_queue_mapping(skb)];
|
|
||||||
|
|
||||||
ieee80211_tx_stats(dev, skb->len);
|
|
||||||
|
|
||||||
- if (sta) {
|
|
||||||
- sta->tx_stats.bytes[skb_get_queue_mapping(skb)] += skb->len;
|
|
||||||
- sta->tx_stats.packets[skb_get_queue_mapping(skb)]++;
|
|
||||||
- }
|
|
||||||
+ sta->tx_stats.bytes[skb_get_queue_mapping(skb)] += skb->len;
|
|
||||||
+ sta->tx_stats.packets[skb_get_queue_mapping(skb)]++;
|
|
||||||
|
|
||||||
if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN)
|
|
||||||
sdata = container_of(sdata->bss,
|
|
||||||
@@ -4286,6 +4245,7 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
|
||||||
struct net_device *dev)
|
|
||||||
{
|
|
||||||
struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
|
|
||||||
+ struct ethhdr *ehdr = (struct ethhdr *)skb->data;
|
|
||||||
struct sta_info *sta;
|
|
||||||
|
|
||||||
if (WARN_ON(!sdata->hw_80211_encap)) {
|
|
||||||
@@ -4302,6 +4262,10 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
|
||||||
|
|
||||||
if (ieee80211_lookup_ra_sta(sdata, skb, &sta))
|
|
||||||
kfree_skb(skb);
|
|
||||||
+ else if (unlikely(IS_ERR_OR_NULL(sta) || !sta->uploaded ||
|
|
||||||
+ !test_sta_flag(sta, WLAN_STA_AUTHORIZED) ||
|
|
||||||
+ sdata->control_port_protocol == ehdr->h_proto))
|
|
||||||
+ ieee80211_subif_start_xmit(skb, dev);
|
|
||||||
else
|
|
||||||
ieee80211_8023_xmit(sdata, dev, sta, skb);
|
|
||||||
|
|
@ -1,31 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 21 Aug 2020 06:03:45 +0200
|
|
||||||
Subject: [PATCH] mac80211: set info->control.hw_key for encap offload
|
|
||||||
packets
|
|
||||||
|
|
||||||
This is needed for drivers that don't do the key lookup themselves
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -4185,6 +4185,7 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
{
|
|
||||||
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
+ struct ieee80211_key *key;
|
|
||||||
struct tid_ampdu_tx *tid_tx;
|
|
||||||
u8 tid;
|
|
||||||
|
|
||||||
@@ -4233,6 +4234,10 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
info->control.flags |= IEEE80211_TX_CTRL_HW_80211_ENCAP;
|
|
||||||
info->control.vif = &sdata->vif;
|
|
||||||
|
|
||||||
+ key = rcu_dereference(sta->ptk[sta->ptk_idx]);
|
|
||||||
+ if (key)
|
|
||||||
+ info->control.hw_key = &key->conf;
|
|
||||||
+
|
|
||||||
ieee80211_tx_8023(sdata, skb, skb->len, sta, false);
|
|
||||||
|
|
||||||
return;
|
|
@ -1,613 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Thu, 13 Aug 2020 15:37:11 +0200
|
|
||||||
Subject: [PATCH] mac80211: rework tx encapsulation offload API
|
|
||||||
|
|
||||||
The current API (which lets the driver turn on/off per vif directly) has a
|
|
||||||
number of limitations:
|
|
||||||
- it does not deal with AP_VLAN
|
|
||||||
- conditions for enabling (no tkip, no monitor) are only checked at
|
|
||||||
add_interface time
|
|
||||||
- no way to indicate 4-addr support
|
|
||||||
|
|
||||||
In order to address this, store offload flags in struct ieee80211_vif
|
|
||||||
(easy to extend for decap offload later). mac80211 initially sets the enable
|
|
||||||
flag, but gives the driver a chance to modify it before its settings are
|
|
||||||
applied. In addition to the .add_interface op, a .update_vif_offload op is
|
|
||||||
introduced, which can be used for runtime changes.
|
|
||||||
|
|
||||||
If a driver can't disable encap offload at runtime, or if it has some extra
|
|
||||||
limitations, it can simply override the flags within those ops.
|
|
||||||
|
|
||||||
Support for encap offload with 4-address mode interfaces can be enabled
|
|
||||||
by setting a flag from .add_interface or .update_vif_offload.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath11k/mac.c
|
|
||||||
+++ b/drivers/net/wireless/ath/ath11k/mac.c
|
|
||||||
@@ -4150,6 +4150,35 @@ static int ath11k_set_he_mu_sounding_mod
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
+static void ath11k_mac_op_update_vif_offload(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_vif *vif)
|
|
||||||
+{
|
|
||||||
+ struct ath11k *ar = hw->priv;
|
|
||||||
+ struct ath11k_base *ab = ar->ab;
|
|
||||||
+ struct ath11k_vif *arvif = ath11k_vif_to_arvif(vif);
|
|
||||||
+ u32 param_id, param_value;
|
|
||||||
+ int ret;
|
|
||||||
+
|
|
||||||
+ param_id = WMI_VDEV_PARAM_TX_ENCAP_TYPE;
|
|
||||||
+ if (ath11k_frame_mode != ATH11K_HW_TXRX_ETHERNET ||
|
|
||||||
+ (vif->type != NL80211_IFTYPE_STATION &&
|
|
||||||
+ vif->type != NL80211_IFTYPE_AP))
|
|
||||||
+ vif->offload_flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+
|
|
||||||
+ if (vif->offload_flags & IEEE80211_OFFLOAD_ENCAP_ENABLED)
|
|
||||||
+ param_value = ATH11K_HW_TXRX_ETHERNET;
|
|
||||||
+ else
|
|
||||||
+ param_value = ATH11K_HW_TXRX_NATIVE_WIFI;
|
|
||||||
+
|
|
||||||
+ ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
|
|
||||||
+ param_id, param_value);
|
|
||||||
+ if (ret) {
|
|
||||||
+ ath11k_warn(ab, "failed to set vdev %d tx encap mode: %d\n",
|
|
||||||
+ arvif->vdev_id, ret);
|
|
||||||
+ vif->offload_flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static int ath11k_mac_op_add_interface(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif)
|
|
||||||
{
|
|
||||||
@@ -4159,7 +4188,6 @@ static int ath11k_mac_op_add_interface(s
|
|
||||||
struct vdev_create_params vdev_param = {0};
|
|
||||||
struct peer_create_params peer_param;
|
|
||||||
u32 param_id, param_value;
|
|
||||||
- int hw_encap = 0;
|
|
||||||
u16 nss;
|
|
||||||
int i;
|
|
||||||
int ret;
|
|
||||||
@@ -4253,30 +4281,7 @@ static int ath11k_mac_op_add_interface(s
|
|
||||||
list_add(&arvif->list, &ar->arvifs);
|
|
||||||
spin_unlock_bh(&ar->data_lock);
|
|
||||||
|
|
||||||
- param_id = WMI_VDEV_PARAM_TX_ENCAP_TYPE;
|
|
||||||
- if (ath11k_frame_mode == ATH11K_HW_TXRX_ETHERNET)
|
|
||||||
- switch (vif->type) {
|
|
||||||
- case NL80211_IFTYPE_STATION:
|
|
||||||
- case NL80211_IFTYPE_AP_VLAN:
|
|
||||||
- case NL80211_IFTYPE_AP:
|
|
||||||
- hw_encap = 1;
|
|
||||||
- break;
|
|
||||||
- default:
|
|
||||||
- break;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (ieee80211_set_hw_80211_encap(vif, hw_encap))
|
|
||||||
- param_value = ATH11K_HW_TXRX_ETHERNET;
|
|
||||||
- else
|
|
||||||
- param_value = ATH11K_HW_TXRX_NATIVE_WIFI;
|
|
||||||
-
|
|
||||||
- ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
|
|
||||||
- param_id, param_value);
|
|
||||||
- if (ret) {
|
|
||||||
- ath11k_warn(ab, "failed to set vdev %d tx encap mode: %d\n",
|
|
||||||
- arvif->vdev_id, ret);
|
|
||||||
- goto err_vdev_del;
|
|
||||||
- }
|
|
||||||
+ ath11k_mac_op_update_vif_offload(hw, vif);
|
|
||||||
|
|
||||||
nss = get_num_chains(ar->cfg_tx_chainmask) ? : 1;
|
|
||||||
ret = ath11k_wmi_vdev_set_param_cmd(ar, arvif->vdev_id,
|
|
||||||
@@ -5599,6 +5604,7 @@ static const struct ieee80211_ops ath11k
|
|
||||||
.reconfig_complete = ath11k_mac_op_reconfig_complete,
|
|
||||||
.add_interface = ath11k_mac_op_add_interface,
|
|
||||||
.remove_interface = ath11k_mac_op_remove_interface,
|
|
||||||
+ .update_vif_offload = ath11k_mac_op_update_vif_offload,
|
|
||||||
.config = ath11k_mac_op_config,
|
|
||||||
.bss_info_changed = ath11k_mac_op_bss_info_changed,
|
|
||||||
.configure_filter = ath11k_mac_op_configure_filter,
|
|
||||||
@@ -5852,6 +5858,7 @@ static int __ath11k_mac_register(struct
|
|
||||||
ieee80211_hw_set(ar->hw, QUEUE_CONTROL);
|
|
||||||
ieee80211_hw_set(ar->hw, SUPPORTS_TX_FRAG);
|
|
||||||
ieee80211_hw_set(ar->hw, REPORTS_LOW_ACK);
|
|
||||||
+ ieee80211_hw_set(ar->hw, SUPPORTS_TX_ENCAP_OFFLOAD);
|
|
||||||
if (ht_cap & WMI_HT_CAP_ENABLED) {
|
|
||||||
ieee80211_hw_set(ar->hw, AMPDU_AGGREGATION);
|
|
||||||
ieee80211_hw_set(ar->hw, TX_AMPDU_SETUP_IN_HW);
|
|
||||||
--- a/include/net/mac80211.h
|
|
||||||
+++ b/include/net/mac80211.h
|
|
||||||
@@ -1603,6 +1603,21 @@ enum ieee80211_vif_flags {
|
|
||||||
IEEE80211_VIF_GET_NOA_UPDATE = BIT(3),
|
|
||||||
};
|
|
||||||
|
|
||||||
+
|
|
||||||
+/**
|
|
||||||
+ * enum ieee80211_offload_flags - virtual interface offload flags
|
|
||||||
+ *
|
|
||||||
+ * @IEEE80211_OFFLOAD_ENCAP_ENABLED: tx encapsulation offload is enabled
|
|
||||||
+ * The driver supports sending frames passed as 802.3 frames by mac80211.
|
|
||||||
+ * It must also support sending 802.11 packets for the same interface.
|
|
||||||
+ * @IEEE80211_OFFLOAD_ENCAP_4ADDR: support 4-address mode encapsulation offload
|
|
||||||
+ */
|
|
||||||
+
|
|
||||||
+enum ieee80211_offload_flags {
|
|
||||||
+ IEEE80211_OFFLOAD_ENCAP_ENABLED = BIT(0),
|
|
||||||
+ IEEE80211_OFFLOAD_ENCAP_4ADDR = BIT(1),
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* struct ieee80211_vif - per-interface data
|
|
||||||
*
|
|
||||||
@@ -1623,6 +1638,11 @@ enum ieee80211_vif_flags {
|
|
||||||
* these need to be set (or cleared) when the interface is added
|
|
||||||
* or, if supported by the driver, the interface type is changed
|
|
||||||
* at runtime, mac80211 will never touch this field
|
|
||||||
+ * @offloaad_flags: hardware offload capabilities/flags for this interface.
|
|
||||||
+ * These are initialized by mac80211 before calling .add_interface,
|
|
||||||
+ * .change_interface or .update_vif_offload and updated by the driver
|
|
||||||
+ * within these ops, based on supported features or runtime change
|
|
||||||
+ * restrictions.
|
|
||||||
* @hw_queue: hardware queue for each AC
|
|
||||||
* @cab_queue: content-after-beacon (DTIM beacon really) queue, AP mode only
|
|
||||||
* @chanctx_conf: The channel context this interface is assigned to, or %NULL
|
|
||||||
@@ -1659,6 +1679,7 @@ struct ieee80211_vif {
|
|
||||||
struct ieee80211_chanctx_conf __rcu *chanctx_conf;
|
|
||||||
|
|
||||||
u32 driver_flags;
|
|
||||||
+ u32 offload_flags;
|
|
||||||
|
|
||||||
#ifdef CPTCFG_MAC80211_DEBUGFS
|
|
||||||
struct dentry *debugfs_dir;
|
|
||||||
@@ -2325,6 +2346,9 @@ struct ieee80211_txq {
|
|
||||||
* aggregating MPDUs with the same keyid, allowing mac80211 to keep Tx
|
|
||||||
* A-MPDU sessions active while rekeying with Extended Key ID.
|
|
||||||
*
|
|
||||||
+ * @IEEE80211_HW_SUPPORTS_TX_ENCAP_OFFLOAD: Hardware supports tx encapsulation
|
|
||||||
+ * offload
|
|
||||||
+ *
|
|
||||||
* @NUM_IEEE80211_HW_FLAGS: number of hardware flags, used for sizing arrays
|
|
||||||
*/
|
|
||||||
enum ieee80211_hw_flags {
|
|
||||||
@@ -2377,6 +2401,7 @@ enum ieee80211_hw_flags {
|
|
||||||
IEEE80211_HW_SUPPORTS_MULTI_BSSID,
|
|
||||||
IEEE80211_HW_SUPPORTS_ONLY_HE_MULTI_BSSID,
|
|
||||||
IEEE80211_HW_AMPDU_KEYBORDER_SUPPORT,
|
|
||||||
+ IEEE80211_HW_SUPPORTS_TX_ENCAP_OFFLOAD,
|
|
||||||
|
|
||||||
/* keep last, obviously */
|
|
||||||
NUM_IEEE80211_HW_FLAGS
|
|
||||||
@@ -3811,6 +3836,8 @@ enum ieee80211_reconfig_type {
|
|
||||||
* @set_tid_config: Apply TID specific configurations. This callback may sleep.
|
|
||||||
* @reset_tid_config: Reset TID specific configuration for the peer.
|
|
||||||
* This callback may sleep.
|
|
||||||
+ * @update_vif_config: Update virtual interface offload flags
|
|
||||||
+ * This callback may sleep.
|
|
||||||
*/
|
|
||||||
struct ieee80211_ops {
|
|
||||||
void (*tx)(struct ieee80211_hw *hw,
|
|
||||||
@@ -4122,6 +4149,8 @@ struct ieee80211_ops {
|
|
||||||
int (*reset_tid_config)(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif,
|
|
||||||
struct ieee80211_sta *sta, u8 tids);
|
|
||||||
+ void (*update_vif_offload)(struct ieee80211_hw *hw,
|
|
||||||
+ struct ieee80211_vif *vif);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
--- a/net/mac80211/debugfs.c
|
|
||||||
+++ b/net/mac80211/debugfs.c
|
|
||||||
@@ -408,6 +408,7 @@ static const char *hw_flag_names[] = {
|
|
||||||
FLAG(SUPPORTS_MULTI_BSSID),
|
|
||||||
FLAG(SUPPORTS_ONLY_HE_MULTI_BSSID),
|
|
||||||
FLAG(AMPDU_KEYBORDER_SUPPORT),
|
|
||||||
+ FLAG(SUPPORTS_TX_ENCAP_OFFLOAD),
|
|
||||||
#undef FLAG
|
|
||||||
};
|
|
||||||
|
|
||||||
--- a/net/mac80211/driver-ops.h
|
|
||||||
+++ b/net/mac80211/driver-ops.h
|
|
||||||
@@ -1385,4 +1385,19 @@ static inline int drv_reset_tid_config(s
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+static inline void drv_update_vif_offload(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata)
|
|
||||||
+{
|
|
||||||
+ might_sleep();
|
|
||||||
+ check_sdata_in_driver(sdata);
|
|
||||||
+
|
|
||||||
+ if (!local->ops->update_vif_offload)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ trace_drv_update_vif_offload(local, sdata);
|
|
||||||
+ local->ops->update_vif_offload(&local->hw, &sdata->vif);
|
|
||||||
+ trace_drv_return_void(local);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
#endif /* __MAC80211_DRIVER_OPS */
|
|
||||||
--- a/net/mac80211/ieee80211_i.h
|
|
||||||
+++ b/net/mac80211/ieee80211_i.h
|
|
||||||
@@ -990,8 +990,6 @@ struct ieee80211_sub_if_data {
|
|
||||||
} debugfs;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
- bool hw_80211_encap;
|
|
||||||
-
|
|
||||||
/* must be last, dynamically sized area in this! */
|
|
||||||
struct ieee80211_vif vif;
|
|
||||||
};
|
|
||||||
@@ -1769,6 +1767,7 @@ void ieee80211_del_virtual_monitor(struc
|
|
||||||
bool __ieee80211_recalc_txpower(struct ieee80211_sub_if_data *sdata);
|
|
||||||
void ieee80211_recalc_txpower(struct ieee80211_sub_if_data *sdata,
|
|
||||||
bool update_bss);
|
|
||||||
+void ieee80211_recalc_offload(struct ieee80211_local *local);
|
|
||||||
|
|
||||||
static inline bool ieee80211_sdata_running(struct ieee80211_sub_if_data *sdata)
|
|
||||||
{
|
|
||||||
--- a/net/mac80211/iface.c
|
|
||||||
+++ b/net/mac80211/iface.c
|
|
||||||
@@ -43,6 +43,7 @@
|
|
||||||
*/
|
|
||||||
|
|
||||||
static void ieee80211_iface_work(struct work_struct *work);
|
|
||||||
+static void ieee80211_set_vif_encap_ops(struct ieee80211_sub_if_data *sdata);
|
|
||||||
|
|
||||||
bool __ieee80211_recalc_txpower(struct ieee80211_sub_if_data *sdata)
|
|
||||||
{
|
|
||||||
@@ -348,6 +349,85 @@ static int ieee80211_check_queues(struct
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
+static bool ieee80211_iftype_supports_encap_offload(enum nl80211_iftype iftype)
|
|
||||||
+{
|
|
||||||
+ switch (iftype) {
|
|
||||||
+ /* P2P GO and client are mapped to AP/STATION types */
|
|
||||||
+ case NL80211_IFTYPE_AP:
|
|
||||||
+ case NL80211_IFTYPE_STATION:
|
|
||||||
+ return true;
|
|
||||||
+ default:
|
|
||||||
+ return false;
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+static bool ieee80211_set_sdata_offload_flags(struct ieee80211_sub_if_data *sdata)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_local *local = sdata->local;
|
|
||||||
+ u32 flags;
|
|
||||||
+
|
|
||||||
+ flags = sdata->vif.offload_flags;
|
|
||||||
+
|
|
||||||
+ if (ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) &&
|
|
||||||
+ ieee80211_iftype_supports_encap_offload(sdata->vif.type)) {
|
|
||||||
+ flags |= IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+
|
|
||||||
+ if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_FRAG) &&
|
|
||||||
+ local->hw.wiphy->frag_threshold != (u32)-1)
|
|
||||||
+ flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+
|
|
||||||
+ if (local->monitors)
|
|
||||||
+ flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+ } else {
|
|
||||||
+ flags &= ~IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (sdata->vif.offload_flags == flags)
|
|
||||||
+ return false;
|
|
||||||
+
|
|
||||||
+ sdata->vif.offload_flags = flags;
|
|
||||||
+ return true;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+static void ieee80211_recalc_sdata_offload(struct ieee80211_sub_if_data *sdata)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_local *local = sdata->local;
|
|
||||||
+ struct ieee80211_sub_if_data *vsdata;
|
|
||||||
+
|
|
||||||
+ if (ieee80211_set_sdata_offload_flags(sdata)) {
|
|
||||||
+ drv_update_vif_offload(local, sdata);
|
|
||||||
+ ieee80211_set_vif_encap_ops(sdata);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ list_for_each_entry(vsdata, &local->interfaces, list) {
|
|
||||||
+ if (vsdata->vif.type != NL80211_IFTYPE_AP_VLAN ||
|
|
||||||
+ vsdata->bss != &sdata->u.ap)
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ ieee80211_set_vif_encap_ops(vsdata);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void ieee80211_recalc_offload(struct ieee80211_local *local)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_sub_if_data *sdata;
|
|
||||||
+
|
|
||||||
+ if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD))
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ mutex_lock(&local->iflist_mtx);
|
|
||||||
+
|
|
||||||
+ list_for_each_entry(sdata, &local->interfaces, list) {
|
|
||||||
+ if (!ieee80211_sdata_running(sdata))
|
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ ieee80211_recalc_sdata_offload(sdata);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ mutex_unlock(&local->iflist_mtx);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
void ieee80211_adjust_monitor_flags(struct ieee80211_sub_if_data *sdata,
|
|
||||||
const int offset)
|
|
||||||
{
|
|
||||||
@@ -587,6 +667,7 @@ int ieee80211_do_open(struct wireless_de
|
|
||||||
if (rtnl_dereference(sdata->bss->beacon)) {
|
|
||||||
ieee80211_vif_vlan_copy_chanctx(sdata);
|
|
||||||
netif_carrier_on(dev);
|
|
||||||
+ ieee80211_set_vif_encap_ops(sdata);
|
|
||||||
} else {
|
|
||||||
netif_carrier_off(dev);
|
|
||||||
}
|
|
||||||
@@ -616,6 +697,7 @@ int ieee80211_do_open(struct wireless_de
|
|
||||||
|
|
||||||
ieee80211_adjust_monitor_flags(sdata, 1);
|
|
||||||
ieee80211_configure_filter(local);
|
|
||||||
+ ieee80211_recalc_offload(local);
|
|
||||||
mutex_lock(&local->mtx);
|
|
||||||
ieee80211_recalc_idle(local);
|
|
||||||
mutex_unlock(&local->mtx);
|
|
||||||
@@ -625,10 +707,13 @@ int ieee80211_do_open(struct wireless_de
|
|
||||||
default:
|
|
||||||
if (coming_up) {
|
|
||||||
ieee80211_del_virtual_monitor(local);
|
|
||||||
+ ieee80211_set_sdata_offload_flags(sdata);
|
|
||||||
|
|
||||||
res = drv_add_interface(local, sdata);
|
|
||||||
if (res)
|
|
||||||
goto err_stop;
|
|
||||||
+
|
|
||||||
+ ieee80211_set_vif_encap_ops(sdata);
|
|
||||||
res = ieee80211_check_queues(sdata,
|
|
||||||
ieee80211_vif_type_p2p(&sdata->vif));
|
|
||||||
if (res)
|
|
||||||
@@ -1286,61 +1371,6 @@ static const struct net_device_ops ieee8
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
-static void __ieee80211_set_hw_80211_encap(struct ieee80211_sub_if_data *sdata,
|
|
||||||
- bool enable)
|
|
||||||
-{
|
|
||||||
- sdata->dev->netdev_ops = enable ? &ieee80211_dataif_8023_ops :
|
|
||||||
- &ieee80211_dataif_ops;
|
|
||||||
- sdata->hw_80211_encap = enable;
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
-bool ieee80211_set_hw_80211_encap(struct ieee80211_vif *vif, bool enable)
|
|
||||||
-{
|
|
||||||
- struct ieee80211_sub_if_data *sdata = vif_to_sdata(vif);
|
|
||||||
- struct ieee80211_local *local = sdata->local;
|
|
||||||
- struct ieee80211_sub_if_data *iter;
|
|
||||||
- struct ieee80211_key *key;
|
|
||||||
-
|
|
||||||
- mutex_lock(&local->iflist_mtx);
|
|
||||||
- list_for_each_entry(iter, &local->interfaces, list) {
|
|
||||||
- struct ieee80211_sub_if_data *disable = NULL;
|
|
||||||
-
|
|
||||||
- if (vif->type == NL80211_IFTYPE_MONITOR) {
|
|
||||||
- disable = iter;
|
|
||||||
- __ieee80211_set_hw_80211_encap(iter, false);
|
|
||||||
- } else if (iter->vif.type == NL80211_IFTYPE_MONITOR) {
|
|
||||||
- disable = sdata;
|
|
||||||
- enable = false;
|
|
||||||
- }
|
|
||||||
- if (disable)
|
|
||||||
- sdata_dbg(disable,
|
|
||||||
- "disable hw 80211 encap due to mon co-exist\n");
|
|
||||||
- }
|
|
||||||
- mutex_unlock(&local->iflist_mtx);
|
|
||||||
-
|
|
||||||
- if (enable == sdata->hw_80211_encap)
|
|
||||||
- return enable;
|
|
||||||
-
|
|
||||||
- if (!sdata->dev)
|
|
||||||
- return false;
|
|
||||||
-
|
|
||||||
- if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_FRAG) &&
|
|
||||||
- (local->hw.wiphy->frag_threshold != (u32)-1))
|
|
||||||
- enable = false;
|
|
||||||
-
|
|
||||||
- mutex_lock(&sdata->local->key_mtx);
|
|
||||||
- list_for_each_entry(key, &sdata->key_list, list) {
|
|
||||||
- if (key->conf.cipher == WLAN_CIPHER_SUITE_TKIP)
|
|
||||||
- enable = false;
|
|
||||||
- }
|
|
||||||
- mutex_unlock(&sdata->local->key_mtx);
|
|
||||||
-
|
|
||||||
- __ieee80211_set_hw_80211_encap(sdata, enable);
|
|
||||||
-
|
|
||||||
- return enable;
|
|
||||||
-}
|
|
||||||
-EXPORT_SYMBOL(ieee80211_set_hw_80211_encap);
|
|
||||||
-
|
|
||||||
static void ieee80211_if_free(struct net_device *dev)
|
|
||||||
{
|
|
||||||
free_percpu(netdev_tstats(dev));
|
|
||||||
@@ -1371,6 +1401,32 @@ static void ieee80211_if_setup_no_queue(
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
+static void ieee80211_set_vif_encap_ops(struct ieee80211_sub_if_data *sdata)
|
|
||||||
+{
|
|
||||||
+ struct ieee80211_local *local = sdata->local;
|
|
||||||
+ struct ieee80211_sub_if_data *bss = sdata;
|
|
||||||
+ bool enabled;
|
|
||||||
+
|
|
||||||
+ if (sdata->vif.type == NL80211_IFTYPE_AP_VLAN) {
|
|
||||||
+ if (!sdata->bss)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ bss = container_of(sdata->bss, struct ieee80211_sub_if_data, u.ap);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (!ieee80211_hw_check(&local->hw, SUPPORTS_TX_ENCAP_OFFLOAD) ||
|
|
||||||
+ !ieee80211_iftype_supports_encap_offload(bss->vif.type))
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ enabled = bss->vif.offload_flags & IEEE80211_OFFLOAD_ENCAP_ENABLED;
|
|
||||||
+ if (sdata->wdev.use_4addr &&
|
|
||||||
+ !(bss->vif.offload_flags & IEEE80211_OFFLOAD_ENCAP_4ADDR))
|
|
||||||
+ enabled = false;
|
|
||||||
+
|
|
||||||
+ sdata->dev->netdev_ops = enabled ? &ieee80211_dataif_8023_ops :
|
|
||||||
+ &ieee80211_dataif_ops;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static void ieee80211_iface_work(struct work_struct *work)
|
|
||||||
{
|
|
||||||
struct ieee80211_sub_if_data *sdata =
|
|
||||||
@@ -1553,7 +1609,6 @@ static void ieee80211_setup_sdata(struct
|
|
||||||
sdata->vif.bss_conf.txpower = INT_MIN; /* unset */
|
|
||||||
|
|
||||||
sdata->noack_map = 0;
|
|
||||||
- sdata->hw_80211_encap = false;
|
|
||||||
|
|
||||||
/* only monitor/p2p-device differ */
|
|
||||||
if (sdata->dev) {
|
|
||||||
@@ -1688,6 +1743,7 @@ static int ieee80211_runtime_change_ifty
|
|
||||||
|
|
||||||
ieee80211_teardown_sdata(sdata);
|
|
||||||
|
|
||||||
+ ieee80211_set_sdata_offload_flags(sdata);
|
|
||||||
ret = drv_change_interface(local, sdata, internal_type, p2p);
|
|
||||||
if (ret)
|
|
||||||
type = ieee80211_vif_type_p2p(&sdata->vif);
|
|
||||||
@@ -1700,6 +1756,7 @@ static int ieee80211_runtime_change_ifty
|
|
||||||
ieee80211_check_queues(sdata, type);
|
|
||||||
|
|
||||||
ieee80211_setup_sdata(sdata, type);
|
|
||||||
+ ieee80211_set_vif_encap_ops(sdata);
|
|
||||||
|
|
||||||
err = ieee80211_do_open(&sdata->wdev, false);
|
|
||||||
WARN(err, "type change: do_open returned %d", err);
|
|
||||||
--- a/net/mac80211/key.c
|
|
||||||
+++ b/net/mac80211/key.c
|
|
||||||
@@ -177,13 +177,6 @@ static int ieee80211_key_enable_hw_accel
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- /* TKIP countermeasures don't work in encap offload mode */
|
|
||||||
- if (key->conf.cipher == WLAN_CIPHER_SUITE_TKIP &&
|
|
||||||
- sdata->hw_80211_encap) {
|
|
||||||
- sdata_dbg(sdata, "TKIP is not allowed in hw 80211 encap mode\n");
|
|
||||||
- return -EINVAL;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
ret = drv_set_key(key->local, SET_KEY, sdata,
|
|
||||||
sta ? &sta->sta : NULL, &key->conf);
|
|
||||||
|
|
||||||
@@ -219,14 +212,6 @@ static int ieee80211_key_enable_hw_accel
|
|
||||||
case WLAN_CIPHER_SUITE_CCMP_256:
|
|
||||||
case WLAN_CIPHER_SUITE_GCMP:
|
|
||||||
case WLAN_CIPHER_SUITE_GCMP_256:
|
|
||||||
- /* We cannot do software crypto of data frames with
|
|
||||||
- * encapsulation offload enabled. However for 802.11w to
|
|
||||||
- * function properly we need cmac/gmac keys.
|
|
||||||
- */
|
|
||||||
- if (sdata->hw_80211_encap)
|
|
||||||
- return -EINVAL;
|
|
||||||
- /* Fall through */
|
|
||||||
-
|
|
||||||
case WLAN_CIPHER_SUITE_AES_CMAC:
|
|
||||||
case WLAN_CIPHER_SUITE_BIP_CMAC_256:
|
|
||||||
case WLAN_CIPHER_SUITE_BIP_GMAC_128:
|
|
||||||
--- a/net/mac80211/trace.h
|
|
||||||
+++ b/net/mac80211/trace.h
|
|
||||||
@@ -2733,6 +2733,12 @@ TRACE_EVENT(drv_get_ftm_responder_stats,
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
+DEFINE_EVENT(local_sdata_addr_evt, drv_update_vif_offload,
|
|
||||||
+ TP_PROTO(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata),
|
|
||||||
+ TP_ARGS(local, sdata)
|
|
||||||
+);
|
|
||||||
+
|
|
||||||
#endif /* !__MAC80211_DRIVER_TRACE || TRACE_HEADER_MULTI_READ */
|
|
||||||
|
|
||||||
#undef TRACE_INCLUDE_PATH
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -4181,11 +4181,10 @@ static bool ieee80211_tx_8023(struct iee
|
|
||||||
|
|
||||||
static void ieee80211_8023_xmit(struct ieee80211_sub_if_data *sdata,
|
|
||||||
struct net_device *dev, struct sta_info *sta,
|
|
||||||
- struct sk_buff *skb)
|
|
||||||
+ struct ieee80211_key *key, struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
- struct ieee80211_key *key;
|
|
||||||
struct tid_ampdu_tx *tid_tx;
|
|
||||||
u8 tid;
|
|
||||||
|
|
||||||
@@ -4234,7 +4233,6 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
info->control.flags |= IEEE80211_TX_CTRL_HW_80211_ENCAP;
|
|
||||||
info->control.vif = &sdata->vif;
|
|
||||||
|
|
||||||
- key = rcu_dereference(sta->ptk[sta->ptk_idx]);
|
|
||||||
if (key)
|
|
||||||
info->control.hw_key = &key->conf;
|
|
||||||
|
|
||||||
@@ -4251,12 +4249,9 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
|
||||||
{
|
|
||||||
struct ieee80211_sub_if_data *sdata = IEEE80211_DEV_TO_SUB_IF(dev);
|
|
||||||
struct ethhdr *ehdr = (struct ethhdr *)skb->data;
|
|
||||||
+ struct ieee80211_key *key;
|
|
||||||
struct sta_info *sta;
|
|
||||||
-
|
|
||||||
- if (WARN_ON(!sdata->hw_80211_encap)) {
|
|
||||||
- kfree_skb(skb);
|
|
||||||
- return NETDEV_TX_OK;
|
|
||||||
- }
|
|
||||||
+ bool offload = true;
|
|
||||||
|
|
||||||
if (unlikely(skb->len < ETH_HLEN)) {
|
|
||||||
kfree_skb(skb);
|
|
||||||
@@ -4265,15 +4260,26 @@ netdev_tx_t ieee80211_subif_start_xmit_8
|
|
||||||
|
|
||||||
rcu_read_lock();
|
|
||||||
|
|
||||||
- if (ieee80211_lookup_ra_sta(sdata, skb, &sta))
|
|
||||||
+ if (ieee80211_lookup_ra_sta(sdata, skb, &sta)) {
|
|
||||||
kfree_skb(skb);
|
|
||||||
- else if (unlikely(IS_ERR_OR_NULL(sta) || !sta->uploaded ||
|
|
||||||
- !test_sta_flag(sta, WLAN_STA_AUTHORIZED) ||
|
|
||||||
- sdata->control_port_protocol == ehdr->h_proto))
|
|
||||||
- ieee80211_subif_start_xmit(skb, dev);
|
|
||||||
+ goto out;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (unlikely(IS_ERR_OR_NULL(sta) || !sta->uploaded ||
|
|
||||||
+ !test_sta_flag(sta, WLAN_STA_AUTHORIZED) ||
|
|
||||||
+ sdata->control_port_protocol == ehdr->h_proto))
|
|
||||||
+ offload = false;
|
|
||||||
+ else if ((key = rcu_dereference(sta->ptk[sta->ptk_idx])) &&
|
|
||||||
+ (!(key->flags & KEY_FLAG_UPLOADED_TO_HARDWARE) ||
|
|
||||||
+ key->conf.cipher == WLAN_CIPHER_SUITE_TKIP))
|
|
||||||
+ offload = false;
|
|
||||||
+
|
|
||||||
+ if (offload)
|
|
||||||
+ ieee80211_8023_xmit(sdata, dev, sta, key, skb);
|
|
||||||
else
|
|
||||||
- ieee80211_8023_xmit(sdata, dev, sta, skb);
|
|
||||||
+ ieee80211_subif_start_xmit(skb, dev);
|
|
||||||
|
|
||||||
+out:
|
|
||||||
rcu_read_unlock();
|
|
||||||
|
|
||||||
return NETDEV_TX_OK;
|
|
@ -1,197 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:16:59 +0200
|
|
||||||
Subject: [PATCH] mac80211: reduce duplication in tx status functions
|
|
||||||
|
|
||||||
Move redundant functionality from __ieee80211_tx_status into
|
|
||||||
ieee80211_tx_status_ext. Preparation for unifying with the 802.3 tx status
|
|
||||||
codepath.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -184,18 +184,6 @@ static void ieee80211_frame_acked(struct
|
|
||||||
struct ieee80211_mgmt *mgmt = (void *) skb->data;
|
|
||||||
struct ieee80211_local *local = sta->local;
|
|
||||||
struct ieee80211_sub_if_data *sdata = sta->sdata;
|
|
||||||
- struct ieee80211_tx_info *txinfo = IEEE80211_SKB_CB(skb);
|
|
||||||
-
|
|
||||||
- if (ieee80211_hw_check(&local->hw, REPORTS_TX_ACK_STATUS)) {
|
|
||||||
- sta->status_stats.last_ack = jiffies;
|
|
||||||
- if (txinfo->status.is_valid_ack_signal) {
|
|
||||||
- sta->status_stats.last_ack_signal =
|
|
||||||
- (s8)txinfo->status.ack_signal;
|
|
||||||
- sta->status_stats.ack_signal_filled = true;
|
|
||||||
- ewma_avg_signal_add(&sta->status_stats.avg_ack_signal,
|
|
||||||
- -txinfo->status.ack_signal);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
|
|
||||||
if (ieee80211_is_data_qos(mgmt->frame_control)) {
|
|
||||||
struct ieee80211_hdr *hdr = (void *) skb->data;
|
|
||||||
@@ -899,7 +887,8 @@ void ieee80211_tx_monitor(struct ieee802
|
|
||||||
}
|
|
||||||
|
|
||||||
static void __ieee80211_tx_status(struct ieee80211_hw *hw,
|
|
||||||
- struct ieee80211_tx_status *status)
|
|
||||||
+ struct ieee80211_tx_status *status,
|
|
||||||
+ int rates_idx, int retry_count)
|
|
||||||
{
|
|
||||||
struct sk_buff *skb = status->skb;
|
|
||||||
struct ieee80211_hdr *hdr = (struct ieee80211_hdr *) skb->data;
|
|
||||||
@@ -908,8 +897,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
struct sta_info *sta;
|
|
||||||
__le16 fc;
|
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
- int retry_count;
|
|
||||||
- int rates_idx;
|
|
||||||
bool send_to_cooked;
|
|
||||||
bool acked;
|
|
||||||
bool noack_success;
|
|
||||||
@@ -918,8 +905,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
int tid = IEEE80211_NUM_TIDS;
|
|
||||||
u16 tx_time_est;
|
|
||||||
|
|
||||||
- rates_idx = ieee80211_tx_get_rates(hw, info, &retry_count);
|
|
||||||
-
|
|
||||||
sband = local->hw.wiphy->bands[info->band];
|
|
||||||
fc = hdr->frame_control;
|
|
||||||
|
|
||||||
@@ -996,24 +981,14 @@ static void __ieee80211_tx_status(struct
|
|
||||||
if (info->flags & IEEE80211_TX_STAT_TX_FILTERED) {
|
|
||||||
ieee80211_handle_filtered_frame(local, sta, skb);
|
|
||||||
return;
|
|
||||||
- } else {
|
|
||||||
+ } else if (ieee80211_is_data_present(fc)) {
|
|
||||||
if (!acked && !noack_success)
|
|
||||||
- sta->status_stats.retry_failed++;
|
|
||||||
- sta->status_stats.retry_count += retry_count;
|
|
||||||
+ sta->status_stats.msdu_failed[tid]++;
|
|
||||||
|
|
||||||
- if (ieee80211_is_data_present(fc)) {
|
|
||||||
- if (!acked && !noack_success)
|
|
||||||
- sta->status_stats.msdu_failed[tid]++;
|
|
||||||
-
|
|
||||||
- sta->status_stats.msdu_retries[tid] +=
|
|
||||||
- retry_count;
|
|
||||||
- }
|
|
||||||
+ sta->status_stats.msdu_retries[tid] +=
|
|
||||||
+ retry_count;
|
|
||||||
}
|
|
||||||
|
|
||||||
- rate_control_tx_status(local, sband, status);
|
|
||||||
- if (ieee80211_vif_is_mesh(&sta->sdata->vif))
|
|
||||||
- ieee80211s_update_metric(local, sta, status);
|
|
||||||
-
|
|
||||||
if (!(info->flags & IEEE80211_TX_CTL_INJECTED) && acked)
|
|
||||||
ieee80211_frame_acked(sta, skb);
|
|
||||||
|
|
||||||
@@ -1038,20 +1013,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
true);
|
|
||||||
ieee80211_info_set_tx_time_est(info, 0);
|
|
||||||
}
|
|
||||||
-
|
|
||||||
- if (ieee80211_hw_check(&local->hw, REPORTS_TX_ACK_STATUS)) {
|
|
||||||
- if (acked) {
|
|
||||||
- if (sta->status_stats.lost_packets)
|
|
||||||
- sta->status_stats.lost_packets = 0;
|
|
||||||
-
|
|
||||||
- /* Track when last TDLS packet was ACKed */
|
|
||||||
- sta->status_stats.last_pkt_time = jiffies;
|
|
||||||
- } else if (noack_success) {
|
|
||||||
- /* nothing to do here, do not account as lost */
|
|
||||||
- } else {
|
|
||||||
- ieee80211_lost_packet(sta, info);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SNMP counters
|
|
||||||
@@ -1135,7 +1096,7 @@ void ieee80211_tx_status(struct ieee8021
|
|
||||||
if (sta)
|
|
||||||
status.sta = &sta->sta;
|
|
||||||
|
|
||||||
- __ieee80211_tx_status(hw, &status);
|
|
||||||
+ ieee80211_tx_status_ext(hw, &status);
|
|
||||||
rcu_read_unlock();
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(ieee80211_tx_status);
|
|
||||||
@@ -1148,7 +1109,7 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
struct ieee80211_sta *pubsta = status->sta;
|
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
struct sta_info *sta;
|
|
||||||
- int retry_count;
|
|
||||||
+ int rates_idx, retry_count;
|
|
||||||
bool acked, noack_success;
|
|
||||||
|
|
||||||
if (pubsta) {
|
|
||||||
@@ -1158,13 +1119,7 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
sta->tx_stats.last_rate_info = *status->rate;
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (status->skb)
|
|
||||||
- return __ieee80211_tx_status(hw, status);
|
|
||||||
-
|
|
||||||
- if (!status->sta)
|
|
||||||
- return;
|
|
||||||
-
|
|
||||||
- ieee80211_tx_get_rates(hw, info, &retry_count);
|
|
||||||
+ rates_idx = ieee80211_tx_get_rates(hw, info, &retry_count);
|
|
||||||
|
|
||||||
sband = hw->wiphy->bands[info->band];
|
|
||||||
|
|
||||||
@@ -1176,20 +1131,30 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
sta->status_stats.retry_failed++;
|
|
||||||
sta->status_stats.retry_count += retry_count;
|
|
||||||
|
|
||||||
- if (acked) {
|
|
||||||
- sta->status_stats.last_ack = jiffies;
|
|
||||||
+ if (ieee80211_hw_check(&local->hw, REPORTS_TX_ACK_STATUS)) {
|
|
||||||
+ if (acked) {
|
|
||||||
+ sta->status_stats.last_ack = jiffies;
|
|
||||||
|
|
||||||
- if (sta->status_stats.lost_packets)
|
|
||||||
- sta->status_stats.lost_packets = 0;
|
|
||||||
+ if (sta->status_stats.lost_packets)
|
|
||||||
+ sta->status_stats.lost_packets = 0;
|
|
||||||
|
|
||||||
- /* Track when last packet was ACKed */
|
|
||||||
- sta->status_stats.last_pkt_time = jiffies;
|
|
||||||
- } else if (test_sta_flag(sta, WLAN_STA_PS_STA)) {
|
|
||||||
- return;
|
|
||||||
- } else if (noack_success) {
|
|
||||||
- /* nothing to do here, do not account as lost */
|
|
||||||
- } else {
|
|
||||||
- ieee80211_lost_packet(sta, info);
|
|
||||||
+ /* Track when last packet was ACKed */
|
|
||||||
+ sta->status_stats.last_pkt_time = jiffies;
|
|
||||||
+
|
|
||||||
+ if (info->status.is_valid_ack_signal) {
|
|
||||||
+ sta->status_stats.last_ack_signal =
|
|
||||||
+ (s8)info->status.ack_signal;
|
|
||||||
+ sta->status_stats.ack_signal_filled = true;
|
|
||||||
+ ewma_avg_signal_add(&sta->status_stats.avg_ack_signal,
|
|
||||||
+ -info->status.ack_signal);
|
|
||||||
+ }
|
|
||||||
+ } else if (test_sta_flag(sta, WLAN_STA_PS_STA)) {
|
|
||||||
+ return;
|
|
||||||
+ } else if (noack_success) {
|
|
||||||
+ /* nothing to do here, do not account as lost */
|
|
||||||
+ } else {
|
|
||||||
+ ieee80211_lost_packet(sta, info);
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
|
|
||||||
rate_control_tx_status(local, sband, status);
|
|
||||||
@@ -1197,6 +1162,10 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
ieee80211s_update_metric(local, sta, status);
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (status->skb)
|
|
||||||
+ return __ieee80211_tx_status(hw, status, rates_idx,
|
|
||||||
+ retry_count);
|
|
||||||
+
|
|
||||||
if (acked || noack_success) {
|
|
||||||
I802_DEBUG_INC(local->dot11TransmittedFrameCount);
|
|
||||||
if (!pubsta)
|
|
@ -1,26 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:29:12 +0200
|
|
||||||
Subject: [PATCH] mac80211: remove tx status call to
|
|
||||||
ieee80211_sta_register_airtime
|
|
||||||
|
|
||||||
All drivers using airtime fairness are calling ieee80211_sta_register_airtime
|
|
||||||
directly
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -997,12 +997,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
ieee80211_sta_tx_notify(sta->sdata, (void *) skb->data,
|
|
||||||
acked, info->status.tx_time);
|
|
||||||
|
|
||||||
- if (info->status.tx_time &&
|
|
||||||
- wiphy_ext_feature_isset(local->hw.wiphy,
|
|
||||||
- NL80211_EXT_FEATURE_AIRTIME_FAIRNESS))
|
|
||||||
- ieee80211_sta_register_airtime(&sta->sta, tid,
|
|
||||||
- info->status.tx_time, 0);
|
|
||||||
-
|
|
||||||
if ((tx_time_est = ieee80211_info_get_tx_time_est(info)) > 0) {
|
|
||||||
/* Do this here to avoid the expensive lookup of the sta
|
|
||||||
* in ieee80211_report_used_skb().
|
|
@ -1,174 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:29:56 +0200
|
|
||||||
Subject: [PATCH] mac80211: optimize station connection monitor
|
|
||||||
|
|
||||||
Calling mod_timer for every rx/tx packet can be quite expensive.
|
|
||||||
Instead of constantly updating the timer, we can simply let it run out
|
|
||||||
and check the timestamp of the last ACK or rx packet to re-arm it.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/ieee80211_i.h
|
|
||||||
+++ b/net/mac80211/ieee80211_i.h
|
|
||||||
@@ -2045,8 +2045,6 @@ void ieee80211_dynamic_ps_timer(struct t
|
|
||||||
void ieee80211_send_nullfunc(struct ieee80211_local *local,
|
|
||||||
struct ieee80211_sub_if_data *sdata,
|
|
||||||
bool powersave);
|
|
||||||
-void ieee80211_sta_rx_notify(struct ieee80211_sub_if_data *sdata,
|
|
||||||
- struct ieee80211_hdr *hdr);
|
|
||||||
void ieee80211_sta_tx_notify(struct ieee80211_sub_if_data *sdata,
|
|
||||||
struct ieee80211_hdr *hdr, bool ack, u16 tx_time);
|
|
||||||
|
|
||||||
--- a/net/mac80211/mlme.c
|
|
||||||
+++ b/net/mac80211/mlme.c
|
|
||||||
@@ -2432,23 +2432,6 @@ static void ieee80211_set_disassoc(struc
|
|
||||||
sdata->encrypt_headroom = IEEE80211_ENCRYPT_HEADROOM;
|
|
||||||
}
|
|
||||||
|
|
||||||
-void ieee80211_sta_rx_notify(struct ieee80211_sub_if_data *sdata,
|
|
||||||
- struct ieee80211_hdr *hdr)
|
|
||||||
-{
|
|
||||||
- /*
|
|
||||||
- * We can postpone the mgd.timer whenever receiving unicast frames
|
|
||||||
- * from AP because we know that the connection is working both ways
|
|
||||||
- * at that time. But multicast frames (and hence also beacons) must
|
|
||||||
- * be ignored here, because we need to trigger the timer during
|
|
||||||
- * data idle periods for sending the periodic probe request to the
|
|
||||||
- * AP we're connected to.
|
|
||||||
- */
|
|
||||||
- if (is_multicast_ether_addr(hdr->addr1))
|
|
||||||
- return;
|
|
||||||
-
|
|
||||||
- ieee80211_sta_reset_conn_monitor(sdata);
|
|
||||||
-}
|
|
||||||
-
|
|
||||||
static void ieee80211_reset_ap_probe(struct ieee80211_sub_if_data *sdata)
|
|
||||||
{
|
|
||||||
struct ieee80211_if_managed *ifmgd = &sdata->u.mgd;
|
|
||||||
@@ -2521,21 +2504,13 @@ void ieee80211_sta_tx_notify(struct ieee
|
|
||||||
{
|
|
||||||
ieee80211_sta_tx_wmm_ac_notify(sdata, hdr, tx_time);
|
|
||||||
|
|
||||||
- if (!ieee80211_is_data(hdr->frame_control))
|
|
||||||
- return;
|
|
||||||
-
|
|
||||||
- if (ieee80211_is_any_nullfunc(hdr->frame_control) &&
|
|
||||||
- sdata->u.mgd.probe_send_count > 0) {
|
|
||||||
- if (ack)
|
|
||||||
- ieee80211_sta_reset_conn_monitor(sdata);
|
|
||||||
- else
|
|
||||||
- sdata->u.mgd.nullfunc_failed = true;
|
|
||||||
- ieee80211_queue_work(&sdata->local->hw, &sdata->work);
|
|
||||||
+ if (!ieee80211_is_any_nullfunc(hdr->frame_control) ||
|
|
||||||
+ !sdata->u.mgd.probe_send_count)
|
|
||||||
return;
|
|
||||||
- }
|
|
||||||
|
|
||||||
- if (ack)
|
|
||||||
- ieee80211_sta_reset_conn_monitor(sdata);
|
|
||||||
+ if (!ack)
|
|
||||||
+ sdata->u.mgd.nullfunc_failed = true;
|
|
||||||
+ ieee80211_queue_work(&sdata->local->hw, &sdata->work);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void ieee80211_mlme_send_probe_req(struct ieee80211_sub_if_data *sdata,
|
|
||||||
@@ -3600,8 +3575,8 @@ static bool ieee80211_assoc_success(stru
|
|
||||||
* Start timer to probe the connection to the AP now.
|
|
||||||
* Also start the timer that will detect beacon loss.
|
|
||||||
*/
|
|
||||||
- ieee80211_sta_rx_notify(sdata, (struct ieee80211_hdr *)mgmt);
|
|
||||||
ieee80211_sta_reset_beacon_monitor(sdata);
|
|
||||||
+ ieee80211_sta_reset_conn_monitor(sdata);
|
|
||||||
|
|
||||||
ret = true;
|
|
||||||
out:
|
|
||||||
@@ -4569,10 +4544,26 @@ static void ieee80211_sta_conn_mon_timer
|
|
||||||
from_timer(sdata, t, u.mgd.conn_mon_timer);
|
|
||||||
struct ieee80211_if_managed *ifmgd = &sdata->u.mgd;
|
|
||||||
struct ieee80211_local *local = sdata->local;
|
|
||||||
+ struct sta_info *sta;
|
|
||||||
+ unsigned long timeout;
|
|
||||||
|
|
||||||
if (sdata->vif.csa_active && !ifmgd->csa_waiting_bcn)
|
|
||||||
return;
|
|
||||||
|
|
||||||
+ sta = sta_info_get(sdata, ifmgd->bssid);
|
|
||||||
+ if (!sta)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ timeout = sta->status_stats.last_ack;
|
|
||||||
+ if (time_before(sta->status_stats.last_ack, sta->rx_stats.last_rx))
|
|
||||||
+ timeout = sta->rx_stats.last_rx;
|
|
||||||
+ timeout += IEEE80211_CONNECTION_IDLE_TIME;
|
|
||||||
+
|
|
||||||
+ if (time_is_before_jiffies(timeout)) {
|
|
||||||
+ mod_timer(&ifmgd->conn_mon_timer, round_jiffies_up(timeout));
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
ieee80211_queue_work(&local->hw, &ifmgd->monitor_work);
|
|
||||||
}
|
|
||||||
|
|
||||||
--- a/net/mac80211/rx.c
|
|
||||||
+++ b/net/mac80211/rx.c
|
|
||||||
@@ -1812,9 +1812,6 @@ ieee80211_rx_h_sta_process(struct ieee80
|
|
||||||
sta->rx_stats.last_rate = sta_stats_encode_rate(status);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (rx->sdata->vif.type == NL80211_IFTYPE_STATION)
|
|
||||||
- ieee80211_sta_rx_notify(rx->sdata, hdr);
|
|
||||||
-
|
|
||||||
sta->rx_stats.fragments++;
|
|
||||||
|
|
||||||
u64_stats_update_begin(&rx->sta->rx_stats.syncp);
|
|
||||||
@@ -4149,7 +4146,6 @@ void ieee80211_check_fast_rx(struct sta_
|
|
||||||
fastrx.sa_offs = offsetof(struct ieee80211_hdr, addr2);
|
|
||||||
fastrx.expected_ds_bits = 0;
|
|
||||||
} else {
|
|
||||||
- fastrx.sta_notify = sdata->u.mgd.probe_send_count > 0;
|
|
||||||
fastrx.da_offs = offsetof(struct ieee80211_hdr, addr1);
|
|
||||||
fastrx.sa_offs = offsetof(struct ieee80211_hdr, addr3);
|
|
||||||
fastrx.expected_ds_bits =
|
|
||||||
@@ -4379,11 +4375,6 @@ static bool ieee80211_invoke_fast_rx(str
|
|
||||||
pskb_trim(skb, skb->len - fast_rx->icv_len))
|
|
||||||
goto drop;
|
|
||||||
|
|
||||||
- if (unlikely(fast_rx->sta_notify)) {
|
|
||||||
- ieee80211_sta_rx_notify(rx->sdata, hdr);
|
|
||||||
- fast_rx->sta_notify = false;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
/* statistics part of ieee80211_rx_h_sta_process() */
|
|
||||||
if (!(status->flag & RX_FLAG_NO_SIGNAL_VAL)) {
|
|
||||||
stats->last_signal = status->signal;
|
|
||||||
--- a/net/mac80211/sta_info.h
|
|
||||||
+++ b/net/mac80211/sta_info.h
|
|
||||||
@@ -336,7 +336,6 @@ struct ieee80211_fast_tx {
|
|
||||||
* @expected_ds_bits: from/to DS bits expected
|
|
||||||
* @icv_len: length of the MIC if present
|
|
||||||
* @key: bool indicating encryption is expected (key is set)
|
|
||||||
- * @sta_notify: notify the MLME code (once)
|
|
||||||
* @internal_forward: forward froms internally on AP/VLAN type interfaces
|
|
||||||
* @uses_rss: copy of USES_RSS hw flag
|
|
||||||
* @da_offs: offset of the DA in the header (for header conversion)
|
|
||||||
@@ -352,7 +351,6 @@ struct ieee80211_fast_rx {
|
|
||||||
__le16 expected_ds_bits;
|
|
||||||
u8 icv_len;
|
|
||||||
u8 key:1,
|
|
||||||
- sta_notify:1,
|
|
||||||
internal_forward:1,
|
|
||||||
uses_rss:1;
|
|
||||||
u8 da_offs, sa_offs;
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -1227,9 +1227,6 @@ void ieee80211_tx_status_8023(struct iee
|
|
||||||
sta->status_stats.retry_count += retry_count;
|
|
||||||
|
|
||||||
if (ieee80211_hw_check(hw, REPORTS_TX_ACK_STATUS)) {
|
|
||||||
- if (acked && vif->type == NL80211_IFTYPE_STATION)
|
|
||||||
- ieee80211_sta_reset_conn_monitor(sdata);
|
|
||||||
-
|
|
||||||
sta->status_stats.last_ack = jiffies;
|
|
||||||
if (info->flags & IEEE80211_TX_STAT_ACK) {
|
|
||||||
if (sta->status_stats.lost_packets)
|
|
@ -1,227 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:35:32 +0200
|
|
||||||
Subject: [PATCH] mac80211: swap NEED_TXPROCESSING and HW_80211_ENCAP tx
|
|
||||||
flags
|
|
||||||
|
|
||||||
In order to unify the tx status path, the hw 802.11 encapsulation flag
|
|
||||||
needs to survive the trip to the tx status call.
|
|
||||||
Since we don't have any free bits in info->flags, we need to move one.
|
|
||||||
IEEE80211_TX_INTFL_NEED_TXPROCESSING is only used internally in mac80211,
|
|
||||||
and only before the call into the driver.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath11k/dp_tx.c
|
|
||||||
+++ b/drivers/net/wireless/ath/ath11k/dp_tx.c
|
|
||||||
@@ -14,7 +14,7 @@ ath11k_dp_tx_get_encap_type(struct ath11
|
|
||||||
{
|
|
||||||
struct ieee80211_tx_info *tx_info = IEEE80211_SKB_CB(skb);
|
|
||||||
|
|
||||||
- if (tx_info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP)
|
|
||||||
+ if (tx_info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP)
|
|
||||||
return HAL_TCL_ENCAP_TYPE_ETHERNET;
|
|
||||||
|
|
||||||
return HAL_TCL_ENCAP_TYPE_NATIVE_WIFI;
|
|
||||||
@@ -93,7 +93,7 @@ int ath11k_dp_tx(struct ath11k *ar, stru
|
|
||||||
if (test_bit(ATH11K_FLAG_CRASH_FLUSH, &ar->ab->dev_flags))
|
|
||||||
return -ESHUTDOWN;
|
|
||||||
|
|
||||||
- if (!(info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP) &&
|
|
||||||
+ if (!(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP) &&
|
|
||||||
!ieee80211_is_data(hdr->frame_control))
|
|
||||||
return -ENOTSUPP;
|
|
||||||
|
|
||||||
--- a/drivers/net/wireless/ath/ath11k/mac.c
|
|
||||||
+++ b/drivers/net/wireless/ath/ath11k/mac.c
|
|
||||||
@@ -3749,7 +3749,7 @@ static int ath11k_mac_mgmt_tx_wmi(struct
|
|
||||||
return -ENOSPC;
|
|
||||||
|
|
||||||
info = IEEE80211_SKB_CB(skb);
|
|
||||||
- if (!(info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP)) {
|
|
||||||
+ if (!(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP)) {
|
|
||||||
if ((ieee80211_is_action(hdr->frame_control) ||
|
|
||||||
ieee80211_is_deauth(hdr->frame_control) ||
|
|
||||||
ieee80211_is_disassoc(hdr->frame_control)) &&
|
|
||||||
@@ -3876,7 +3876,7 @@ static void ath11k_mac_op_tx(struct ieee
|
|
||||||
bool is_prb_rsp;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
- if (info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP) {
|
|
||||||
+ if (info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP) {
|
|
||||||
skb_cb->flags |= ATH11K_SKB_HW_80211_ENCAP;
|
|
||||||
} else if (ieee80211_is_mgmt(hdr->frame_control)) {
|
|
||||||
is_prb_rsp = ieee80211_is_probe_resp(hdr->frame_control);
|
|
||||||
--- a/include/net/mac80211.h
|
|
||||||
+++ b/include/net/mac80211.h
|
|
||||||
@@ -720,9 +720,8 @@ struct ieee80211_bss_conf {
|
|
||||||
* @IEEE80211_TX_INTFL_OFFCHAN_TX_OK: Internal to mac80211. Used to indicate
|
|
||||||
* that a frame can be transmitted while the queues are stopped for
|
|
||||||
* off-channel operation.
|
|
||||||
- * @IEEE80211_TX_INTFL_NEED_TXPROCESSING: completely internal to mac80211,
|
|
||||||
- * used to indicate that a pending frame requires TX processing before
|
|
||||||
- * it can be sent out.
|
|
||||||
+ * @IEEE80211_TX_CTL_HW_80211_ENCAP: This frame uses hardware encapsulation
|
|
||||||
+ * (header conversion)
|
|
||||||
* @IEEE80211_TX_INTFL_RETRIED: completely internal to mac80211,
|
|
||||||
* used to indicate that a frame was already retried due to PS
|
|
||||||
* @IEEE80211_TX_INTFL_DONT_ENCRYPT: completely internal to mac80211,
|
|
||||||
@@ -791,7 +790,7 @@ enum mac80211_tx_info_flags {
|
|
||||||
IEEE80211_TX_STAT_AMPDU_NO_BACK = BIT(11),
|
|
||||||
IEEE80211_TX_CTL_RATE_CTRL_PROBE = BIT(12),
|
|
||||||
IEEE80211_TX_INTFL_OFFCHAN_TX_OK = BIT(13),
|
|
||||||
- IEEE80211_TX_INTFL_NEED_TXPROCESSING = BIT(14),
|
|
||||||
+ IEEE80211_TX_CTL_HW_80211_ENCAP = BIT(14),
|
|
||||||
IEEE80211_TX_INTFL_RETRIED = BIT(15),
|
|
||||||
IEEE80211_TX_INTFL_DONT_ENCRYPT = BIT(16),
|
|
||||||
IEEE80211_TX_CTL_NO_PS_BUFFER = BIT(17),
|
|
||||||
@@ -823,8 +822,9 @@ enum mac80211_tx_info_flags {
|
|
||||||
* @IEEE80211_TX_CTRL_AMSDU: This frame is an A-MSDU frame
|
|
||||||
* @IEEE80211_TX_CTRL_FAST_XMIT: This frame is going through the fast_xmit path
|
|
||||||
* @IEEE80211_TX_CTRL_SKIP_MPATH_LOOKUP: This frame skips mesh path lookup
|
|
||||||
- * @IEEE80211_TX_CTRL_HW_80211_ENCAP: This frame uses hardware encapsulation
|
|
||||||
- * (header conversion)
|
|
||||||
+ * @IEEE80211_TX_INTCFL_NEED_TXPROCESSING: completely internal to mac80211,
|
|
||||||
+ * used to indicate that a pending frame requires TX processing before
|
|
||||||
+ * it can be sent out.
|
|
||||||
*
|
|
||||||
* These flags are used in tx_info->control.flags.
|
|
||||||
*/
|
|
||||||
@@ -835,7 +835,7 @@ enum mac80211_tx_control_flags {
|
|
||||||
IEEE80211_TX_CTRL_AMSDU = BIT(3),
|
|
||||||
IEEE80211_TX_CTRL_FAST_XMIT = BIT(4),
|
|
||||||
IEEE80211_TX_CTRL_SKIP_MPATH_LOOKUP = BIT(5),
|
|
||||||
- IEEE80211_TX_CTRL_HW_80211_ENCAP = BIT(6),
|
|
||||||
+ IEEE80211_TX_INTCFL_NEED_TXPROCESSING = BIT(6),
|
|
||||||
};
|
|
||||||
|
|
||||||
/*
|
|
||||||
--- a/net/mac80211/mesh_hwmp.c
|
|
||||||
+++ b/net/mac80211/mesh_hwmp.c
|
|
||||||
@@ -212,7 +212,7 @@ static void prepare_frame_for_deferred_t
|
|
||||||
skb->priority = 7;
|
|
||||||
|
|
||||||
info->control.vif = &sdata->vif;
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
ieee80211_set_qos_hdr(sdata, skb);
|
|
||||||
ieee80211_mps_set_frame_flags(sdata, NULL, hdr);
|
|
||||||
}
|
|
||||||
@@ -1163,7 +1163,7 @@ int mesh_nexthop_resolve(struct ieee8021
|
|
||||||
if (skb_queue_len(&mpath->frame_queue) >= MESH_FRAME_QUEUE_LEN)
|
|
||||||
skb_to_free = skb_dequeue(&mpath->frame_queue);
|
|
||||||
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
ieee80211_set_qos_hdr(sdata, skb);
|
|
||||||
skb_queue_tail(&mpath->frame_queue, skb);
|
|
||||||
if (skb_to_free)
|
|
||||||
--- a/net/mac80211/mesh_ps.c
|
|
||||||
+++ b/net/mac80211/mesh_ps.c
|
|
||||||
@@ -432,7 +432,7 @@ static void mpsp_qos_null_append(struct
|
|
||||||
|
|
||||||
info = IEEE80211_SKB_CB(new_skb);
|
|
||||||
info->control.vif = &sdata->vif;
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
|
|
||||||
__skb_queue_tail(frames, new_skb);
|
|
||||||
}
|
|
||||||
--- a/net/mac80211/rx.c
|
|
||||||
+++ b/net/mac80211/rx.c
|
|
||||||
@@ -2897,7 +2897,7 @@ ieee80211_rx_h_mesh_fwding(struct ieee80
|
|
||||||
fwd_hdr->frame_control &= ~cpu_to_le16(IEEE80211_FCTL_RETRY);
|
|
||||||
info = IEEE80211_SKB_CB(fwd_skb);
|
|
||||||
memset(info, 0, sizeof(*info));
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
info->control.vif = &rx->sdata->vif;
|
|
||||||
info->control.jiffies = jiffies;
|
|
||||||
if (is_multicast_ether_addr(fwd_hdr->addr1)) {
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -66,8 +66,8 @@ static void ieee80211_handle_filtered_fr
|
|
||||||
|
|
||||||
info->control.jiffies = jiffies;
|
|
||||||
info->control.vif = &sta->sdata->vif;
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING |
|
|
||||||
- IEEE80211_TX_INTFL_RETRANSMISSION;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
+ info->flags |= IEEE80211_TX_INTFL_RETRANSMISSION;
|
|
||||||
info->flags &= ~IEEE80211_TX_TEMPORARY_FLAGS;
|
|
||||||
|
|
||||||
sta->status_stats.filtered++;
|
|
||||||
--- a/net/mac80211/tx.c
|
|
||||||
+++ b/net/mac80211/tx.c
|
|
||||||
@@ -530,7 +530,7 @@ ieee80211_tx_h_unicast_ps_buf(struct iee
|
|
||||||
|
|
||||||
info->control.jiffies = jiffies;
|
|
||||||
info->control.vif = &tx->sdata->vif;
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
info->flags &= ~IEEE80211_TX_TEMPORARY_FLAGS;
|
|
||||||
skb_queue_tail(&sta->ps_tx_buf[ac], tx->skb);
|
|
||||||
spin_unlock(&sta->ps_lock);
|
|
||||||
@@ -1132,7 +1132,7 @@ static bool ieee80211_tx_prep_agg(struct
|
|
||||||
tx->sta->sta.addr, tx->sta->sta.aid);
|
|
||||||
}
|
|
||||||
info->control.vif = &tx->sdata->vif;
|
|
||||||
- info->flags |= IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags |= IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
info->flags &= ~IEEE80211_TX_TEMPORARY_FLAGS;
|
|
||||||
__skb_queue_tail(&tid_tx->pending, skb);
|
|
||||||
if (skb_queue_len(&tid_tx->pending) > STA_MAX_TX_BUFFER)
|
|
||||||
@@ -1177,7 +1177,7 @@ ieee80211_tx_prepare(struct ieee80211_su
|
|
||||||
* we are doing the needed processing, so remove the flag
|
|
||||||
* now.
|
|
||||||
*/
|
|
||||||
- info->flags &= ~IEEE80211_TX_INTFL_NEED_TXPROCESSING;
|
|
||||||
+ info->control.flags &= ~IEEE80211_TX_INTCFL_NEED_TXPROCESSING;
|
|
||||||
|
|
||||||
hdr = (struct ieee80211_hdr *) skb->data;
|
|
||||||
|
|
||||||
@@ -1256,7 +1256,7 @@ static struct txq_info *ieee80211_get_tx
|
|
||||||
(info->control.flags & IEEE80211_TX_CTRL_PS_RESPONSE))
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
- if (!(info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP) &&
|
|
||||||
+ if (!(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP) &&
|
|
||||||
unlikely(!ieee80211_is_data_present(hdr->frame_control))) {
|
|
||||||
if ((!ieee80211_is_mgmt(hdr->frame_control) ||
|
|
||||||
ieee80211_is_bufferable_mmpdu(hdr->frame_control) ||
|
|
||||||
@@ -3640,7 +3640,7 @@ begin:
|
|
||||||
else
|
|
||||||
info->flags &= ~IEEE80211_TX_CTL_AMPDU;
|
|
||||||
|
|
||||||
- if (info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP)
|
|
||||||
+ if (info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP)
|
|
||||||
goto encap_out;
|
|
||||||
|
|
||||||
if (info->control.flags & IEEE80211_TX_CTRL_FAST_XMIT) {
|
|
||||||
@@ -4230,7 +4230,7 @@ static void ieee80211_8023_xmit(struct i
|
|
||||||
sdata = container_of(sdata->bss,
|
|
||||||
struct ieee80211_sub_if_data, u.ap);
|
|
||||||
|
|
||||||
- info->control.flags |= IEEE80211_TX_CTRL_HW_80211_ENCAP;
|
|
||||||
+ info->flags |= IEEE80211_TX_CTL_HW_80211_ENCAP;
|
|
||||||
info->control.vif = &sdata->vif;
|
|
||||||
|
|
||||||
if (key)
|
|
||||||
@@ -4355,7 +4355,7 @@ static bool ieee80211_tx_pending_skb(str
|
|
||||||
|
|
||||||
sdata = vif_to_sdata(info->control.vif);
|
|
||||||
|
|
||||||
- if (info->flags & IEEE80211_TX_INTFL_NEED_TXPROCESSING) {
|
|
||||||
+ if (info->control.flags & IEEE80211_TX_INTCFL_NEED_TXPROCESSING) {
|
|
||||||
chanctx_conf = rcu_dereference(sdata->vif.chanctx_conf);
|
|
||||||
if (unlikely(!chanctx_conf)) {
|
|
||||||
dev_kfree_skb(skb);
|
|
||||||
@@ -4363,7 +4363,7 @@ static bool ieee80211_tx_pending_skb(str
|
|
||||||
}
|
|
||||||
info->band = chanctx_conf->def.chan->band;
|
|
||||||
result = ieee80211_tx(sdata, NULL, skb, true, 0);
|
|
||||||
- } else if (info->control.flags & IEEE80211_TX_CTRL_HW_80211_ENCAP) {
|
|
||||||
+ } else if (info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP) {
|
|
||||||
if (ieee80211_lookup_ra_sta(sdata, skb, &sta)) {
|
|
||||||
dev_kfree_skb(skb);
|
|
||||||
return true;
|
|
@ -1,159 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Mon, 17 Aug 2020 13:54:19 +0200
|
|
||||||
Subject: [PATCH] mac80211: unify 802.3 (offload) and 802.11 tx status
|
|
||||||
codepath
|
|
||||||
|
|
||||||
Make ieee80211_tx_status_8023 call ieee80211_tx_status_ext, similar to
|
|
||||||
ieee80211_tx_status.
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -903,7 +903,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
struct ieee80211_bar *bar;
|
|
||||||
int shift = 0;
|
|
||||||
int tid = IEEE80211_NUM_TIDS;
|
|
||||||
- u16 tx_time_est;
|
|
||||||
|
|
||||||
sband = local->hw.wiphy->bands[info->band];
|
|
||||||
fc = hdr->frame_control;
|
|
||||||
@@ -996,17 +995,6 @@ static void __ieee80211_tx_status(struct
|
|
||||||
ieee80211_hw_check(&local->hw, REPORTS_TX_ACK_STATUS))
|
|
||||||
ieee80211_sta_tx_notify(sta->sdata, (void *) skb->data,
|
|
||||||
acked, info->status.tx_time);
|
|
||||||
-
|
|
||||||
- if ((tx_time_est = ieee80211_info_get_tx_time_est(info)) > 0) {
|
|
||||||
- /* Do this here to avoid the expensive lookup of the sta
|
|
||||||
- * in ieee80211_report_used_skb().
|
|
||||||
- */
|
|
||||||
- ieee80211_sta_update_pending_airtime(local, sta,
|
|
||||||
- skb_get_queue_mapping(skb),
|
|
||||||
- tx_time_est,
|
|
||||||
- true);
|
|
||||||
- ieee80211_info_set_tx_time_est(info, 0);
|
|
||||||
- }
|
|
||||||
}
|
|
||||||
|
|
||||||
/* SNMP counters
|
|
||||||
@@ -1102,9 +1090,11 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
struct ieee80211_tx_info *info = status->info;
|
|
||||||
struct ieee80211_sta *pubsta = status->sta;
|
|
||||||
struct ieee80211_supported_band *sband;
|
|
||||||
- struct sta_info *sta;
|
|
||||||
+ struct sk_buff *skb = status->skb;
|
|
||||||
+ struct sta_info *sta = NULL;
|
|
||||||
int rates_idx, retry_count;
|
|
||||||
bool acked, noack_success;
|
|
||||||
+ u16 tx_time_est;
|
|
||||||
|
|
||||||
if (pubsta) {
|
|
||||||
sta = container_of(pubsta, struct sta_info, sta);
|
|
||||||
@@ -1156,7 +1146,18 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
ieee80211s_update_metric(local, sta, status);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (status->skb)
|
|
||||||
+ if (skb && (tx_time_est = ieee80211_info_get_tx_time_est(info)) > 0) {
|
|
||||||
+ /* Do this here to avoid the expensive lookup of the sta
|
|
||||||
+ * in ieee80211_report_used_skb().
|
|
||||||
+ */
|
|
||||||
+ ieee80211_sta_update_pending_airtime(local, sta,
|
|
||||||
+ skb_get_queue_mapping(skb),
|
|
||||||
+ tx_time_est,
|
|
||||||
+ true);
|
|
||||||
+ ieee80211_info_set_tx_time_est(info, 0);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (skb && !(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP))
|
|
||||||
return __ieee80211_tx_status(hw, status, rates_idx,
|
|
||||||
retry_count);
|
|
||||||
|
|
||||||
@@ -1171,6 +1172,12 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
} else {
|
|
||||||
I802_DEBUG_INC(local->dot11FailedCount);
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ if (!skb)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ ieee80211_report_used_skb(local, skb, false);
|
|
||||||
+ dev_kfree_skb(skb);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(ieee80211_tx_status_ext);
|
|
||||||
|
|
||||||
@@ -1197,66 +1204,23 @@ void ieee80211_tx_status_8023(struct iee
|
|
||||||
struct ieee80211_vif *vif,
|
|
||||||
struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
- struct ieee80211_local *local = hw_to_local(hw);
|
|
||||||
struct ieee80211_sub_if_data *sdata;
|
|
||||||
- struct ieee80211_tx_info *info = IEEE80211_SKB_CB(skb);
|
|
||||||
+ struct ieee80211_tx_status status = {
|
|
||||||
+ .skb = skb,
|
|
||||||
+ .info = IEEE80211_SKB_CB(skb),
|
|
||||||
+ };
|
|
||||||
struct sta_info *sta;
|
|
||||||
- int retry_count;
|
|
||||||
- int rates_idx;
|
|
||||||
- bool acked;
|
|
||||||
|
|
||||||
sdata = vif_to_sdata(vif);
|
|
||||||
|
|
||||||
- acked = info->flags & IEEE80211_TX_STAT_ACK;
|
|
||||||
- rates_idx = ieee80211_tx_get_rates(hw, info, &retry_count);
|
|
||||||
-
|
|
||||||
rcu_read_lock();
|
|
||||||
|
|
||||||
- if (ieee80211_lookup_ra_sta(sdata, skb, &sta))
|
|
||||||
- goto counters_update;
|
|
||||||
-
|
|
||||||
- if (IS_ERR(sta))
|
|
||||||
- goto counters_update;
|
|
||||||
-
|
|
||||||
- if (!acked)
|
|
||||||
- sta->status_stats.retry_failed++;
|
|
||||||
-
|
|
||||||
- if (rates_idx != -1)
|
|
||||||
- sta->tx_stats.last_rate = info->status.rates[rates_idx];
|
|
||||||
-
|
|
||||||
- sta->status_stats.retry_count += retry_count;
|
|
||||||
-
|
|
||||||
- if (ieee80211_hw_check(hw, REPORTS_TX_ACK_STATUS)) {
|
|
||||||
- sta->status_stats.last_ack = jiffies;
|
|
||||||
- if (info->flags & IEEE80211_TX_STAT_ACK) {
|
|
||||||
- if (sta->status_stats.lost_packets)
|
|
||||||
- sta->status_stats.lost_packets = 0;
|
|
||||||
+ if (!ieee80211_lookup_ra_sta(sdata, skb, &sta) && !IS_ERR(sta))
|
|
||||||
+ status.sta = &sta->sta;
|
|
||||||
|
|
||||||
- sta->status_stats.last_pkt_time = jiffies;
|
|
||||||
- } else {
|
|
||||||
- ieee80211_lost_packet(sta, info);
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
+ ieee80211_tx_status_ext(hw, &status);
|
|
||||||
|
|
||||||
-counters_update:
|
|
||||||
rcu_read_unlock();
|
|
||||||
- ieee80211_led_tx(local);
|
|
||||||
-
|
|
||||||
- if (!(info->flags & IEEE80211_TX_STAT_ACK) &&
|
|
||||||
- !(info->flags & IEEE80211_TX_STAT_NOACK_TRANSMITTED))
|
|
||||||
- goto skip_stats_update;
|
|
||||||
-
|
|
||||||
- I802_DEBUG_INC(local->dot11TransmittedFrameCount);
|
|
||||||
- if (is_multicast_ether_addr(skb->data))
|
|
||||||
- I802_DEBUG_INC(local->dot11MulticastTransmittedFrameCount);
|
|
||||||
- if (retry_count > 0)
|
|
||||||
- I802_DEBUG_INC(local->dot11RetryCount);
|
|
||||||
- if (retry_count > 1)
|
|
||||||
- I802_DEBUG_INC(local->dot11MultipleRetryCount);
|
|
||||||
-
|
|
||||||
-skip_stats_update:
|
|
||||||
- ieee80211_report_used_skb(local, skb, false);
|
|
||||||
- dev_kfree_skb(skb);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(ieee80211_tx_status_8023);
|
|
||||||
|
|
@ -1,63 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Thu, 20 Aug 2020 17:27:00 +0200
|
|
||||||
Subject: [PATCH] mac80211: support using ieee80211_tx_status_ext to free
|
|
||||||
skbs without status info
|
|
||||||
|
|
||||||
For encap-offloaded packets, ieee80211_free_txskb cannot be used, since it
|
|
||||||
does not have the vif pointer.
|
|
||||||
Using ieee80211_tx_status_ext for this purpose has the advantage of being able
|
|
||||||
avoid an extra station lookup for AQL
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -1103,6 +1103,21 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
sta->tx_stats.last_rate_info = *status->rate;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (skb && (tx_time_est =
|
|
||||||
+ ieee80211_info_get_tx_time_est(IEEE80211_SKB_CB(skb))) > 0) {
|
|
||||||
+ /* Do this here to avoid the expensive lookup of the sta
|
|
||||||
+ * in ieee80211_report_used_skb().
|
|
||||||
+ */
|
|
||||||
+ ieee80211_sta_update_pending_airtime(local, sta,
|
|
||||||
+ skb_get_queue_mapping(skb),
|
|
||||||
+ tx_time_est,
|
|
||||||
+ true);
|
|
||||||
+ ieee80211_info_set_tx_time_est(IEEE80211_SKB_CB(skb), 0);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (!status->info)
|
|
||||||
+ goto free;
|
|
||||||
+
|
|
||||||
rates_idx = ieee80211_tx_get_rates(hw, info, &retry_count);
|
|
||||||
|
|
||||||
sband = hw->wiphy->bands[info->band];
|
|
||||||
@@ -1146,17 +1161,6 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
ieee80211s_update_metric(local, sta, status);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (skb && (tx_time_est = ieee80211_info_get_tx_time_est(info)) > 0) {
|
|
||||||
- /* Do this here to avoid the expensive lookup of the sta
|
|
||||||
- * in ieee80211_report_used_skb().
|
|
||||||
- */
|
|
||||||
- ieee80211_sta_update_pending_airtime(local, sta,
|
|
||||||
- skb_get_queue_mapping(skb),
|
|
||||||
- tx_time_est,
|
|
||||||
- true);
|
|
||||||
- ieee80211_info_set_tx_time_est(info, 0);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if (skb && !(info->flags & IEEE80211_TX_CTL_HW_80211_ENCAP))
|
|
||||||
return __ieee80211_tx_status(hw, status, rates_idx,
|
|
||||||
retry_count);
|
|
||||||
@@ -1173,6 +1177,7 @@ void ieee80211_tx_status_ext(struct ieee
|
|
||||||
I802_DEBUG_INC(local->dot11FailedCount);
|
|
||||||
}
|
|
||||||
|
|
||||||
+free:
|
|
||||||
if (!skb)
|
|
||||||
return;
|
|
||||||
|
|
@ -1,53 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 21 Aug 2020 05:49:07 +0200
|
|
||||||
Subject: [PATCH] mac80211: extend ieee80211_tx_status_ext to support
|
|
||||||
bulk free
|
|
||||||
|
|
||||||
Store processed skbs ready to be freed in a list so the driver bulk free them
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/include/net/mac80211.h
|
|
||||||
+++ b/include/net/mac80211.h
|
|
||||||
@@ -1092,12 +1092,14 @@ ieee80211_info_get_tx_time_est(struct ie
|
|
||||||
* @info: Basic tx status information
|
|
||||||
* @skb: Packet skb (can be NULL if not provided by the driver)
|
|
||||||
* @rate: The TX rate that was used when sending the packet
|
|
||||||
+ * @free_list: list where processed skbs are stored to be free'd by the driver
|
|
||||||
*/
|
|
||||||
struct ieee80211_tx_status {
|
|
||||||
struct ieee80211_sta *sta;
|
|
||||||
struct ieee80211_tx_info *info;
|
|
||||||
struct sk_buff *skb;
|
|
||||||
struct rate_info *rate;
|
|
||||||
+ struct list_head *free_list;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
--- a/net/mac80211/status.c
|
|
||||||
+++ b/net/mac80211/status.c
|
|
||||||
@@ -1053,7 +1053,10 @@ static void __ieee80211_tx_status(struct
|
|
||||||
* with this test...
|
|
||||||
*/
|
|
||||||
if (!local->monitors && (!send_to_cooked || !local->cooked_mntrs)) {
|
|
||||||
- dev_kfree_skb(skb);
|
|
||||||
+ if (status->free_list)
|
|
||||||
+ list_add_tail(&skb->list, status->free_list);
|
|
||||||
+ else
|
|
||||||
+ dev_kfree_skb(skb);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1182,7 +1185,10 @@ free:
|
|
||||||
return;
|
|
||||||
|
|
||||||
ieee80211_report_used_skb(local, skb, false);
|
|
||||||
- dev_kfree_skb(skb);
|
|
||||||
+ if (status->free_list)
|
|
||||||
+ list_add_tail(&skb->list, status->free_list);
|
|
||||||
+ else
|
|
||||||
+ dev_kfree_skb(skb);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(ieee80211_tx_status_ext);
|
|
||||||
|
|
@ -1,109 +0,0 @@
|
|||||||
From: Felix Fietkau <nbd@nbd.name>
|
|
||||||
Date: Fri, 21 Aug 2020 05:51:58 +0200
|
|
||||||
Subject: [PATCH] mac80211: notify the driver when a sta uses 4-address
|
|
||||||
mode
|
|
||||||
|
|
||||||
This is needed for encapsulation offload of 4-address mode packets
|
|
||||||
|
|
||||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
|
||||||
---
|
|
||||||
|
|
||||||
--- a/include/net/mac80211.h
|
|
||||||
+++ b/include/net/mac80211.h
|
|
||||||
@@ -3840,6 +3840,8 @@ enum ieee80211_reconfig_type {
|
|
||||||
* This callback may sleep.
|
|
||||||
* @update_vif_config: Update virtual interface offload flags
|
|
||||||
* This callback may sleep.
|
|
||||||
+ * @sta_set_4addr: Called to notify the driver when a station starts/stops using
|
|
||||||
+ * 4-address mode
|
|
||||||
*/
|
|
||||||
struct ieee80211_ops {
|
|
||||||
void (*tx)(struct ieee80211_hw *hw,
|
|
||||||
@@ -4153,6 +4155,8 @@ struct ieee80211_ops {
|
|
||||||
struct ieee80211_sta *sta, u8 tids);
|
|
||||||
void (*update_vif_offload)(struct ieee80211_hw *hw,
|
|
||||||
struct ieee80211_vif *vif);
|
|
||||||
+ void (*sta_set_4addr)(struct ieee80211_hw *hw, struct ieee80211_vif *vif,
|
|
||||||
+ struct ieee80211_sta *sta, bool enabled);
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
--- a/net/mac80211/cfg.c
|
|
||||||
+++ b/net/mac80211/cfg.c
|
|
||||||
@@ -1694,6 +1694,7 @@ static int ieee80211_change_station(stru
|
|
||||||
|
|
||||||
rcu_assign_pointer(vlansdata->u.vlan.sta, sta);
|
|
||||||
__ieee80211_check_fast_rx_iface(vlansdata);
|
|
||||||
+ drv_sta_set_4addr(local, sta->sdata, &sta->sta, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (sta->sdata->vif.type == NL80211_IFTYPE_AP_VLAN &&
|
|
||||||
--- a/net/mac80211/driver-ops.h
|
|
||||||
+++ b/net/mac80211/driver-ops.h
|
|
||||||
@@ -1400,4 +1400,18 @@ static inline void drv_update_vif_offloa
|
|
||||||
trace_drv_return_void(local);
|
|
||||||
}
|
|
||||||
|
|
||||||
+static inline void drv_sta_set_4addr(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata,
|
|
||||||
+ struct ieee80211_sta *sta, bool enabled)
|
|
||||||
+{
|
|
||||||
+ sdata = get_bss_sdata(sdata);
|
|
||||||
+ if (!check_sdata_in_driver(sdata))
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ trace_drv_sta_set_4addr(local, sdata, sta, enabled);
|
|
||||||
+ if (local->ops->sta_set_4addr)
|
|
||||||
+ local->ops->sta_set_4addr(&local->hw, &sdata->vif, sta, enabled);
|
|
||||||
+ trace_drv_return_void(local);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
#endif /* __MAC80211_DRIVER_OPS */
|
|
||||||
--- a/net/mac80211/mlme.c
|
|
||||||
+++ b/net/mac80211/mlme.c
|
|
||||||
@@ -3518,6 +3518,9 @@ static bool ieee80211_assoc_success(stru
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ if (sdata->wdev.use_4addr)
|
|
||||||
+ drv_sta_set_4addr(local, sdata, &sta->sta, true);
|
|
||||||
+
|
|
||||||
mutex_unlock(&sdata->local->sta_mtx);
|
|
||||||
|
|
||||||
/*
|
|
||||||
--- a/net/mac80211/trace.h
|
|
||||||
+++ b/net/mac80211/trace.h
|
|
||||||
@@ -2739,6 +2739,33 @@ DEFINE_EVENT(local_sdata_addr_evt, drv_u
|
|
||||||
TP_ARGS(local, sdata)
|
|
||||||
);
|
|
||||||
|
|
||||||
+TRACE_EVENT(drv_sta_set_4addr,
|
|
||||||
+ TP_PROTO(struct ieee80211_local *local,
|
|
||||||
+ struct ieee80211_sub_if_data *sdata,
|
|
||||||
+ struct ieee80211_sta *sta, bool enabled),
|
|
||||||
+
|
|
||||||
+ TP_ARGS(local, sdata, sta, enabled),
|
|
||||||
+
|
|
||||||
+ TP_STRUCT__entry(
|
|
||||||
+ LOCAL_ENTRY
|
|
||||||
+ VIF_ENTRY
|
|
||||||
+ STA_ENTRY
|
|
||||||
+ __field(bool, enabled)
|
|
||||||
+ ),
|
|
||||||
+
|
|
||||||
+ TP_fast_assign(
|
|
||||||
+ LOCAL_ASSIGN;
|
|
||||||
+ VIF_ASSIGN;
|
|
||||||
+ STA_ASSIGN;
|
|
||||||
+ __entry->enabled = enabled;
|
|
||||||
+ ),
|
|
||||||
+
|
|
||||||
+ TP_printk(
|
|
||||||
+ LOCAL_PR_FMT VIF_PR_FMT STA_PR_FMT " enabled:%d",
|
|
||||||
+ LOCAL_PR_ARG, VIF_PR_ARG, STA_PR_ARG, __entry->enabled
|
|
||||||
+ )
|
|
||||||
+);
|
|
||||||
+
|
|
||||||
#endif /* !__MAC80211_DRIVER_TRACE || TRACE_HEADER_MULTI_READ */
|
|
||||||
|
|
||||||
#undef TRACE_INCLUDE_PATH
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user