From: Kalle Valo <kvalo@qca.qualcomm.com>
To: linux-wireless@vger.kernel.org
Cc: joe@perches.com, devel@linuxdriverproject.org, gregkh@suse.de,
error27@gmail.com
Subject: [PATCH v2 00/23] ath6kl cleaned up driver
Date: Sun, 17 Jul 2011 13:20:07 +0300 [thread overview]
Message-ID: <20110717101844.18367.44984.stgit@localhost6.localdomain6> (raw)
Hello,
last May we started working on cleaning up ath6kl driver which is
currently in staging. The work has happened in a separate
ath6kl-cleanup tree:
http://git.kernel.org/?p=linux/kernel/git/kvalo/ath6kl-cleanup.git;a=summary
After over 1100 (!) patches we have now reached a state where I would
like to start discussing about pushing the driver to the wireless
trees and replacing the staging driver.
The driver is now a lot smaller and looks like a proper Linux driver.
For example, I'm now a lot more comfortable working with this driver
than the staging driver. The size of the driver (measured with simple
wc -l) dropped from 49 kLOC to 19 kLOC and the number of the .c and .h
files dropped from 107 to 23. Most importantly the number of
subdirectories reduced from 26 to zero :)
There are two remaining checkpatch warnings in the driver which we
decided to omit for now:
drivers/net/wireless/ath/ath6kl/debug.c:31:
WARNING: printk() should include KERN_ facility level
drivers/net/wireless/ath/ath6kl/sdio.c:527:
WARNING: msleep < 20ms can sleep for up to 20ms;
see Documentation/timers/timers-howto.txt
The driver has endian annotations for all the hardware specific
structures and there are no sparse errors. Unfortunately I don't have
any big endian hardware to test that but we are trying find something.
We have been testing the driver both on x86 and arm platforms. The
code is also compiled with sparc and parisc cross compilers.
Notable missing features compared to the current staging driver are:
o HCI over SDIO support
o nl80211 testmode
o firmware logging
o suspend support (forgot to mention this in v1)
Testmode, firmware logging and suspend support will be added soon. HCI
over SDIO support will be more difficult as the HCI driver needs to
share code with the wifi driver. This is something we need to research
more.
Even we have done a lot of cleanup, it's still not fully finished. The
todo list is available here:
http://wireless.kernel.org/en/users/Drivers/ath6kl/todo
The most important tasks left are:
o proper review of locking (currently 13 spin locks and one semaphore)
o excessive use of void pointers
But I think these cleanups can happen in wireless-testing tree as
well. There is no need to keep the driver out-of-tree anymore as the
changes should be pretty small compared to the changes we had until
now.
Also I want to point out the changes I did for signed endian support.
As I wasn't able to find any support for signed endian annotations I
decided to follow what NTFS has done and added my own. Grep for sle16
and sle32, especially from wmi.h.
Various people have been working on the cleanup, the hall of
fame based on number of patches is:
543 Vasanthakumar Thiagarajan
403 Raja Mani
244 Kalle Valo
16 Vivek Natarajan
12 Suraj Sumangala
2 Jouni Malinen
I'm sending the patch in multiple emails, one file per message, to
make it easier to review. The driver is also available as one patch to
make it easier for John to commit:
http://www.kernel.org/pub/linux/kernel/people/kvalo/ath6kl/ath6kl-201107171240.patch
Note: these patches now depend on my patch "ieee80211: add few wmm
tspec values" which I sent earlier today.
Please review and comment. John, please consider taking this driver to
wireless-testing.
Kalle
Changes from v1:
o don't split log messages (kvalo)
o use wmi prefix in wmi.c (raja)
o smatch fixes (vasanth)
o use only public ieee80211 defines and remove ieee80211.h (kvalo)
---
Kalle Valo (23):
ath6kl: add bmi.c
ath6kl: add bmi.h
ath6kl: add cfg80211.c
ath6kl: add cfg80211.h
ath6kl: add common.h
ath6kl: add core.h
ath6kl: add debug.c
ath6kl: add debug.h
ath6kl: add hif-ops.h
ath6kl: add hif.h
ath6kl: add htc.c
ath6kl: add htc.h
ath6kl: add htc_hif.c
ath6kl: add htc_hif.h
ath6kl: add init.c
ath6kl: add main.c
ath6kl: add node.c
ath6kl: add sdio.c
ath6kl: add target.h
ath6kl: add txrx.c
ath6kl: add wmi.c
ath6kl: add wmi.h
ath6kl: add Kconfig and Makefile
drivers/net/wireless/ath/Kconfig | 1
drivers/net/wireless/ath/Makefile | 1
drivers/net/wireless/ath/ath6kl/Kconfig | 17
drivers/net/wireless/ath/ath6kl/Makefile | 35
drivers/net/wireless/ath/ath6kl/bmi.c | 692 +++++++
drivers/net/wireless/ath/ath6kl/bmi.h | 250 +++
drivers/net/wireless/ath/ath6kl/cfg80211.c | 1651 +++++++++++++++++
drivers/net/wireless/ath/ath6kl/cfg80211.h | 39
drivers/net/wireless/ath/ath6kl/common.h | 183 ++
drivers/net/wireless/ath/ath6kl/core.h | 544 ++++++
drivers/net/wireless/ath/ath6kl/debug.c | 150 ++
drivers/net/wireless/ath/ath6kl/debug.h | 104 +
drivers/net/wireless/ath/ath6kl/hif-ops.h | 67 +
drivers/net/wireless/ath/ath6kl/hif.h | 214 ++
drivers/net/wireless/ath/ath6kl/htc.c | 2469 +++++++++++++++++++++++++
drivers/net/wireless/ath/ath6kl/htc.h | 596 ++++++
drivers/net/wireless/ath/ath6kl/htc_hif.c | 812 ++++++++
drivers/net/wireless/ath/ath6kl/htc_hif.h | 113 +
drivers/net/wireless/ath/ath6kl/init.c | 1312 +++++++++++++
drivers/net/wireless/ath/ath6kl/main.c | 1339 ++++++++++++++
drivers/net/wireless/ath/ath6kl/node.c | 238 ++
drivers/net/wireless/ath/ath6kl/sdio.c | 853 +++++++++
drivers/net/wireless/ath/ath6kl/target.h | 331 +++
drivers/net/wireless/ath/ath6kl/txrx.c | 1453 +++++++++++++++
drivers/net/wireless/ath/ath6kl/wmi.c | 2761 ++++++++++++++++++++++++++++
drivers/net/wireless/ath/ath6kl/wmi.h | 2024 +++++++++++++++++++++
26 files changed, 18249 insertions(+), 0 deletions(-)
create mode 100644 drivers/net/wireless/ath/ath6kl/Kconfig
create mode 100644 drivers/net/wireless/ath/ath6kl/Makefile
create mode 100644 drivers/net/wireless/ath/ath6kl/bmi.c
create mode 100644 drivers/net/wireless/ath/ath6kl/bmi.h
create mode 100644 drivers/net/wireless/ath/ath6kl/cfg80211.c
create mode 100644 drivers/net/wireless/ath/ath6kl/cfg80211.h
create mode 100644 drivers/net/wireless/ath/ath6kl/common.h
create mode 100644 drivers/net/wireless/ath/ath6kl/core.h
create mode 100644 drivers/net/wireless/ath/ath6kl/debug.c
create mode 100644 drivers/net/wireless/ath/ath6kl/debug.h
create mode 100644 drivers/net/wireless/ath/ath6kl/hif-ops.h
create mode 100644 drivers/net/wireless/ath/ath6kl/hif.h
create mode 100644 drivers/net/wireless/ath/ath6kl/htc.c
create mode 100644 drivers/net/wireless/ath/ath6kl/htc.h
create mode 100644 drivers/net/wireless/ath/ath6kl/htc_hif.c
create mode 100644 drivers/net/wireless/ath/ath6kl/htc_hif.h
create mode 100644 drivers/net/wireless/ath/ath6kl/init.c
create mode 100644 drivers/net/wireless/ath/ath6kl/main.c
create mode 100644 drivers/net/wireless/ath/ath6kl/node.c
create mode 100644 drivers/net/wireless/ath/ath6kl/sdio.c
create mode 100644 drivers/net/wireless/ath/ath6kl/target.h
create mode 100644 drivers/net/wireless/ath/ath6kl/txrx.c
create mode 100644 drivers/net/wireless/ath/ath6kl/wmi.c
create mode 100644 drivers/net/wireless/ath/ath6kl/wmi.h
next reply other threads:[~2011-07-17 10:20 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2011-07-17 10:20 Kalle Valo [this message]
2011-07-17 10:20 ` [PATCH v2 01/23] ath6kl: add bmi.c Kalle Valo
2011-07-17 10:20 ` [PATCH v2 02/23] ath6kl: add bmi.h Kalle Valo
2011-07-17 10:21 ` [PATCH v2 03/23] ath6kl: add cfg80211.c Kalle Valo
2011-07-17 11:12 ` Johannes Berg
2011-07-17 19:40 ` Kalle Valo
2011-07-17 10:21 ` [PATCH v2 04/23] ath6kl: add cfg80211.h Kalle Valo
2011-07-17 10:21 ` [PATCH v2 05/23] ath6kl: add common.h Kalle Valo
2011-07-17 10:21 ` [PATCH v2 06/23] ath6kl: add core.h Kalle Valo
2011-07-17 10:21 ` [PATCH v2 07/23] ath6kl: add debug.c Kalle Valo
2011-07-17 10:22 ` [PATCH v2 08/23] ath6kl: add debug.h Kalle Valo
2011-07-17 10:22 ` [PATCH v2 09/23] ath6kl: add hif-ops.h Kalle Valo
2011-07-17 10:22 ` [PATCH v2 10/23] ath6kl: add hif.h Kalle Valo
2011-07-17 10:22 ` [PATCH v2 11/23] ath6kl: add htc.c Kalle Valo
2011-07-17 10:22 ` [PATCH v2 12/23] ath6kl: add htc.h Kalle Valo
2011-07-17 10:22 ` [PATCH v2 13/23] ath6kl: add htc_hif.c Kalle Valo
2011-07-17 10:23 ` [PATCH v2 14/23] ath6kl: add htc_hif.h Kalle Valo
2011-07-17 10:23 ` [PATCH v2 15/23] ath6kl: add init.c Kalle Valo
2011-07-17 10:23 ` [PATCH v2 16/23] ath6kl: add main.c Kalle Valo
2011-07-17 10:23 ` [PATCH v2 17/23] ath6kl: add node.c Kalle Valo
2011-07-17 10:23 ` [PATCH v2 18/23] ath6kl: add sdio.c Kalle Valo
2011-07-17 10:24 ` [PATCH v2 19/23] ath6kl: add target.h Kalle Valo
2011-07-17 10:24 ` [PATCH v2 20/23] ath6kl: add txrx.c Kalle Valo
2011-07-17 10:24 ` [PATCH v2 21/23] ath6kl: add wmi.c Kalle Valo
2011-07-17 10:24 ` [PATCH v2 22/23] ath6kl: add wmi.h Kalle Valo
2011-07-17 10:24 ` [PATCH v2 23/23] ath6kl: add Kconfig and Makefile Kalle Valo
2011-07-17 10:57 ` [PATCH v2 00/23] ath6kl cleaned up driver Kalle Valo
2011-07-19 4:21 ` Ali Bahar
2011-07-19 4:26 ` Kalle Valo
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20110717101844.18367.44984.stgit@localhost6.localdomain6 \
--to=kvalo@qca.qualcomm.com \
--cc=devel@linuxdriverproject.org \
--cc=error27@gmail.com \
--cc=gregkh@suse.de \
--cc=joe@perches.com \
--cc=linux-wireless@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).