Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
687b9308
Commit
687b9308
authored
Sep 26, 2014
by
John W. Linville
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'for-linville' of
git://github.com/kvalo/ath
parents
d3d3e001
b25f32cb
Changes
28
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
28 changed files
with
1017 additions
and
440 deletions
+1017
-440
drivers/net/wireless/ath/ath10k/Kconfig
drivers/net/wireless/ath/ath10k/Kconfig
+1
-1
drivers/net/wireless/ath/ath10k/Makefile
drivers/net/wireless/ath/ath10k/Makefile
+1
-0
drivers/net/wireless/ath/ath10k/bmi.h
drivers/net/wireless/ath/ath10k/bmi.h
+0
-1
drivers/net/wireless/ath/ath10k/ce.c
drivers/net/wireless/ath/ath10k/ce.c
+0
-2
drivers/net/wireless/ath/ath10k/ce.h
drivers/net/wireless/ath/ath10k/ce.h
+5
-8
drivers/net/wireless/ath/ath10k/core.c
drivers/net/wireless/ath/ath10k/core.c
+76
-30
drivers/net/wireless/ath/ath10k/core.h
drivers/net/wireless/ath/ath10k/core.h
+22
-3
drivers/net/wireless/ath/ath10k/debug.c
drivers/net/wireless/ath/ath10k/debug.c
+64
-38
drivers/net/wireless/ath/ath10k/debug.h
drivers/net/wireless/ath/ath10k/debug.h
+12
-0
drivers/net/wireless/ath/ath10k/hif.h
drivers/net/wireless/ath/ath10k/hif.h
+0
-1
drivers/net/wireless/ath/ath10k/htc.c
drivers/net/wireless/ath/ath10k/htc.c
+3
-7
drivers/net/wireless/ath/ath10k/htc.h
drivers/net/wireless/ath/ath10k/htc.h
+0
-1
drivers/net/wireless/ath/ath10k/htt.c
drivers/net/wireless/ath/ath10k/htt.c
+1
-1
drivers/net/wireless/ath/ath10k/htt.h
drivers/net/wireless/ath/ath10k/htt.h
+1
-2
drivers/net/wireless/ath/ath10k/htt_rx.c
drivers/net/wireless/ath/ath10k/htt_rx.c
+29
-25
drivers/net/wireless/ath/ath10k/htt_tx.c
drivers/net/wireless/ath/ath10k/htt_tx.c
+0
-2
drivers/net/wireless/ath/ath10k/hw.h
drivers/net/wireless/ath/ath10k/hw.h
+2
-0
drivers/net/wireless/ath/ath10k/mac.c
drivers/net/wireless/ath/ath10k/mac.c
+89
-103
drivers/net/wireless/ath/ath10k/pci.c
drivers/net/wireless/ath/ath10k/pci.c
+59
-124
drivers/net/wireless/ath/ath10k/rx_desc.h
drivers/net/wireless/ath/ath10k/rx_desc.h
+0
-1
drivers/net/wireless/ath/ath10k/targaddrs.h
drivers/net/wireless/ath/ath10k/targaddrs.h
+0
-1
drivers/net/wireless/ath/ath10k/testmode.c
drivers/net/wireless/ath/ath10k/testmode.c
+382
-0
drivers/net/wireless/ath/ath10k/testmode.h
drivers/net/wireless/ath/ath10k/testmode.h
+46
-0
drivers/net/wireless/ath/ath10k/testmode_i.h
drivers/net/wireless/ath/ath10k/testmode_i.h
+70
-0
drivers/net/wireless/ath/ath10k/trace.h
drivers/net/wireless/ath/ath10k/trace.h
+78
-27
drivers/net/wireless/ath/ath10k/txrx.c
drivers/net/wireless/ath/ath10k/txrx.c
+1
-1
drivers/net/wireless/ath/ath10k/wmi.c
drivers/net/wireless/ath/ath10k/wmi.c
+62
-41
drivers/net/wireless/ath/ath10k/wmi.h
drivers/net/wireless/ath/ath10k/wmi.h
+13
-20
No files found.
drivers/net/wireless/ath/ath10k/Kconfig
View file @
687b9308
...
@@ -24,7 +24,7 @@ config ATH10K_DEBUG
...
@@ -24,7 +24,7 @@ config ATH10K_DEBUG
config ATH10K_DEBUGFS
config ATH10K_DEBUGFS
bool "Atheros ath10k debugfs support"
bool "Atheros ath10k debugfs support"
depends on ATH10K
depends on ATH10K
&& DEBUG_FS
select RELAY
select RELAY
---help---
---help---
Enabled debugfs support
Enabled debugfs support
...
...
drivers/net/wireless/ath/ath10k/Makefile
View file @
687b9308
...
@@ -11,6 +11,7 @@ ath10k_core-y += mac.o \
...
@@ -11,6 +11,7 @@ ath10k_core-y += mac.o \
bmi.o
bmi.o
ath10k_core-$(CONFIG_ATH10K_DEBUGFS)
+=
spectral.o
ath10k_core-$(CONFIG_ATH10K_DEBUGFS)
+=
spectral.o
ath10k_core-$(CONFIG_NL80211_TESTMODE)
+=
testmode.o
ath10k_core-$(CONFIG_ATH10K_TRACING)
+=
trace.o
ath10k_core-$(CONFIG_ATH10K_TRACING)
+=
trace.o
obj-$(CONFIG_ATH10K_PCI)
+=
ath10k_pci.o
obj-$(CONFIG_ATH10K_PCI)
+=
ath10k_pci.o
...
...
drivers/net/wireless/ath/ath10k/bmi.h
View file @
687b9308
...
@@ -177,7 +177,6 @@ struct bmi_target_info {
...
@@ -177,7 +177,6 @@ struct bmi_target_info {
u32
type
;
u32
type
;
};
};
/* in msec */
/* in msec */
#define BMI_COMMUNICATION_TIMEOUT_HZ (1*HZ)
#define BMI_COMMUNICATION_TIMEOUT_HZ (1*HZ)
...
...
drivers/net/wireless/ath/ath10k/ce.c
View file @
687b9308
...
@@ -260,7 +260,6 @@ static inline void ath10k_ce_engine_int_status_clear(struct ath10k *ar,
...
@@ -260,7 +260,6 @@ static inline void ath10k_ce_engine_int_status_clear(struct ath10k *ar,
ath10k_pci_write32
(
ar
,
ce_ctrl_addr
+
HOST_IS_ADDRESS
,
mask
);
ath10k_pci_write32
(
ar
,
ce_ctrl_addr
+
HOST_IS_ADDRESS
,
mask
);
}
}
/*
/*
* Guts of ath10k_ce_send, used by both ath10k_ce_send and
* Guts of ath10k_ce_send, used by both ath10k_ce_send and
* ath10k_ce_sendlist_send.
* ath10k_ce_sendlist_send.
...
@@ -385,7 +384,6 @@ int ath10k_ce_num_free_src_entries(struct ath10k_ce_pipe *pipe)
...
@@ -385,7 +384,6 @@ int ath10k_ce_num_free_src_entries(struct ath10k_ce_pipe *pipe)
return
delta
;
return
delta
;
}
}
int
__ath10k_ce_rx_num_free_bufs
(
struct
ath10k_ce_pipe
*
pipe
)
int
__ath10k_ce_rx_num_free_bufs
(
struct
ath10k_ce_pipe
*
pipe
)
{
{
struct
ath10k
*
ar
=
pipe
->
ar
;
struct
ath10k
*
ar
=
pipe
->
ar
;
...
...
drivers/net/wireless/ath/ath10k/ce.h
View file @
687b9308
...
@@ -20,7 +20,6 @@
...
@@ -20,7 +20,6 @@
#include "hif.h"
#include "hif.h"
/* Maximum number of Copy Engine's supported */
/* Maximum number of Copy Engine's supported */
#define CE_COUNT_MAX 8
#define CE_COUNT_MAX 8
#define CE_HTT_H2T_MSG_SRC_NENTRIES 4096
#define CE_HTT_H2T_MSG_SRC_NENTRIES 4096
...
@@ -37,7 +36,6 @@
...
@@ -37,7 +36,6 @@
struct
ath10k_ce_pipe
;
struct
ath10k_ce_pipe
;
#define CE_DESC_FLAGS_GATHER (1 << 0)
#define CE_DESC_FLAGS_GATHER (1 << 0)
#define CE_DESC_FLAGS_BYTE_SWAP (1 << 1)
#define CE_DESC_FLAGS_BYTE_SWAP (1 << 1)
#define CE_DESC_FLAGS_META_DATA_MASK 0xFFFC
#define CE_DESC_FLAGS_META_DATA_MASK 0xFFFC
...
@@ -383,7 +381,6 @@ struct ce_attr {
...
@@ -383,7 +381,6 @@ struct ce_attr {
#define DST_WATERMARK_HIGH_RESET 0
#define DST_WATERMARK_HIGH_RESET 0
#define DST_WATERMARK_ADDRESS 0x0050
#define DST_WATERMARK_ADDRESS 0x0050
static
inline
u32
ath10k_ce_base_address
(
unsigned
int
ce_id
)
static
inline
u32
ath10k_ce_base_address
(
unsigned
int
ce_id
)
{
{
return
CE0_BASE_ADDRESS
+
(
CE1_BASE_ADDRESS
-
CE0_BASE_ADDRESS
)
*
ce_id
;
return
CE0_BASE_ADDRESS
+
(
CE1_BASE_ADDRESS
-
CE0_BASE_ADDRESS
)
*
ce_id
;
...
...
drivers/net/wireless/ath/ath10k/core.c
View file @
687b9308
...
@@ -26,6 +26,7 @@
...
@@ -26,6 +26,7 @@
#include "bmi.h"
#include "bmi.h"
#include "debug.h"
#include "debug.h"
#include "htt.h"
#include "htt.h"
#include "testmode.h"
unsigned
int
ath10k_debug_mask
;
unsigned
int
ath10k_debug_mask
;
static
bool
uart_print
;
static
bool
uart_print
;
...
@@ -257,21 +258,42 @@ static int ath10k_download_and_run_otp(struct ath10k *ar)
...
@@ -257,21 +258,42 @@ static int ath10k_download_and_run_otp(struct ath10k *ar)
return
0
;
return
0
;
}
}
static
int
ath10k_download_fw
(
struct
ath10k
*
ar
)
static
int
ath10k_download_fw
(
struct
ath10k
*
ar
,
enum
ath10k_firmware_mode
mode
)
{
{
u32
address
;
u32
address
,
data_len
;
const
char
*
mode_name
;
const
void
*
data
;
int
ret
;
int
ret
;
address
=
ar
->
hw_params
.
patch_load_addr
;
address
=
ar
->
hw_params
.
patch_load_addr
;
ret
=
ath10k_bmi_fast_download
(
ar
,
address
,
ar
->
firmware_data
,
switch
(
mode
)
{
ar
->
firmware_len
);
case
ATH10K_FIRMWARE_MODE_NORMAL
:
data
=
ar
->
firmware_data
;
data_len
=
ar
->
firmware_len
;
mode_name
=
"normal"
;
break
;
case
ATH10K_FIRMWARE_MODE_UTF
:
data
=
ar
->
testmode
.
utf
->
data
;
data_len
=
ar
->
testmode
.
utf
->
size
;
mode_name
=
"utf"
;
break
;
default:
ath10k_err
(
ar
,
"unknown firmware mode: %d
\n
"
,
mode
);
return
-
EINVAL
;
}
ath10k_dbg
(
ar
,
ATH10K_DBG_BOOT
,
"boot uploading firmware image %p len %d mode %s
\n
"
,
data
,
data_len
,
mode_name
);
ret
=
ath10k_bmi_fast_download
(
ar
,
address
,
data
,
data_len
);
if
(
ret
)
{
if
(
ret
)
{
ath10k_err
(
ar
,
"could not write fw (%d)
\n
"
,
ret
);
ath10k_err
(
ar
,
"failed to download %s firmware: %d
\n
"
,
goto
exit
;
mode_name
,
ret
);
return
ret
;
}
}
exit:
return
ret
;
return
ret
;
}
}
...
@@ -567,7 +589,8 @@ static int ath10k_core_fetch_firmware_files(struct ath10k *ar)
...
@@ -567,7 +589,8 @@ static int ath10k_core_fetch_firmware_files(struct ath10k *ar)
return
0
;
return
0
;
}
}
static
int
ath10k_init_download_firmware
(
struct
ath10k
*
ar
)
static
int
ath10k_init_download_firmware
(
struct
ath10k
*
ar
,
enum
ath10k_firmware_mode
mode
)
{
{
int
ret
;
int
ret
;
...
@@ -583,7 +606,7 @@ static int ath10k_init_download_firmware(struct ath10k *ar)
...
@@ -583,7 +606,7 @@ static int ath10k_init_download_firmware(struct ath10k *ar)
return
ret
;
return
ret
;
}
}
ret
=
ath10k_download_fw
(
ar
);
ret
=
ath10k_download_fw
(
ar
,
mode
);
if
(
ret
)
{
if
(
ret
)
{
ath10k_err
(
ar
,
"failed to download firmware: %d
\n
"
,
ret
);
ath10k_err
(
ar
,
"failed to download firmware: %d
\n
"
,
ret
);
return
ret
;
return
ret
;
...
@@ -685,12 +708,15 @@ static void ath10k_core_restart(struct work_struct *work)
...
@@ -685,12 +708,15 @@ static void ath10k_core_restart(struct work_struct *work)
case
ATH10K_STATE_WEDGED
:
case
ATH10K_STATE_WEDGED
:
ath10k_warn
(
ar
,
"device is wedged, will not restart
\n
"
);
ath10k_warn
(
ar
,
"device is wedged, will not restart
\n
"
);
break
;
break
;
case
ATH10K_STATE_UTF
:
ath10k_warn
(
ar
,
"firmware restart in UTF mode not supported
\n
"
);
break
;
}
}
mutex_unlock
(
&
ar
->
conf_mutex
);
mutex_unlock
(
&
ar
->
conf_mutex
);
}
}
int
ath10k_core_start
(
struct
ath10k
*
ar
)
int
ath10k_core_start
(
struct
ath10k
*
ar
,
enum
ath10k_firmware_mode
mode
)
{
{
int
status
;
int
status
;
...
@@ -703,7 +729,7 @@ int ath10k_core_start(struct ath10k *ar)
...
@@ -703,7 +729,7 @@ int ath10k_core_start(struct ath10k *ar)
goto
err
;
goto
err
;
}
}
status
=
ath10k_init_download_firmware
(
ar
);
status
=
ath10k_init_download_firmware
(
ar
,
mode
);
if
(
status
)
if
(
status
)
goto
err
;
goto
err
;
...
@@ -760,11 +786,13 @@ int ath10k_core_start(struct ath10k *ar)
...
@@ -760,11 +786,13 @@ int ath10k_core_start(struct ath10k *ar)
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
if
(
mode
==
ATH10K_FIRMWARE_MODE_NORMAL
)
{
status
=
ath10k_htt_connect
(
&
ar
->
htt
);
status
=
ath10k_htt_connect
(
&
ar
->
htt
);
if
(
status
)
{
if
(
status
)
{
ath10k_err
(
ar
,
"failed to connect htt (%d)
\n
"
,
status
);
ath10k_err
(
ar
,
"failed to connect htt (%d)
\n
"
,
status
);
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
}
status
=
ath10k_wmi_connect
(
ar
);
status
=
ath10k_wmi_connect
(
ar
);
if
(
status
)
{
if
(
status
)
{
...
@@ -778,12 +806,14 @@ int ath10k_core_start(struct ath10k *ar)
...
@@ -778,12 +806,14 @@ int ath10k_core_start(struct ath10k *ar)
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
if
(
mode
==
ATH10K_FIRMWARE_MODE_NORMAL
)
{
status
=
ath10k_wmi_wait_for_service_ready
(
ar
);
status
=
ath10k_wmi_wait_for_service_ready
(
ar
);
if
(
status
<=
0
)
{
if
(
status
<=
0
)
{
ath10k_warn
(
ar
,
"wmi service ready event not received"
);
ath10k_warn
(
ar
,
"wmi service ready event not received"
);
status
=
-
ETIMEDOUT
;
status
=
-
ETIMEDOUT
;
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
}
ath10k_dbg
(
ar
,
ATH10K_DBG_BOOT
,
"firmware %s booted
\n
"
,
ath10k_dbg
(
ar
,
ATH10K_DBG_BOOT
,
"firmware %s booted
\n
"
,
ar
->
hw
->
wiphy
->
fw_version
);
ar
->
hw
->
wiphy
->
fw_version
);
...
@@ -802,11 +832,14 @@ int ath10k_core_start(struct ath10k *ar)
...
@@ -802,11 +832,14 @@ int ath10k_core_start(struct ath10k *ar)
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
/* we don't care about HTT in UTF mode */
if
(
mode
==
ATH10K_FIRMWARE_MODE_NORMAL
)
{
status
=
ath10k_htt_setup
(
&
ar
->
htt
);
status
=
ath10k_htt_setup
(
&
ar
->
htt
);
if
(
status
)
{
if
(
status
)
{
ath10k_err
(
ar
,
"failed to setup htt: %d
\n
"
,
status
);
ath10k_err
(
ar
,
"failed to setup htt: %d
\n
"
,
status
);
goto
err_hif_stop
;
goto
err_hif_stop
;
}
}
}
status
=
ath10k_debug_start
(
ar
);
status
=
ath10k_debug_start
(
ar
);
if
(
status
)
if
(
status
)
...
@@ -861,7 +894,8 @@ void ath10k_core_stop(struct ath10k *ar)
...
@@ -861,7 +894,8 @@ void ath10k_core_stop(struct ath10k *ar)
lockdep_assert_held
(
&
ar
->
conf_mutex
);
lockdep_assert_held
(
&
ar
->
conf_mutex
);
/* try to suspend target */
/* try to suspend target */
if
(
ar
->
state
!=
ATH10K_STATE_RESTARTING
)
if
(
ar
->
state
!=
ATH10K_STATE_RESTARTING
&&
ar
->
state
!=
ATH10K_STATE_UTF
)
ath10k_wait_for_suspend
(
ar
,
WMI_PDEV_SUSPEND_AND_DISABLE_INTR
);
ath10k_wait_for_suspend
(
ar
,
WMI_PDEV_SUSPEND_AND_DISABLE_INTR
);
ath10k_debug_stop
(
ar
);
ath10k_debug_stop
(
ar
);
...
@@ -914,7 +948,7 @@ static int ath10k_core_probe_fw(struct ath10k *ar)
...
@@ -914,7 +948,7 @@ static int ath10k_core_probe_fw(struct ath10k *ar)
mutex_lock
(
&
ar
->
conf_mutex
);
mutex_lock
(
&
ar
->
conf_mutex
);
ret
=
ath10k_core_start
(
ar
);
ret
=
ath10k_core_start
(
ar
,
ATH10K_FIRMWARE_MODE_NORMAL
);
if
(
ret
)
{
if
(
ret
)
{
ath10k_err
(
ar
,
"could not init core (%d)
\n
"
,
ret
);
ath10k_err
(
ar
,
"could not init core (%d)
\n
"
,
ret
);
ath10k_core_free_firmware_files
(
ar
);
ath10k_core_free_firmware_files
(
ar
);
...
@@ -977,7 +1011,7 @@ static void ath10k_core_register_work(struct work_struct *work)
...
@@ -977,7 +1011,7 @@ static void ath10k_core_register_work(struct work_struct *work)
goto
err_release_fw
;
goto
err_release_fw
;
}
}
status
=
ath10k_debug_
create
(
ar
);
status
=
ath10k_debug_
register
(
ar
);
if
(
status
)
{
if
(
status
)
{
ath10k_err
(
ar
,
"unable to initialize debugfs
\n
"
);
ath10k_err
(
ar
,
"unable to initialize debugfs
\n
"
);
goto
err_unregister_mac
;
goto
err_unregister_mac
;
...
@@ -1041,9 +1075,11 @@ void ath10k_core_unregister(struct ath10k *ar)
...
@@ -1041,9 +1075,11 @@ void ath10k_core_unregister(struct ath10k *ar)
* unhappy about callback failures. */
* unhappy about callback failures. */
ath10k_mac_unregister
(
ar
);
ath10k_mac_unregister
(
ar
);
ath10k_testmode_destroy
(
ar
);
ath10k_core_free_firmware_files
(
ar
);
ath10k_core_free_firmware_files
(
ar
);
ath10k_debug_
destroy
(
ar
);
ath10k_debug_
unregister
(
ar
);
}
}
EXPORT_SYMBOL
(
ath10k_core_unregister
);
EXPORT_SYMBOL
(
ath10k_core_unregister
);
...
@@ -1051,6 +1087,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
...
@@ -1051,6 +1087,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
const
struct
ath10k_hif_ops
*
hif_ops
)
const
struct
ath10k_hif_ops
*
hif_ops
)
{
{
struct
ath10k
*
ar
;
struct
ath10k
*
ar
;
int
ret
;
ar
=
ath10k_mac_create
(
priv_size
);
ar
=
ath10k_mac_create
(
priv_size
);
if
(
!
ar
)
if
(
!
ar
)
...
@@ -1076,7 +1113,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
...
@@ -1076,7 +1113,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
ar
->
workqueue
=
create_singlethread_workqueue
(
"ath10k_wq"
);
ar
->
workqueue
=
create_singlethread_workqueue
(
"ath10k_wq"
);
if
(
!
ar
->
workqueue
)
if
(
!
ar
->
workqueue
)
goto
err_
wq
;
goto
err_
free_mac
;
mutex_init
(
&
ar
->
conf_mutex
);
mutex_init
(
&
ar
->
conf_mutex
);
spin_lock_init
(
&
ar
->
data_lock
);
spin_lock_init
(
&
ar
->
data_lock
);
...
@@ -1094,10 +1131,18 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
...
@@ -1094,10 +1131,18 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
INIT_WORK
(
&
ar
->
register_work
,
ath10k_core_register_work
);
INIT_WORK
(
&
ar
->
register_work
,
ath10k_core_register_work
);
INIT_WORK
(
&
ar
->
restart_work
,
ath10k_core_restart
);
INIT_WORK
(
&
ar
->
restart_work
,
ath10k_core_restart
);
ret
=
ath10k_debug_create
(
ar
);
if
(
ret
)
goto
err_free_wq
;
return
ar
;
return
ar
;
err_wq:
err_free_wq:
destroy_workqueue
(
ar
->
workqueue
);
err_free_mac:
ath10k_mac_destroy
(
ar
);
ath10k_mac_destroy
(
ar
);
return
NULL
;
return
NULL
;
}
}
EXPORT_SYMBOL
(
ath10k_core_create
);
EXPORT_SYMBOL
(
ath10k_core_create
);
...
@@ -1107,6 +1152,7 @@ void ath10k_core_destroy(struct ath10k *ar)
...
@@ -1107,6 +1152,7 @@ void ath10k_core_destroy(struct ath10k *ar)
flush_workqueue
(
ar
->
workqueue
);
flush_workqueue
(
ar
->
workqueue
);
destroy_workqueue
(
ar
->
workqueue
);
destroy_workqueue
(
ar
->
workqueue
);
ath10k_debug_destroy
(
ar
);
ath10k_mac_destroy
(
ar
);
ath10k_mac_destroy
(
ar
);
}
}
EXPORT_SYMBOL
(
ath10k_core_destroy
);
EXPORT_SYMBOL
(
ath10k_core_destroy
);
...
...
drivers/net/wireless/ath/ath10k/core.h
View file @
687b9308
...
@@ -293,7 +293,7 @@ struct ath10k_debug {
...
@@ -293,7 +293,7 @@ struct ath10k_debug {
struct
dentry
*
debugfs_phy
;
struct
dentry
*
debugfs_phy
;
struct
ath10k_target_stats
target_stats
;
struct
ath10k_target_stats
target_stats
;
DECLARE_BITMAP
(
wmi_service_bitmap
,
WMI_SERVICE_
BM_SIZE
);
DECLARE_BITMAP
(
wmi_service_bitmap
,
WMI_SERVICE_
MAX
);
struct
completion
event_stats_compl
;
struct
completion
event_stats_compl
;
...
@@ -330,6 +330,17 @@ enum ath10k_state {
...
@@ -330,6 +330,17 @@ enum ath10k_state {
* prevents completion timeouts and makes the driver more responsive to
* prevents completion timeouts and makes the driver more responsive to
* userspace commands. This is also prevents recursive recovery. */
* userspace commands. This is also prevents recursive recovery. */
ATH10K_STATE_WEDGED
,
ATH10K_STATE_WEDGED
,
/* factory tests */
ATH10K_STATE_UTF
,
};
enum
ath10k_firmware_mode
{
/* the default mode, standard 802.11 functionality */
ATH10K_FIRMWARE_MODE_NORMAL
,
/* factory tests etc */
ATH10K_FIRMWARE_MODE_UTF
,
};
};
enum
ath10k_fw_features
{
enum
ath10k_fw_features
{
...
@@ -472,7 +483,6 @@ struct ath10k {
...
@@ -472,7 +483,6 @@ struct ath10k {
struct
cfg80211_chan_def
chandef
;
struct
cfg80211_chan_def
chandef
;
int
free_vdev_map
;
int
free_vdev_map
;
bool
promisc
;
bool
monitor
;
bool
monitor
;
int
monitor_vdev_id
;
int
monitor_vdev_id
;
bool
monitor_started
;
bool
monitor_started
;
...
@@ -544,6 +554,15 @@ struct ath10k {
...
@@ -544,6 +554,15 @@ struct ath10k {
struct
ath10k_spec_scan
config
;
struct
ath10k_spec_scan
config
;
}
spectral
;
}
spectral
;
struct
{
/* protected by conf_mutex */
const
struct
firmware
*
utf
;
DECLARE_BITMAP
(
orig_fw_features
,
ATH10K_FW_FEATURE_COUNT
);
/* protected by data_lock */
bool
utf_monitor
;
}
testmode
;
/* must be last */
/* must be last */
u8
drv_priv
[
0
]
__aligned
(
sizeof
(
void
*
));
u8
drv_priv
[
0
]
__aligned
(
sizeof
(
void
*
));
};
};
...
@@ -552,7 +571,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
...
@@ -552,7 +571,7 @@ struct ath10k *ath10k_core_create(size_t priv_size, struct device *dev,
const
struct
ath10k_hif_ops
*
hif_ops
);
const
struct
ath10k_hif_ops
*
hif_ops
);
void
ath10k_core_destroy
(
struct
ath10k
*
ar
);
void
ath10k_core_destroy
(
struct
ath10k
*
ar
);
int
ath10k_core_start
(
struct
ath10k
*
ar
);
int
ath10k_core_start
(
struct
ath10k
*
ar
,
enum
ath10k_firmware_mode
mode
);
int
ath10k_wait_for_suspend
(
struct
ath10k
*
ar
,
u32
suspend_opt
);
int
ath10k_wait_for_suspend
(
struct
ath10k
*
ar
,
u32
suspend_opt
);
void
ath10k_core_stop
(
struct
ath10k
*
ar
);
void
ath10k_core_stop
(
struct
ath10k
*
ar
);
int
ath10k_core_register
(
struct
ath10k
*
ar
,
u32
chip_id
);
int
ath10k_core_register
(
struct
ath10k
*
ar
,
u32
chip_id
);
...
...
drivers/net/wireless/ath/ath10k/debug.c
View file @
687b9308
...
@@ -117,7 +117,7 @@ int ath10k_info(struct ath10k *ar, const char *fmt, ...)
...
@@ -117,7 +117,7 @@ int ath10k_info(struct ath10k *ar, const char *fmt, ...)
va_start
(
args
,
fmt
);
va_start
(
args
,
fmt
);
vaf
.
va
=
&
args
;
vaf
.
va
=
&
args
;
ret
=
dev_info
(
ar
->
dev
,
"%pV"
,
&
vaf
);
ret
=
dev_info
(
ar
->
dev
,
"%pV"
,
&
vaf
);
trace_ath10k_log_info
(
&
vaf
);
trace_ath10k_log_info
(
ar
,
&
vaf
);
va_end
(
args
);
va_end
(
args
);
return
ret
;
return
ret
;
...
@@ -134,11 +134,12 @@ void ath10k_print_driver_info(struct ath10k *ar)
...
@@ -134,11 +134,12 @@ void ath10k_print_driver_info(struct ath10k *ar)
ar
->
fw_api
,
ar
->
fw_api
,
ar
->
htt
.
target_version_major
,
ar
->
htt
.
target_version_major
,
ar
->
htt
.
target_version_minor
);
ar
->
htt
.
target_version_minor
);
ath10k_info
(
ar
,
"debug %d debugfs %d tracing %d dfs %d
\n
"
,
ath10k_info
(
ar
,
"debug %d debugfs %d tracing %d dfs %d
testmode %d
\n
"
,
config_enabled
(
CONFIG_ATH10K_DEBUG
),
config_enabled
(
CONFIG_ATH10K_DEBUG
),
config_enabled
(
CONFIG_ATH10K_DEBUGFS
),
config_enabled
(
CONFIG_ATH10K_DEBUGFS
),
config_enabled
(
CONFIG_ATH10K_TRACING
),
config_enabled
(
CONFIG_ATH10K_TRACING
),
config_enabled
(
CONFIG_ATH10K_DFS_CERTIFIED
));
config_enabled
(
CONFIG_ATH10K_DFS_CERTIFIED
),
config_enabled
(
CONFIG_NL80211_TESTMODE
));
}
}
EXPORT_SYMBOL
(
ath10k_print_driver_info
);
EXPORT_SYMBOL
(
ath10k_print_driver_info
);
...
@@ -153,7 +154,7 @@ int ath10k_err(struct ath10k *ar, const char *fmt, ...)
...
@@ -153,7 +154,7 @@ int ath10k_err(struct ath10k *ar, const char *fmt, ...)
va_start
(
args
,
fmt
);
va_start
(
args
,
fmt
);
vaf
.
va
=
&
args
;
vaf
.
va
=
&
args
;
ret
=
dev_err
(
ar
->
dev
,
"%pV"
,
&
vaf
);
ret
=
dev_err
(
ar
->
dev
,
"%pV"
,
&
vaf
);
trace_ath10k_log_err
(
&
vaf
);
trace_ath10k_log_err
(
ar
,
&
vaf
);
va_end
(
args
);
va_end
(
args
);
return
ret
;
return
ret
;
...
@@ -170,7 +171,7 @@ int ath10k_warn(struct ath10k *ar, const char *fmt, ...)
...
@@ -170,7 +171,7 @@ int ath10k_warn(struct ath10k *ar, const char *fmt, ...)
va_start
(
args
,
fmt
);
va_start
(
args
,
fmt
);
vaf
.
va
=
&
args
;
vaf
.
va
=
&
args
;
dev_warn_ratelimited
(
ar
->
dev
,
"%pV"
,
&
vaf
);
dev_warn_ratelimited
(
ar
->
dev
,
"%pV"
,
&
vaf
);
trace_ath10k_log_warn
(
&
vaf
);
trace_ath10k_log_warn
(
ar
,
&
vaf
);
va_end
(
args
);
va_end
(
args
);
...
@@ -208,7 +209,7 @@ static ssize_t ath10k_read_wmi_services(struct file *file,
...
@@ -208,7 +209,7 @@ static ssize_t ath10k_read_wmi_services(struct file *file,
if
(
len
>
buf_len
)
if
(
len
>
buf_len
)
len
=
buf_len
;
len
=
buf_len
;
for
(
i
=
0
;
i
<
WMI_
MAX_SERVICE
;
i
++
)
{
for
(
i
=
0
;
i
<
WMI_
SERVICE_MAX
;
i
++
)
{
enabled
=
test_bit
(
i
,
ar
->
debug
.
wmi_service_bitmap
);
enabled
=
test_bit
(
i
,
ar
->
debug
.
wmi_service_bitmap
);
name
=
wmi_service_name
(
i
);
name
=
wmi_service_name
(
i
);
...
@@ -564,16 +565,35 @@ static const struct file_operations fops_fw_stats = {
...
@@ -564,16 +565,35 @@ static const struct file_operations fops_fw_stats = {
.
llseek
=
default_llseek
,
.
llseek
=
default_llseek
,
};
};
/* This is a clean assert crash in firmware. */
static
int
ath10k_debug_fw_assert
(
struct
ath10k
*
ar
)
{
struct
wmi_vdev_install_key_cmd
*
cmd
;
struct
sk_buff
*
skb
;
skb
=
ath10k_wmi_alloc_skb
(
ar
,
sizeof
(
*
cmd
)
+
16
);
if
(
!
skb
)
return
-
ENOMEM
;
cmd
=
(
struct
wmi_vdev_install_key_cmd
*
)
skb
->
data
;
memset
(
cmd
,
0
,
sizeof
(
*
cmd
));
/* big enough number so that firmware asserts */
cmd
->
vdev_id
=
__cpu_to_le32
(
0x7ffe
);
return
ath10k_wmi_cmd_send
(
ar
,
skb
,
ar
->
wmi
.
cmd
->
vdev_install_key_cmdid
);
}
static
ssize_t
ath10k_read_simulate_fw_crash
(
struct
file
*
file
,
static
ssize_t
ath10k_read_simulate_fw_crash
(
struct
file
*
file
,
char
__user
*
user_buf
,
char
__user
*
user_buf
,
size_t
count
,
loff_t
*
ppos
)
size_t
count
,
loff_t
*
ppos
)
{
{
const
char
buf
[]
=
"To simulate firmware crash write one of the"
const
char
buf
[]
=
" keywords to this file:
\n
`soft` - this will send"
"To simulate firmware crash write one of the keywords to this file:
\n
"
" WMI_FORCE_FW_HANG_ASSERT to firmware if FW"
"`soft` - this will send WMI_FORCE_FW_HANG_ASSERT to firmware if FW supports that command.
\n
"
" supports that command.
\n
`hard` - this will send"
"`hard` - this will send to firmware command with illegal parameters causing firmware crash.
\n
"
" to firmware command with illegal parameters"
"`assert` - this will send special illegal parameter to firmware to cause assert failure and crash.
\n
"
;
" causing firmware crash.
\n
"
;
return
simple_read_from_buffer
(
user_buf
,
count
,
ppos
,
buf
,
strlen
(
buf
));
return
simple_read_from_buffer
(
user_buf
,
count
,
ppos
,
buf
,
strlen
(
buf
));
}
}
...
@@ -621,7 +641,11 @@ static ssize_t ath10k_write_simulate_fw_crash(struct file *file,
...
@@ -621,7 +641,11 @@ static ssize_t ath10k_write_simulate_fw_crash(struct file *file,
* firmware variants in order to force a firmware crash.
* firmware variants in order to force a firmware crash.
*/
*/
ret
=
ath10k_wmi_vdev_set_param
(
ar
,
0x7fff
,
ret
=
ath10k_wmi_vdev_set_param
(
ar
,
0x7fff
,
ar
->
wmi
.
vdev_param
->
rts_threshold
,
0
);
ar
->
wmi
.
vdev_param
->
rts_threshold
,
0
);
}
else
if
(
!
strcmp
(
buf
,
"assert"
))
{
ath10k_info
(
ar
,
"simulating firmware assert crash
\n
"
);
ret
=
ath10k_debug_fw_assert
(
ar
);
}
else
{
}
else
{
ret
=
-
EINVAL
;
ret
=
-
EINVAL
;
goto
exit
;
goto
exit
;
...
@@ -1132,19 +1156,28 @@ static const struct file_operations fops_dfs_stats = {
...
@@ -1132,19 +1156,28 @@ static const struct file_operations fops_dfs_stats = {
int
ath10k_debug_create
(
struct
ath10k
*
ar
)
int
ath10k_debug_create
(
struct
ath10k
*
ar
)
{
{
int
ret
;
ar
->
debug
.
fw_crash_data
=
vzalloc
(
sizeof
(
*
ar
->
debug
.
fw_crash_data
));
ar
->
debug
.
fw_crash_data
=
vzalloc
(
sizeof
(
*
ar
->
debug
.
fw_crash_data
));
if
(
!
ar
->
debug
.
fw_crash_data
)
{
if
(
!
ar
->
debug
.
fw_crash_data
)
ret
=
-
ENOMEM
;
return
-
ENOMEM
;
goto
err
;
}
return
0
;
}
void
ath10k_debug_destroy
(
struct
ath10k
*
ar
)
{
vfree
(
ar
->
debug
.
fw_crash_data
);
ar
->
debug
.
fw_crash_data
=
NULL
;
}
int
ath10k_debug_register
(
struct
ath10k
*
ar
)
{
ar
->
debug
.
debugfs_phy
=
debugfs_create_dir
(
"ath10k"
,
ar
->
debug
.
debugfs_phy
=
debugfs_create_dir
(
"ath10k"
,
ar
->
hw
->
wiphy
->
debugfsdir
);
ar
->
hw
->
wiphy
->
debugfsdir
);
if
(
!
ar
->
debug
.
debugfs_phy
)
{
if
(
IS_ERR_OR_NULL
(
ar
->
debug
.
debugfs_phy
))
{
ret
=
-
ENOMEM
;
if
(
IS_ERR
(
ar
->
debug
.
debugfs_phy
))
goto
err_free_fw_crash_data
;
return
PTR_ERR
(
ar
->
debug
.
debugfs_phy
);
return
-
ENOMEM
;
}
}
INIT_DELAYED_WORK
(
&
ar
->
debug
.
htt_stats_dwork
,
INIT_DELAYED_WORK
(
&
ar
->
debug
.
htt_stats_dwork
,
...
@@ -1192,17 +1225,10 @@ int ath10k_debug_create(struct ath10k *ar)
...
@@ -1192,17 +1225,10 @@ int ath10k_debug_create(struct ath10k *ar)
}
}
return
0
;
return
0
;
err_free_fw_crash_data:
vfree
(
ar
->
debug
.
fw_crash_data
);
err:
return
ret
;
}
}
void
ath10k_debug_
destroy
(
struct
ath10k
*
ar
)
void
ath10k_debug_
unregister
(
struct
ath10k
*
ar
)
{
{
vfree
(
ar
->
debug
.
fw_crash_data
);
cancel_delayed_work_sync
(
&
ar
->
debug
.
htt_stats_dwork
);
cancel_delayed_work_sync
(
&
ar
->
debug
.
htt_stats_dwork
);
}
}
...
@@ -1223,7 +1249,7 @@ void ath10k_dbg(struct ath10k *ar, enum ath10k_debug_mask mask,
...
@@ -1223,7 +1249,7 @@ void ath10k_dbg(struct ath10k *ar, enum ath10k_debug_mask mask,
if
(
ath10k_debug_mask
&
mask
)
if
(
ath10k_debug_mask
&
mask
)
dev_printk
(
KERN_DEBUG
,
ar
->
dev
,
"%pV"
,
&
vaf
);
dev_printk
(
KERN_DEBUG
,
ar
->
dev
,
"%pV"
,
&
vaf
);
trace_ath10k_log_dbg
(
mask
,
&
vaf
);
trace_ath10k_log_dbg
(
ar
,
mask
,
&
vaf
);
va_end
(
args
);
va_end
(
args
);
}
}
...
@@ -1242,7 +1268,7 @@ void ath10k_dbg_dump(struct ath10k *ar,
...
@@ -1242,7 +1268,7 @@ void ath10k_dbg_dump(struct ath10k *ar,
}
}
/* tracing code doesn't like null strings :/ */
/* tracing code doesn't like null strings :/ */
trace_ath10k_log_dbg_dump
(
msg
?
msg
:
""
,
prefix
?
prefix
:
""
,
trace_ath10k_log_dbg_dump
(
ar
,
msg
?
msg
:
""
,
prefix
?
prefix
:
""
,
buf
,
len
);
buf
,
len
);
}
}
EXPORT_SYMBOL
(
ath10k_dbg_dump
);
EXPORT_SYMBOL
(
ath10k_dbg_dump
);
...
...
drivers/net/wireless/ath/ath10k/debug.h
View file @
687b9308
...
@@ -34,6 +34,7 @@ enum ath10k_debug_mask {
...
@@ -34,6 +34,7 @@ enum ath10k_debug_mask {
ATH10K_DBG_DATA
=
0x00000200
,
ATH10K_DBG_DATA
=
0x00000200
,
ATH10K_DBG_BMI
=
0x00000400
,
ATH10K_DBG_BMI
=
0x00000400
,
ATH10K_DBG_REGULATORY
=
0x00000800
,
ATH10K_DBG_REGULATORY
=
0x00000800
,
ATH10K_DBG_TESTMODE
=
0x00001000
,
ATH10K_DBG_ANY
=
0xffffffff
,
ATH10K_DBG_ANY
=
0xffffffff
,
};
};
...
@@ -49,6 +50,8 @@ int ath10k_debug_start(struct ath10k *ar);
...
@@ -49,6 +50,8 @@ int ath10k_debug_start(struct ath10k *ar);
void
ath10k_debug_stop
(
struct
ath10k
*
ar
);
void
ath10k_debug_stop
(
struct
ath10k
*
ar
);
int
ath10k_debug_create
(
struct
ath10k
*
ar
);
int
ath10k_debug_create
(
struct
ath10k
*
ar
);
void
ath10k_debug_destroy
(
struct
ath10k
*
ar
);
void
ath10k_debug_destroy
(
struct
ath10k
*
ar
);
int
ath10k_debug_register
(
struct
ath10k
*
ar
);
void
ath10k_debug_unregister
(
struct
ath10k
*
ar
);
void
ath10k_debug_read_service_map
(
struct
ath10k
*
ar
,
void
ath10k_debug_read_service_map
(
struct
ath10k
*
ar
,
void
*
service_map
,
void
*
service_map
,
size_t
map_size
);
size_t
map_size
);
...
@@ -80,6 +83,15 @@ static inline void ath10k_debug_destroy(struct ath10k *ar)
...
@@ -80,6 +83,15 @@ static inline void ath10k_debug_destroy(struct ath10k *ar)
{
{
}
}
static
inline
int
ath10k_debug_register
(
struct
ath10k
*
ar
)
{
return
0
;
}
static
inline
void
ath10k_debug_unregister
(
struct
ath10k
*
ar
)
{
}
static
inline
void
ath10k_debug_read_service_map
(
struct
ath10k
*
ar
,
static
inline
void
ath10k_debug_read_service_map
(
struct
ath10k
*
ar
,
void
*
service_map
,
void
*
service_map
,
size_t
map_size
)
size_t
map_size
)
...
...
drivers/net/wireless/ath/ath10k/hif.h
View file @
687b9308
...
@@ -91,7 +91,6 @@ struct ath10k_hif_ops {
...
@@ -91,7 +91,6 @@ struct ath10k_hif_ops {
int
(
*
resume
)(
struct
ath10k
*
ar
);
int
(
*
resume
)(
struct
ath10k
*
ar
);
};
};
static
inline
int
ath10k_hif_tx_sg
(
struct
ath10k
*
ar
,
u8
pipe_id
,
static
inline
int
ath10k_hif_tx_sg
(
struct
ath10k
*
ar
,
u8
pipe_id
,
struct
ath10k_hif_sg_item
*
items
,
struct
ath10k_hif_sg_item
*
items
,
int
n_items
)
int
n_items
)
...
...
drivers/net/wireless/ath/ath10k/htc.c
View file @
687b9308
...
@@ -45,10 +45,8 @@ static struct sk_buff *ath10k_htc_build_tx_ctrl_skb(void *ar)
...
@@ -45,10 +45,8 @@ static struct sk_buff *ath10k_htc_build_tx_ctrl_skb(void *ar)
struct
ath10k_skb_cb
*
skb_cb
;
struct
ath10k_skb_cb
*
skb_cb
;
skb
=
dev_alloc_skb
(
ATH10K_HTC_CONTROL_BUFFER_SIZE
);
skb
=
dev_alloc_skb
(
ATH10K_HTC_CONTROL_BUFFER_SIZE
);
if
(
!
skb
)
{
if
(
!
skb
)
ath10k_warn
(
ar
,
"Unable to allocate ctrl skb
\n
"
);
return
NULL
;
return
NULL
;
}
skb_reserve
(
skb
,
20
);
/* FIXME: why 20 bytes? */
skb_reserve
(
skb
,
20
);
/* FIXME: why 20 bytes? */
WARN_ONCE
((
unsigned
long
)
skb
->
data
&
3
,
"unaligned skb"
);
WARN_ONCE
((
unsigned
long
)
skb
->
data
&
3
,
"unaligned skb"
);
...
@@ -806,10 +804,8 @@ struct sk_buff *ath10k_htc_alloc_skb(struct ath10k *ar, int size)
...
@@ -806,10 +804,8 @@ struct sk_buff *ath10k_htc_alloc_skb(struct ath10k *ar, int size)
struct
sk_buff
*
skb
;
struct
sk_buff
*
skb
;
skb
=
dev_alloc_skb
(
size
+
sizeof
(
struct
ath10k_htc_hdr
));
skb
=
dev_alloc_skb
(
size
+
sizeof
(
struct
ath10k_htc_hdr
));
if
(
!
skb
)
{
if
(
!
skb
)
ath10k_warn
(
ar
,
"could not allocate HTC tx skb
\n
"
);
return
NULL
;
return
NULL
;
}
skb_reserve
(
skb
,
sizeof
(
struct
ath10k_htc_hdr
));
skb_reserve
(
skb
,
sizeof
(
struct
ath10k_htc_hdr
));
...
...
drivers/net/wireless/ath/ath10k/htc.h
View file @
687b9308
...
@@ -214,7 +214,6 @@ struct ath10k_htc_frame {
...
@@ -214,7 +214,6 @@ struct ath10k_htc_frame {
struct
ath10k_htc_record
trailer
[
0
];
struct
ath10k_htc_record
trailer
[
0
];
}
__packed
__aligned
(
4
);
}
__packed
__aligned
(
4
);
/*******************/
/*******************/
/* Host-side stuff */
/* Host-side stuff */
/*******************/
/*******************/
...
...
drivers/net/wireless/ath/ath10k/htt.c
View file @
687b9308
drivers/net/wireless/ath/ath10k/htt.h
View file @
687b9308
...
@@ -265,7 +265,6 @@ enum htt_mgmt_tx_status {
...
@@ -265,7 +265,6 @@ enum htt_mgmt_tx_status {
/*=== target -> host messages ===============================================*/
/*=== target -> host messages ===============================================*/
enum
htt_t2h_msg_type
{
enum
htt_t2h_msg_type
{
HTT_T2H_MSG_TYPE_VERSION_CONF
=
0x0
,
HTT_T2H_MSG_TYPE_VERSION_CONF
=
0x0
,
HTT_T2H_MSG_TYPE_RX_IND
=
0x1
,
HTT_T2H_MSG_TYPE_RX_IND
=
0x1
,
...
@@ -1032,6 +1031,7 @@ static inline struct htt_stats_conf_item *htt_stats_conf_next_item(
...
@@ -1032,6 +1031,7 @@ static inline struct htt_stats_conf_item *htt_stats_conf_next_item(
{
{
return
(
void
*
)
item
+
sizeof
(
*
item
)
+
roundup
(
item
->
length
,
4
);
return
(
void
*
)
item
+
sizeof
(
*
item
)
+
roundup
(
item
->
length
,
4
);
}
}
/*
/*
* host -> target FRAG DESCRIPTOR/MSDU_EXT DESC bank
* host -> target FRAG DESCRIPTOR/MSDU_EXT DESC bank
*
*
...
@@ -1148,7 +1148,6 @@ struct htt_resp {
...
@@ -1148,7 +1148,6 @@ struct htt_resp {
};
};
}
__packed
;
}
__packed
;
/*** host side structures follow ***/
/*** host side structures follow ***/
struct
htt_tx_done
{
struct
htt_tx_done
{
...
...
drivers/net/wireless/ath/ath10k/htt_rx.c
View file @
687b9308
...
@@ -42,7 +42,6 @@
...
@@ -42,7 +42,6 @@
/* when under memory pressure rx ring refill may fail and needs a retry */
/* when under memory pressure rx ring refill may fail and needs a retry */
#define HTT_RX_RING_REFILL_RETRY_MS 50
#define HTT_RX_RING_REFILL_RETRY_MS 50
static
int
ath10k_htt_rx_get_csum_state
(
struct
sk_buff
*
skb
);
static
int
ath10k_htt_rx_get_csum_state
(
struct
sk_buff
*
skb
);
static
void
ath10k_htt_txrx_compl_task
(
unsigned
long
ptr
);
static
void
ath10k_htt_txrx_compl_task
(
unsigned
long
ptr
);
...
@@ -133,7 +132,7 @@ static int __ath10k_htt_rx_ring_fill_n(struct ath10k_htt *htt, int num)
...
@@ -133,7 +132,7 @@ static int __ath10k_htt_rx_ring_fill_n(struct ath10k_htt *htt, int num)
dma_addr_t
paddr
;
dma_addr_t
paddr
;
int
ret
=
0
,
idx
;
int
ret
=
0
,
idx
;
idx
=
__le32_to_cpu
(
*
(
htt
->
rx_ring
.
alloc_idx
.
vaddr
)
);
idx
=
__le32_to_cpu
(
*
htt
->
rx_ring
.
alloc_idx
.
vaddr
);
while
(
num
>
0
)
{
while
(
num
>
0
)
{
skb
=
dev_alloc_skb
(
HTT_RX_BUF_SIZE
+
HTT_RX_DESC_ALIGN
);
skb
=
dev_alloc_skb
(
HTT_RX_BUF_SIZE
+
HTT_RX_DESC_ALIGN
);
if
(
!
skb
)
{
if
(
!
skb
)
{
...
@@ -171,7 +170,7 @@ static int __ath10k_htt_rx_ring_fill_n(struct ath10k_htt *htt, int num)
...
@@ -171,7 +170,7 @@ static int __ath10k_htt_rx_ring_fill_n(struct ath10k_htt *htt, int num)
}
}
fail:
fail:
*
(
htt
->
rx_ring
.
alloc_idx
.
vaddr
)
=
__cpu_to_le32
(
idx
);
*
htt
->
rx_ring
.
alloc_idx
.
vaddr
=
__cpu_to_le32
(
idx
);
return
ret
;
return
ret
;
}
}
...
@@ -223,6 +222,7 @@ static void ath10k_htt_rx_msdu_buff_replenish(struct ath10k_htt *htt)
...
@@ -223,6 +222,7 @@ static void ath10k_htt_rx_msdu_buff_replenish(struct ath10k_htt *htt)
static
void
ath10k_htt_rx_ring_refill_retry
(
unsigned
long
arg
)
static
void
ath10k_htt_rx_ring_refill_retry
(
unsigned
long
arg
)
{
{
struct
ath10k_htt
*
htt
=
(
struct
ath10k_htt
*
)
arg
;
struct
ath10k_htt
*
htt
=
(
struct
ath10k_htt
*
)
arg
;
ath10k_htt_rx_msdu_buff_replenish
(
htt
);
ath10k_htt_rx_msdu_buff_replenish
(
htt
);
}
}
...
@@ -314,7 +314,7 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
...
@@ -314,7 +314,7 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
{
{
struct
ath10k
*
ar
=
htt
->
ar
;
struct
ath10k
*
ar
=
htt
->
ar
;
int
msdu_len
,
msdu_chaining
=
0
;
int
msdu_len
,
msdu_chaining
=
0
;
struct
sk_buff
*
msdu
;
struct
sk_buff
*
msdu
,
*
next
;
struct
htt_rx_desc
*
rx_desc
;
struct
htt_rx_desc
*
rx_desc
;
lockdep_assert_held
(
&
htt
->
rx_ring
.
lock
);
lockdep_assert_held
(
&
htt
->
rx_ring
.
lock
);
...
@@ -450,12 +450,12 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
...
@@ -450,12 +450,12 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
if
(
last_msdu
)
{
if
(
last_msdu
)
{
msdu
->
next
=
NULL
;
msdu
->
next
=
NULL
;
break
;
break
;
}
else
{
}
struct
sk_buff
*
next
=
ath10k_htt_rx_netbuf_pop
(
htt
);
next
=
ath10k_htt_rx_netbuf_pop
(
htt
);
msdu
->
next
=
next
;
msdu
->
next
=
next
;
msdu
=
next
;
msdu
=
next
;
}
}
}
*
tail_msdu
=
msdu
;
*
tail_msdu
=
msdu
;
if
(
*
head_msdu
==
NULL
)
if
(
*
head_msdu
==
NULL
)
...
@@ -480,6 +480,7 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
...
@@ -480,6 +480,7 @@ static int ath10k_htt_rx_amsdu_pop(struct ath10k_htt *htt,
static
void
ath10k_htt_rx_replenish_task
(
unsigned
long
ptr
)
static
void
ath10k_htt_rx_replenish_task
(
unsigned
long
ptr
)
{
{
struct
ath10k_htt
*
htt
=
(
struct
ath10k_htt
*
)
ptr
;
struct
ath10k_htt
*
htt
=
(
struct
ath10k_htt
*
)
ptr
;
ath10k_htt_rx_msdu_buff_replenish
(
htt
);
ath10k_htt_rx_msdu_buff_replenish
(
htt
);
}
}
...
@@ -488,6 +489,7 @@ int ath10k_htt_rx_alloc(struct ath10k_htt *htt)
...
@@ -488,6 +489,7 @@ int ath10k_htt_rx_alloc(struct ath10k_htt *htt)
struct
ath10k
*
ar
=
htt
->
ar
;
struct
ath10k
*
ar
=
htt
->
ar
;
dma_addr_t
paddr
;
dma_addr_t
paddr
;
void
*
vaddr
;
void
*
vaddr
;
size_t
size
;
struct
timer_list
*
timer
=
&
htt
->
rx_ring
.
refill_retry_timer
;
struct
timer_list
*
timer
=
&
htt
->
rx_ring
.
refill_retry_timer
;
htt
->
rx_ring
.
size
=
ath10k_htt_rx_ring_size
(
htt
);
htt
->
rx_ring
.
size
=
ath10k_htt_rx_ring_size
(
htt
);
...
@@ -515,9 +517,9 @@ int ath10k_htt_rx_alloc(struct ath10k_htt *htt)
...
@@ -515,9 +517,9 @@ int ath10k_htt_rx_alloc(struct ath10k_htt *htt)
if
(
!
htt
->
rx_ring
.
netbufs_ring
)
if
(
!
htt
->
rx_ring
.
netbufs_ring
)
goto
err_netbuf
;
goto
err_netbuf
;
vaddr
=
dma_alloc_coherent
(
htt
->
ar
->
dev
,
size
=
htt
->
rx_ring
.
size
*
sizeof
(
htt
->
rx_ring
.
paddrs_ring
);
(
htt
->
rx_ring
.
size
*
sizeof
(
htt
->
rx_ring
.
paddrs_ring
)),
&
paddr
,
GFP_DMA
);
vaddr
=
dma_alloc_coherent
(
htt
->
ar
->
dev
,
size
,
&
paddr
,
GFP_DMA
);
if
(
!
vaddr
)
if
(
!
vaddr
)
goto
err_dma_ring
;
goto
err_dma_ring
;
...
@@ -629,15 +631,17 @@ static struct ieee80211_hdr *ath10k_htt_rx_skb_get_hdr(struct sk_buff *skb)
...
@@ -629,15 +631,17 @@ static struct ieee80211_hdr *ath10k_htt_rx_skb_get_hdr(struct sk_buff *skb)
if
(
fmt
==
RX_MSDU_DECAP_RAW
)
if
(
fmt
==
RX_MSDU_DECAP_RAW
)
return
(
void
*
)
skb
->
data
;
return
(
void
*
)
skb
->
data
;
else
return
(
void
*
)
skb
->
data
-
RX_HTT_HDR_STATUS_LEN
;
return
(
void
*
)
skb
->
data
-
RX_HTT_HDR_STATUS_LEN
;
}
}
/* This function only applies for first msdu in an msdu chain */
/* This function only applies for first msdu in an msdu chain */
static
bool
ath10k_htt_rx_hdr_is_amsdu
(
struct
ieee80211_hdr
*
hdr
)
static
bool
ath10k_htt_rx_hdr_is_amsdu
(
struct
ieee80211_hdr
*
hdr
)
{
{
u8
*
qc
;
if
(
ieee80211_is_data_qos
(
hdr
->
frame_control
))
{
if
(
ieee80211_is_data_qos
(
hdr
->
frame_control
))
{
u8
*
qc
=
ieee80211_get_qos_ctl
(
hdr
);
qc
=
ieee80211_get_qos_ctl
(
hdr
);
if
(
qc
[
0
]
&
0x80
)
if
(
qc
[
0
]
&
0x80
)
return
true
;
return
true
;
}
}
...
@@ -950,8 +954,8 @@ static void ath10k_htt_rx_amsdu(struct ath10k_htt *htt,
...
@@ -950,8 +954,8 @@ static void ath10k_htt_rx_amsdu(struct ath10k_htt *htt,
/* pull decapped header and copy SA & DA */
/* pull decapped header and copy SA & DA */
hdr
=
(
struct
ieee80211_hdr
*
)
skb
->
data
;
hdr
=
(
struct
ieee80211_hdr
*
)
skb
->
data
;
hdr_len
=
ath10k_htt_rx_nwifi_hdrlen
(
hdr
);
hdr_len
=
ath10k_htt_rx_nwifi_hdrlen
(
hdr
);
memcpy
(
da
,
ieee80211_get_DA
(
hdr
),
ETH_ALEN
);
ether_addr_copy
(
da
,
ieee80211_get_DA
(
hdr
)
);
memcpy
(
sa
,
ieee80211_get_SA
(
hdr
),
ETH_ALEN
);
ether_addr_copy
(
sa
,
ieee80211_get_SA
(
hdr
)
);
skb_pull
(
skb
,
hdr_len
);
skb_pull
(
skb
,
hdr_len
);
/* push original 802.11 header */
/* push original 802.11 header */
...
@@ -968,8 +972,8 @@ static void ath10k_htt_rx_amsdu(struct ath10k_htt *htt,
...
@@ -968,8 +972,8 @@ static void ath10k_htt_rx_amsdu(struct ath10k_htt *htt,
/* original 802.11 header has a different DA and in
/* original 802.11 header has a different DA and in
* case of 4addr it may also have different SA
* case of 4addr it may also have different SA
*/
*/
memcpy
(
ieee80211_get_DA
(
hdr
),
da
,
ETH_ALEN
);
ether_addr_copy
(
ieee80211_get_DA
(
hdr
),
da
);
memcpy
(
ieee80211_get_SA
(
hdr
),
sa
,
ETH_ALEN
);
ether_addr_copy
(
ieee80211_get_SA
(
hdr
),
sa
);
break
;
break
;
case
RX_MSDU_DECAP_ETHERNET2_DIX
:
case
RX_MSDU_DECAP_ETHERNET2_DIX
:
/* strip ethernet header and insert decapped 802.11
/* strip ethernet header and insert decapped 802.11
...
@@ -1654,7 +1658,7 @@ void ath10k_htt_t2h_msg_handler(struct ath10k *ar, struct sk_buff *skb)
...
@@ -1654,7 +1658,7 @@ void ath10k_htt_t2h_msg_handler(struct ath10k *ar, struct sk_buff *skb)
/* FIX THIS */
/* FIX THIS */
break
;
break
;
case
HTT_T2H_MSG_TYPE_STATS_CONF
:
case
HTT_T2H_MSG_TYPE_STATS_CONF
:
trace_ath10k_htt_stats
(
skb
->
data
,
skb
->
len
);
trace_ath10k_htt_stats
(
ar
,
skb
->
data
,
skb
->
len
);
break
;
break
;
case
HTT_T2H_MSG_TYPE_TX_INSPECT_IND
:
case
HTT_T2H_MSG_TYPE_TX_INSPECT_IND
:
/* Firmware can return tx frames if it's unable to fully
/* Firmware can return tx frames if it's unable to fully
...
...
drivers/net/wireless/ath/ath10k/htt_tx.c
View file @
687b9308
...
@@ -154,7 +154,6 @@ void ath10k_htt_tx_free(struct ath10k_htt *htt)
...
@@ -154,7 +154,6 @@ void ath10k_htt_tx_free(struct ath10k_htt *htt)
kfree
(
htt
->
pending_tx
);
kfree
(
htt
->
pending_tx
);
kfree
(
htt
->
used_msdu_ids
);
kfree
(
htt
->
used_msdu_ids
);
dma_pool_destroy
(
htt
->
tx_pool
);
dma_pool_destroy
(
htt
->
tx_pool
);
return
;
}
}
void
ath10k_htt_htc_tx_complete
(
struct
ath10k
*
ar
,
struct
sk_buff
*
skb
)
void
ath10k_htt_htc_tx_complete
(
struct
ath10k
*
ar
,
struct
sk_buff
*
skb
)
...
@@ -377,7 +376,6 @@ int ath10k_htt_mgmt_tx(struct ath10k_htt *htt, struct sk_buff *msdu)
...
@@ -377,7 +376,6 @@ int ath10k_htt_mgmt_tx(struct ath10k_htt *htt, struct sk_buff *msdu)
int
msdu_id
=
-
1
;
int
msdu_id
=
-
1
;
int
res
;
int
res
;
res
=
ath10k_htt_tx_inc_pending
(
htt
);
res
=
ath10k_htt_tx_inc_pending
(
htt
);
if
(
res
)
if
(
res
)
goto
err
;
goto
err
;
...
...
drivers/net/wireless/ath/ath10k/hw.h
View file @
687b9308
...
@@ -36,6 +36,8 @@
...
@@ -36,6 +36,8 @@
#define ATH10K_FW_API2_FILE "firmware-2.bin"
#define ATH10K_FW_API2_FILE "firmware-2.bin"
#define ATH10K_FW_API3_FILE "firmware-3.bin"
#define ATH10K_FW_API3_FILE "firmware-3.bin"
#define ATH10K_FW_UTF_FILE "utf.bin"
/* includes also the null byte */
/* includes also the null byte */
#define ATH10K_FIRMWARE_MAGIC "QCA-ATH10K"
#define ATH10K_FIRMWARE_MAGIC "QCA-ATH10K"
...
...
drivers/net/wireless/ath/ath10k/mac.c
View file @
687b9308
This diff is collapsed.
Click to expand it.
drivers/net/wireless/ath/ath10k/pci.c
View file @
687b9308
This diff is collapsed.
Click to expand it.
drivers/net/wireless/ath/ath10k/rx_desc.h
View file @
687b9308
...
@@ -839,7 +839,6 @@ struct rx_ppdu_start {
...
@@ -839,7 +839,6 @@ struct rx_ppdu_start {
* Reserved: HW should fill with 0, FW should ignore.
* Reserved: HW should fill with 0, FW should ignore.
*/
*/
#define RX_PPDU_END_FLAGS_PHY_ERR (1 << 0)
#define RX_PPDU_END_FLAGS_PHY_ERR (1 << 0)
#define RX_PPDU_END_FLAGS_RX_LOCATION (1 << 1)
#define RX_PPDU_END_FLAGS_RX_LOCATION (1 << 1)
#define RX_PPDU_END_FLAGS_TXBF_H_INFO (1 << 2)
#define RX_PPDU_END_FLAGS_TXBF_H_INFO (1 << 2)
...
...
drivers/net/wireless/ath/ath10k/targaddrs.h
View file @
687b9308
...
@@ -284,7 +284,6 @@ Fw Mode/SubMode Mask
...
@@ -284,7 +284,6 @@ Fw Mode/SubMode Mask
#define HI_OPTION_ALL_FW_SUBMODE_MASK 0xFF00
#define HI_OPTION_ALL_FW_SUBMODE_MASK 0xFF00
#define HI_OPTION_ALL_FW_SUBMODE_SHIFT 0x8
#define HI_OPTION_ALL_FW_SUBMODE_SHIFT 0x8
/* hi_option_flag2 options */
/* hi_option_flag2 options */
#define HI_OPTION_OFFLOAD_AMSDU 0x01
#define HI_OPTION_OFFLOAD_AMSDU 0x01
#define HI_OPTION_DFS_SUPPORT 0x02
/* Enable DFS support */
#define HI_OPTION_DFS_SUPPORT 0x02
/* Enable DFS support */
...
...
drivers/net/wireless/ath/ath10k/testmode.c
0 → 100644
View file @
687b9308
/*
* Copyright (c) 2014 Qualcomm Atheros, Inc.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include "testmode.h"
#include <net/netlink.h>
#include <linux/firmware.h>
#include "debug.h"
#include "wmi.h"
#include "hif.h"
#include "hw.h"
#include "testmode_i.h"
static
const
struct
nla_policy
ath10k_tm_policy
[
ATH10K_TM_ATTR_MAX
+
1
]
=
{
[
ATH10K_TM_ATTR_CMD
]
=
{
.
type
=
NLA_U32
},
[
ATH10K_TM_ATTR_DATA
]
=
{
.
type
=
NLA_BINARY
,
.
len
=
ATH10K_TM_DATA_MAX_LEN
},
[
ATH10K_TM_ATTR_WMI_CMDID
]
=
{
.
type
=
NLA_U32
},
[
ATH10K_TM_ATTR_VERSION_MAJOR
]
=
{
.
type
=
NLA_U32
},
[
ATH10K_TM_ATTR_VERSION_MINOR
]
=
{
.
type
=
NLA_U32
},
};
/* Returns true if callee consumes the skb and the skb should be discarded.
* Returns false if skb is not used. Does not sleep.
*/
bool
ath10k_tm_event_wmi
(
struct
ath10k
*
ar
,
u32
cmd_id
,
struct
sk_buff
*
skb
)
{
struct
sk_buff
*
nl_skb
;
bool
consumed
;
int
ret
;
ath10k_dbg
(
ar
,
ATH10K_DBG_TESTMODE
,
"testmode event wmi cmd_id %d skb %p skb->len %d
\n
"
,
cmd_id
,
skb
,
skb
->
len
);
ath10k_dbg_dump
(
ar
,
ATH10K_DBG_TESTMODE
,
NULL
,
""
,
skb
->
data
,
skb
->
len
);
spin_lock_bh
(
&
ar
->
data_lock
);
if
(
!
ar
->
testmode
.
utf_monitor
)
{
consumed
=
false
;
goto
out
;
}
/* Only testmode.c should be handling events from utf firmware,
* otherwise all sort of problems will arise as mac80211 operations
* are not initialised.
*/
consumed
=
true
;
nl_skb
=
cfg80211_testmode_alloc_event_skb
(
ar
->
hw
->
wiphy
,
2
*
sizeof
(
u32
)
+
skb
->
len
,
GFP_ATOMIC
);
if
(
!
nl_skb
)
{
ath10k_warn
(
ar
,
"failed to allocate skb for testmode wmi event
\n
"
);
goto
out
;
}
ret
=
nla_put_u32
(
nl_skb
,
ATH10K_TM_ATTR_CMD
,
ATH10K_TM_CMD_WMI
);
if
(
ret
)
{
ath10k_warn
(
ar
,
"failed to to put testmode wmi event cmd attribute: %d
\n
"
,
ret
);
kfree_skb
(
nl_skb
);
goto
out
;
}
ret
=
nla_put_u32
(
nl_skb
,
ATH10K_TM_ATTR_WMI_CMDID
,
cmd_id
);
if
(
ret
)
{
ath10k_warn
(
ar
,
"failed to to put testmode wmi even cmd_id: %d
\n
"
,
ret
);
kfree_skb
(
nl_skb
);
goto
out
;
}
ret
=
nla_put
(
nl_skb
,
ATH10K_TM_ATTR_DATA
,
skb
->
len
,
skb
->
data
);
if
(
ret
)
{
ath10k_warn
(
ar
,
"failed to copy skb to testmode wmi event: %d
\n
"
,
ret
);
kfree_skb
(
nl_skb
);
goto
out
;
}
cfg80211_testmode_event
(
nl_skb
,
GFP_ATOMIC
);
out:
spin_unlock_bh
(
&
ar
->
data_lock
);
return
consumed
;
}
static
int
ath10k_tm_cmd_get_version
(
struct
ath10k
*
ar
,
struct
nlattr
*
tb
[])
{
struct
sk_buff
*
skb
;
int
ret
;
ath10k_dbg
(
ar
,
ATH10K_DBG_TESTMODE
,
"testmode cmd get version_major %d version_minor %d
\n
"
,
ATH10K_TESTMODE_VERSION_MAJOR
,
ATH10K_TESTMODE_VERSION_MINOR
);
skb
=
cfg80211_testmode_alloc_reply_skb
(
ar
->
hw
->
wiphy
,
nla_total_size
(
sizeof
(
u32
)));
if
(
!
skb
)
return
-
ENOMEM
;
ret
=
nla_put_u32
(
skb
,
ATH10K_TM_ATTR_VERSION_MAJOR
,
ATH10K_TESTMODE_VERSION_MAJOR
);
if
(
ret
)
{
kfree_skb
(
skb
);
return
ret
;
}
ret
=
nla_put_u32
(
skb
,
ATH10K_TM_ATTR_VERSION_MINOR
,
ATH10K_TESTMODE_VERSION_MINOR
);
if
(
ret
)
{
kfree_skb
(
skb
);
return
ret
;
}
return
cfg80211_testmode_reply
(
skb
);
}
static
int
ath10k_tm_cmd_utf_start
(
struct
ath10k
*
ar
,
struct
nlattr
*
tb
[])
{
char
filename
[
100
];
int
ret
;
ath10k_dbg
(
ar
,
ATH10K_DBG_TESTMODE
,
"testmode cmd utf start
\n
"
);
mutex_lock
(
&
ar
->
conf_mutex
);
if
(
ar
->
state
==
ATH10K_STATE_UTF
)
{
ret
=
-
EALREADY
;
goto
err
;
}
/* start utf only when the driver is not in use */
if
(
ar
->
state
!=
ATH10K_STATE_OFF
)
{
ret
=
-
EBUSY
;
goto
err
;
}
if
(
WARN_ON
(
ar
->
testmode
.
utf
!=
NULL
))
{
/* utf image is already downloaded, it shouldn't be */
ret
=
-
EEXIST
;
goto
err
;
}
snprintf
(
filename
,
sizeof
(
filename
),
"%s/%s"
,
ar
->
hw_params
.
fw
.
dir
,
ATH10K_FW_UTF_FILE
);
/* load utf firmware image */
ret
=
request_firmware
(
&
ar
->
testmode
.
utf
,
filename
,
ar
->
dev
);
if
(
ret
)
{
ath10k_warn
(
ar
,
"failed to retrieve utf firmware '%s': %d
\n
"
,
filename
,
ret
);
goto
err
;
}
spin_lock_bh
(
&
ar
->
data_lock
);
ar
->
testmode
.
utf_monitor
=
true
;
spin_unlock_bh
(
&
ar
->
data_lock
);
BUILD_BUG_ON
(
sizeof
(
ar
->
fw_features
)
!=
sizeof
(
ar
->
testmode
.
orig_fw_features
));
memcpy
(
ar
->
testmode
.
orig_fw_features
,
ar
->
fw_features
,
sizeof
(
ar
->
fw_features
));
/* utf.bin firmware image does not advertise firmware features. Do
* an ugly hack where we force the firmware features so that wmi.c
* will use the correct WMI interface.
*/
memset
(
ar
->
fw_features
,
0
,
sizeof
(
ar
->
fw_features
));
__set_bit
(
ATH10K_FW_FEATURE_WMI_10X
,
ar
->
fw_features
);
ret
=
ath10k_hif_power_up
(
ar
);
if
(
ret
)
{
ath10k_err
(
ar
,
"failed to power up hif (testmode): %d
\n
"
,
ret
);
ar
->
state
=
ATH10K_STATE_OFF
;
goto
err_fw_features
;
}
ret
=
ath10k_core_start
(
ar
,
ATH10K_FIRMWARE_MODE_UTF
);
if
(
ret
)
{
ath10k_err
(
ar
,
"failed to start core (testmode): %d
\n
"
,
ret
);
ar
->
state
=
ATH10K_STATE_OFF
;
goto
err_power_down
;
}
ar
->
state
=
ATH10K_STATE_UTF
;
ath10k_info
(
ar
,
"UTF firmware started
\n
"
);
mutex_unlock
(
&
ar
->
conf_mutex
);
return
0
;
err_power_down:
ath10k_hif_power_down
(
ar
);
err_fw_features:
/* return the original firmware features */
memcpy
(
ar
->
fw_features
,
ar
->
testmode
.
orig_fw_features
,
sizeof
(
ar
->
fw_features
));
release_firmware
(
ar
->
testmode
.
utf
);
ar
->
testmode
.
utf
=
NULL
;
err:
mutex_unlock
(
&
ar
->
conf_mutex
);
return
ret
;
}
static
void
__ath10k_tm_cmd_utf_stop
(
struct
ath10k
*
ar
)
{
lockdep_assert_held
(
&
ar
->
conf_mutex
);
ath10k_core_stop
(
ar
);
ath10k_hif_power_down
(
ar
);
spin_lock_bh
(
&
ar
->
data_lock
);
ar
->
testmode
.
utf_monitor
=
false
;
spin_unlock_bh
(
&
ar
->
data_lock
);
/* return the original firmware features */
memcpy
(
ar
->
fw_features
,
ar
->
testmode
.
orig_fw_features
,
sizeof
(
ar
->
fw_features
));
release_firmware
(
ar
->
testmode
.
utf
);
ar
->
testmode
.
utf
=
NULL
;
ar
->
state
=
ATH10K_STATE_OFF
;
}
static
int
ath10k_tm_cmd_utf_stop
(
struct
ath10k
*
ar
,
struct
nlattr
*
tb
[])
{
int
ret
;
ath10k_dbg
(
ar
,
ATH10K_DBG_TESTMODE
,
"testmode cmd utf stop
\n
"
);
mutex_lock
(
&
ar
->
conf_mutex
);
if
(
ar
->
state
!=
ATH10K_STATE_UTF
)
{
ret
=
-
ENETDOWN
;
goto
out
;
}
__ath10k_tm_cmd_utf_stop
(
ar
);
ret
=
0
;
ath10k_info
(
ar
,
"UTF firmware stopped
\n
"
);
out:
mutex_unlock
(
&
ar
->
conf_mutex
);
return
ret
;
}
static
int
ath10k_tm_cmd_wmi
(
struct
ath10k
*
ar
,
struct
nlattr
*
tb
[])
{
struct
sk_buff
*
skb
;
int
ret
,
buf_len
;
u32
cmd_id
;
void
*
buf
;
mutex_lock
(
&
ar
->
conf_mutex
);
if
(
ar
->
state
!=
ATH10K_STATE_UTF
)
{
ret
=
-
ENETDOWN
;
goto
out
;
}
if
(
!
tb
[
ATH10K_TM_ATTR_DATA
])
{
ret
=
-
EINVAL
;
goto
out
;
}
if
(
!
tb
[
ATH10K_TM_ATTR_WMI_CMDID
])
{
ret
=
-
EINVAL
;
goto
out
;
}
buf
=
nla_data
(
tb
[
ATH10K_TM_ATTR_DATA
]);
buf_len
=
nla_len
(
tb
[
ATH10K_TM_ATTR_DATA
]);
cmd_id
=
nla_get_u32
(
tb
[
ATH10K_TM_ATTR_WMI_CMDID
]);
ath10k_dbg
(
ar
,
ATH10K_DBG_TESTMODE
,
"testmode cmd wmi cmd_id %d buf %p buf_len %d
\n
"
,
cmd_id
,
buf
,
buf_len
);
ath10k_dbg_dump
(
ar
,
ATH10K_DBG_TESTMODE
,
NULL
,
""
,
buf
,
buf_len
);
skb
=
ath10k_wmi_alloc_skb
(
ar
,
buf_len
);
if
(
!
skb
)
{
ret
=
-
ENOMEM
;
goto
out
;
}
memcpy
(
skb
->
data
,
buf
,
buf_len
);
ret
=
ath10k_wmi_cmd_send
(
ar
,
skb
,
cmd_id
);
if
(
ret
)
{
ath10k_warn
(
ar
,
"failed to transmit wmi command (testmode): %d
\n
"
,
ret
);
goto
out
;
}
ret
=
0
;
out:
mutex_unlock
(
&
ar
->
conf_mutex
);
return
ret
;
}
int
ath10k_tm_cmd
(
struct
ieee80211_hw
*
hw
,
struct
ieee80211_vif
*
vif
,
void
*
data
,
int
len
)
{
struct
ath10k
*
ar
=
hw
->
priv
;
struct
nlattr
*
tb
[
ATH10K_TM_ATTR_MAX
+
1
];
int
ret
;
ret
=
nla_parse
(
tb
,
ATH10K_TM_ATTR_MAX
,
data
,
len
,
ath10k_tm_policy
);
if
(
ret
)
return
ret
;
if
(
!
tb
[
ATH10K_TM_ATTR_CMD
])
return
-
EINVAL
;
switch
(
nla_get_u32
(
tb
[
ATH10K_TM_ATTR_CMD
]))
{
case
ATH10K_TM_CMD_GET_VERSION
:
return
ath10k_tm_cmd_get_version
(
ar
,
tb
);
case
ATH10K_TM_CMD_UTF_START
:
return
ath10k_tm_cmd_utf_start
(
ar
,
tb
);
case
ATH10K_TM_CMD_UTF_STOP
:
return
ath10k_tm_cmd_utf_stop
(
ar
,
tb
);
case
ATH10K_TM_CMD_WMI
:
return
ath10k_tm_cmd_wmi
(
ar
,
tb
);
default:
return
-
EOPNOTSUPP
;
}
}
void
ath10k_testmode_destroy
(
struct
ath10k
*
ar
)
{
mutex_lock
(
&
ar
->
conf_mutex
);
if
(
ar
->
state
!=
ATH10K_STATE_UTF
)
{
/* utf firmware is not running, nothing to do */
goto
out
;
}
__ath10k_tm_cmd_utf_stop
(
ar
);
out:
mutex_unlock
(
&
ar
->
conf_mutex
);
}
drivers/net/wireless/ath/ath10k/testmode.h
0 → 100644
View file @
687b9308
/*
* Copyright (c) 2014 Qualcomm Atheros, Inc.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
#include "core.h"
#ifdef CONFIG_NL80211_TESTMODE
void
ath10k_testmode_destroy
(
struct
ath10k
*
ar
);
bool
ath10k_tm_event_wmi
(
struct
ath10k
*
ar
,
u32
cmd_id
,
struct
sk_buff
*
skb
);
int
ath10k_tm_cmd
(
struct
ieee80211_hw
*
hw
,
struct
ieee80211_vif
*
vif
,
void
*
data
,
int
len
);
#else
static
inline
void
ath10k_testmode_destroy
(
struct
ath10k
*
ar
)
{
}
static
inline
bool
ath10k_tm_event_wmi
(
struct
ath10k
*
ar
,
u32
cmd_id
,
struct
sk_buff
*
skb
)
{
return
false
;
}
static
inline
int
ath10k_tm_cmd
(
struct
ieee80211_hw
*
hw
,
struct
ieee80211_vif
*
vif
,
void
*
data
,
int
len
)
{
return
0
;
}
#endif
drivers/net/wireless/ath/ath10k/testmode_i.h
0 → 100644
View file @
687b9308
/*
* Copyright (c) 2014 Qualcomm Atheros, Inc.
*
* Permission to use, copy, modify, and/or distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/* "API" level of the ath10k testmode interface. Bump it after every
* incompatible interface change.
*/
#define ATH10K_TESTMODE_VERSION_MAJOR 1
/* Bump this after every _compatible_ interface change, for example
* addition of a new command or an attribute.
*/
#define ATH10K_TESTMODE_VERSION_MINOR 0
#define ATH10K_TM_DATA_MAX_LEN 5000
enum
ath10k_tm_attr
{
__ATH10K_TM_ATTR_INVALID
=
0
,
ATH10K_TM_ATTR_CMD
=
1
,
ATH10K_TM_ATTR_DATA
=
2
,
ATH10K_TM_ATTR_WMI_CMDID
=
3
,
ATH10K_TM_ATTR_VERSION_MAJOR
=
4
,
ATH10K_TM_ATTR_VERSION_MINOR
=
5
,
/* keep last */
__ATH10K_TM_ATTR_AFTER_LAST
,
ATH10K_TM_ATTR_MAX
=
__ATH10K_TM_ATTR_AFTER_LAST
-
1
,
};
/* All ath10k testmode interface commands specified in
* ATH10K_TM_ATTR_CMD
*/
enum
ath10k_tm_cmd
{
/* Returns the supported ath10k testmode interface version in
* ATH10K_TM_ATTR_VERSION. Always guaranteed to work. User space
* uses this to verify it's using the correct version of the
* testmode interface
*/
ATH10K_TM_CMD_GET_VERSION
=
0
,
/* Boots the UTF firmware, the netdev interface must be down at the
* time.
*/
ATH10K_TM_CMD_UTF_START
=
1
,
/* Shuts down the UTF firmware and puts the driver back into OFF
* state.
*/
ATH10K_TM_CMD_UTF_STOP
=
2
,
/* The command used to transmit a WMI command to the firmware and
* the event to receive WMI events from the firmware. Without
* struct wmi_cmd_hdr header, only the WMI payload. Command id is
* provided with ATH10K_TM_ATTR_WMI_CMDID and payload in
* ATH10K_TM_ATTR_DATA.
*/
ATH10K_TM_CMD_WMI
=
3
,
};
drivers/net/wireless/ath/ath10k/trace.h
View file @
687b9308
...
@@ -18,6 +18,7 @@
...
@@ -18,6 +18,7 @@
#if !defined(_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
#if !defined(_TRACE_H_) || defined(TRACE_HEADER_MULTI_READ)
#include <linux/tracepoint.h>
#include <linux/tracepoint.h>
#include "core.h"
#define _TRACE_H_
#define _TRACE_H_
...
@@ -39,59 +40,79 @@ static inline void trace_ ## name(proto) {}
...
@@ -39,59 +40,79 @@ static inline void trace_ ## name(proto) {}
#define ATH10K_MSG_MAX 200
#define ATH10K_MSG_MAX 200
DECLARE_EVENT_CLASS
(
ath10k_log_event
,
DECLARE_EVENT_CLASS
(
ath10k_log_event
,
TP_PROTO
(
struct
va_format
*
vaf
),
TP_PROTO
(
struct
ath10k
*
ar
,
struct
va_format
*
vaf
),
TP_ARGS
(
vaf
),
TP_ARGS
(
ar
,
vaf
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__dynamic_array
(
char
,
msg
,
ATH10K_MSG_MAX
)
__dynamic_array
(
char
,
msg
,
ATH10K_MSG_MAX
)
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
WARN_ON_ONCE
(
vsnprintf
(
__get_dynamic_array
(
msg
),
WARN_ON_ONCE
(
vsnprintf
(
__get_dynamic_array
(
msg
),
ATH10K_MSG_MAX
,
ATH10K_MSG_MAX
,
vaf
->
fmt
,
vaf
->
fmt
,
*
vaf
->
va
)
>=
ATH10K_MSG_MAX
);
*
vaf
->
va
)
>=
ATH10K_MSG_MAX
);
),
),
TP_printk
(
"%s"
,
__get_str
(
msg
))
TP_printk
(
"%s %s %s"
,
__get_str
(
driver
),
__get_str
(
device
),
__get_str
(
msg
)
)
);
);
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_err
,
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_err
,
TP_PROTO
(
struct
va_format
*
vaf
),
TP_PROTO
(
struct
ath10k
*
ar
,
struct
va_format
*
vaf
),
TP_ARGS
(
vaf
)
TP_ARGS
(
ar
,
vaf
)
);
);
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_warn
,
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_warn
,
TP_PROTO
(
struct
va_format
*
vaf
),
TP_PROTO
(
struct
ath10k
*
ar
,
struct
va_format
*
vaf
),
TP_ARGS
(
vaf
)
TP_ARGS
(
ar
,
vaf
)
);
);
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_info
,
DEFINE_EVENT
(
ath10k_log_event
,
ath10k_log_info
,
TP_PROTO
(
struct
va_format
*
vaf
),
TP_PROTO
(
struct
ath10k
*
ar
,
struct
va_format
*
vaf
),
TP_ARGS
(
vaf
)
TP_ARGS
(
ar
,
vaf
)
);
);
TRACE_EVENT
(
ath10k_log_dbg
,
TRACE_EVENT
(
ath10k_log_dbg
,
TP_PROTO
(
unsigned
int
level
,
struct
va_format
*
vaf
),
TP_PROTO
(
struct
ath10k
*
ar
,
unsigned
int
level
,
struct
va_format
*
vaf
),
TP_ARGS
(
level
,
vaf
),
TP_ARGS
(
ar
,
level
,
vaf
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__field
(
unsigned
int
,
level
)
__field
(
unsigned
int
,
level
)
__dynamic_array
(
char
,
msg
,
ATH10K_MSG_MAX
)
__dynamic_array
(
char
,
msg
,
ATH10K_MSG_MAX
)
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__entry
->
level
=
level
;
__entry
->
level
=
level
;
WARN_ON_ONCE
(
vsnprintf
(
__get_dynamic_array
(
msg
),
WARN_ON_ONCE
(
vsnprintf
(
__get_dynamic_array
(
msg
),
ATH10K_MSG_MAX
,
ATH10K_MSG_MAX
,
vaf
->
fmt
,
vaf
->
fmt
,
*
vaf
->
va
)
>=
ATH10K_MSG_MAX
);
*
vaf
->
va
)
>=
ATH10K_MSG_MAX
);
),
),
TP_printk
(
"%s"
,
__get_str
(
msg
))
TP_printk
(
"%s %s %s"
,
__get_str
(
driver
),
__get_str
(
device
),
__get_str
(
msg
)
)
);
);
TRACE_EVENT
(
ath10k_log_dbg_dump
,
TRACE_EVENT
(
ath10k_log_dbg_dump
,
TP_PROTO
(
const
char
*
msg
,
const
char
*
prefix
,
TP_PROTO
(
struct
ath10k
*
ar
,
const
char
*
msg
,
const
char
*
prefix
,
const
void
*
buf
,
size_t
buf_len
),
const
void
*
buf
,
size_t
buf_len
),
TP_ARGS
(
msg
,
prefix
,
buf
,
buf_len
),
TP_ARGS
(
ar
,
msg
,
prefix
,
buf
,
buf_len
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__string
(
msg
,
msg
)
__string
(
msg
,
msg
)
__string
(
prefix
,
prefix
)
__string
(
prefix
,
prefix
)
__field
(
size_t
,
buf_len
)
__field
(
size_t
,
buf_len
)
...
@@ -99,6 +120,8 @@ TRACE_EVENT(ath10k_log_dbg_dump,
...
@@ -99,6 +120,8 @@ TRACE_EVENT(ath10k_log_dbg_dump,
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__assign_str
(
msg
,
msg
);
__assign_str
(
msg
,
msg
);
__assign_str
(
prefix
,
prefix
);
__assign_str
(
prefix
,
prefix
);
__entry
->
buf_len
=
buf_len
;
__entry
->
buf_len
=
buf_len
;
...
@@ -106,16 +129,22 @@ TRACE_EVENT(ath10k_log_dbg_dump,
...
@@ -106,16 +129,22 @@ TRACE_EVENT(ath10k_log_dbg_dump,
),
),
TP_printk
(
TP_printk
(
"%s/%s
\n
"
,
__get_str
(
prefix
),
__get_str
(
msg
)
"%s %s %s/%s
\n
"
,
__get_str
(
driver
),
__get_str
(
device
),
__get_str
(
prefix
),
__get_str
(
msg
)
)
)
);
);
TRACE_EVENT
(
ath10k_wmi_cmd
,
TRACE_EVENT
(
ath10k_wmi_cmd
,
TP_PROTO
(
int
id
,
void
*
buf
,
size_t
buf_len
,
int
ret
),
TP_PROTO
(
struct
ath10k
*
ar
,
int
id
,
void
*
buf
,
size_t
buf_len
,
int
ret
),
TP_ARGS
(
id
,
buf
,
buf_len
,
ret
),
TP_ARGS
(
ar
,
id
,
buf
,
buf_len
,
ret
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__field
(
unsigned
int
,
id
)
__field
(
unsigned
int
,
id
)
__field
(
size_t
,
buf_len
)
__field
(
size_t
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
...
@@ -123,6 +152,8 @@ TRACE_EVENT(ath10k_wmi_cmd,
...
@@ -123,6 +152,8 @@ TRACE_EVENT(ath10k_wmi_cmd,
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__entry
->
id
=
id
;
__entry
->
id
=
id
;
__entry
->
buf_len
=
buf_len
;
__entry
->
buf_len
=
buf_len
;
__entry
->
ret
=
ret
;
__entry
->
ret
=
ret
;
...
@@ -130,7 +161,9 @@ TRACE_EVENT(ath10k_wmi_cmd,
...
@@ -130,7 +161,9 @@ TRACE_EVENT(ath10k_wmi_cmd,
),
),
TP_printk
(
TP_printk
(
"id %d len %zu ret %d"
,
"%s %s id %d len %zu ret %d"
,
__get_str
(
driver
),
__get_str
(
device
),
__entry
->
id
,
__entry
->
id
,
__entry
->
buf_len
,
__entry
->
buf_len
,
__entry
->
ret
__entry
->
ret
...
@@ -138,67 +171,85 @@ TRACE_EVENT(ath10k_wmi_cmd,
...
@@ -138,67 +171,85 @@ TRACE_EVENT(ath10k_wmi_cmd,
);
);
TRACE_EVENT
(
ath10k_wmi_event
,
TRACE_EVENT
(
ath10k_wmi_event
,
TP_PROTO
(
int
id
,
void
*
buf
,
size_t
buf_len
),
TP_PROTO
(
struct
ath10k
*
ar
,
int
id
,
void
*
buf
,
size_t
buf_len
),
TP_ARGS
(
id
,
buf
,
buf_len
),
TP_ARGS
(
ar
,
id
,
buf
,
buf_len
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__field
(
unsigned
int
,
id
)
__field
(
unsigned
int
,
id
)
__field
(
size_t
,
buf_len
)
__field
(
size_t
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__entry
->
id
=
id
;
__entry
->
id
=
id
;
__entry
->
buf_len
=
buf_len
;
__entry
->
buf_len
=
buf_len
;
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
),
),
TP_printk
(
TP_printk
(
"id %d len %zu"
,
"%s %s id %d len %zu"
,
__get_str
(
driver
),
__get_str
(
device
),
__entry
->
id
,
__entry
->
id
,
__entry
->
buf_len
__entry
->
buf_len
)
)
);
);
TRACE_EVENT
(
ath10k_htt_stats
,
TRACE_EVENT
(
ath10k_htt_stats
,
TP_PROTO
(
void
*
buf
,
size_t
buf_len
),
TP_PROTO
(
struct
ath10k
*
ar
,
void
*
buf
,
size_t
buf_len
),
TP_ARGS
(
buf
,
buf_len
),
TP_ARGS
(
ar
,
buf
,
buf_len
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__field
(
size_t
,
buf_len
)
__field
(
size_t
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__entry
->
buf_len
=
buf_len
;
__entry
->
buf_len
=
buf_len
;
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
),
),
TP_printk
(
TP_printk
(
"len %zu"
,
"%s %s len %zu"
,
__get_str
(
driver
),
__get_str
(
device
),
__entry
->
buf_len
__entry
->
buf_len
)
)
);
);
TRACE_EVENT
(
ath10k_wmi_dbglog
,
TRACE_EVENT
(
ath10k_wmi_dbglog
,
TP_PROTO
(
void
*
buf
,
size_t
buf_len
),
TP_PROTO
(
struct
ath10k
*
ar
,
void
*
buf
,
size_t
buf_len
),
TP_ARGS
(
buf
,
buf_len
),
TP_ARGS
(
ar
,
buf
,
buf_len
),
TP_STRUCT__entry
(
TP_STRUCT__entry
(
__string
(
device
,
dev_name
(
ar
->
dev
))
__string
(
driver
,
dev_driver_string
(
ar
->
dev
))
__field
(
size_t
,
buf_len
)
__field
(
size_t
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
__dynamic_array
(
u8
,
buf
,
buf_len
)
),
),
TP_fast_assign
(
TP_fast_assign
(
__assign_str
(
device
,
dev_name
(
ar
->
dev
));
__assign_str
(
driver
,
dev_driver_string
(
ar
->
dev
));
__entry
->
buf_len
=
buf_len
;
__entry
->
buf_len
=
buf_len
;
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
memcpy
(
__get_dynamic_array
(
buf
),
buf
,
buf_len
);
),
),
TP_printk
(
TP_printk
(
"len %zu"
,
"%s %s len %zu"
,
__get_str
(
driver
),
__get_str
(
device
),
__entry
->
buf_len
__entry
->
buf_len
)
)
);
);
...
...
drivers/net/wireless/ath/ath10k/txrx.c
View file @
687b9308
...
@@ -178,7 +178,7 @@ void ath10k_peer_map_event(struct ath10k_htt *htt,
...
@@ -178,7 +178,7 @@ void ath10k_peer_map_event(struct ath10k_htt *htt,
goto
exit
;
goto
exit
;
peer
->
vdev_id
=
ev
->
vdev_id
;
peer
->
vdev_id
=
ev
->
vdev_id
;
memcpy
(
peer
->
addr
,
ev
->
addr
,
ETH_ALEN
);
ether_addr_copy
(
peer
->
addr
,
ev
->
addr
);
list_add
(
&
peer
->
list
,
&
ar
->
peers
);
list_add
(
&
peer
->
list
,
&
ar
->
peers
);
wake_up
(
&
ar
->
peer_mapping_wq
);
wake_up
(
&
ar
->
peer_mapping_wq
);
}
}
...
...
drivers/net/wireless/ath/ath10k/wmi.c
View file @
687b9308
This diff is collapsed.
Click to expand it.
drivers/net/wireless/ath/ath10k/wmi.h
View file @
687b9308
...
@@ -109,6 +109,9 @@ enum wmi_service {
...
@@ -109,6 +109,9 @@ enum wmi_service {
WMI_SERVICE_BURST
,
WMI_SERVICE_BURST
,
WMI_SERVICE_SMART_ANTENNA_SW_SUPPORT
,
WMI_SERVICE_SMART_ANTENNA_SW_SUPPORT
,
WMI_SERVICE_SMART_ANTENNA_HW_SUPPORT
,
WMI_SERVICE_SMART_ANTENNA_HW_SUPPORT
,
/* keep last */
WMI_SERVICE_MAX
,
};
};
enum
wmi_10x_service
{
enum
wmi_10x_service
{
...
@@ -219,8 +222,6 @@ static inline char *wmi_service_name(int service_id)
...
@@ -219,8 +222,6 @@ static inline char *wmi_service_name(int service_id)
#undef SVCSTR
#undef SVCSTR
}
}
#define WMI_MAX_SERVICE 64
#define WMI_SERVICE_IS_ENABLED(wmi_svc_bmap, svc_id) \
#define WMI_SERVICE_IS_ENABLED(wmi_svc_bmap, svc_id) \
(__le32_to_cpu((wmi_svc_bmap)[(svc_id)/(sizeof(u32))]) & \
(__le32_to_cpu((wmi_svc_bmap)[(svc_id)/(sizeof(u32))]) & \
BIT((svc_id)%(sizeof(u32))))
BIT((svc_id)%(sizeof(u32))))
...
@@ -347,9 +348,6 @@ static inline void wmi_main_svc_map(const __le32 *in, unsigned long *out)
...
@@ -347,9 +348,6 @@ static inline void wmi_main_svc_map(const __le32 *in, unsigned long *out)
#undef SVCMAP
#undef SVCMAP
#define WMI_SERVICE_BM_SIZE \
((WMI_MAX_SERVICE + sizeof(u32) - 1)/sizeof(u32))
/* 2 word representation of MAC addr */
/* 2 word representation of MAC addr */
struct
wmi_mac_addr
{
struct
wmi_mac_addr
{
union
{
union
{
...
@@ -1271,7 +1269,6 @@ enum wmi_channel_change_cause {
...
@@ -1271,7 +1269,6 @@ enum wmi_channel_change_cause {
WMI_HT_CAP_RX_STBC | \
WMI_HT_CAP_RX_STBC | \
WMI_HT_CAP_LDPC)
WMI_HT_CAP_LDPC)
/*
/*
* WMI_VHT_CAP_* these maps to ieee 802.11ac vht capability information
* WMI_VHT_CAP_* these maps to ieee 802.11ac vht capability information
* field. The fields not defined here are not supported, or reserved.
* field. The fields not defined here are not supported, or reserved.
...
@@ -1405,7 +1402,7 @@ struct wmi_service_ready_event {
...
@@ -1405,7 +1402,7 @@ struct wmi_service_ready_event {
__le32
phy_capability
;
__le32
phy_capability
;
/* Maximum number of frag table entries that SW will populate less 1 */
/* Maximum number of frag table entries that SW will populate less 1 */
__le32
max_frag_entry
;
__le32
max_frag_entry
;
__le32
wmi_service_bitmap
[
WMI_SERVICE_BM_SIZE
];
__le32
wmi_service_bitmap
[
16
];
__le32
num_rf_chains
;
__le32
num_rf_chains
;
/*
/*
* The following field is only valid for service type
* The following field is only valid for service type
...
@@ -1444,7 +1441,7 @@ struct wmi_service_ready_event_10x {
...
@@ -1444,7 +1441,7 @@ struct wmi_service_ready_event_10x {
/* Maximum number of frag table entries that SW will populate less 1 */
/* Maximum number of frag table entries that SW will populate less 1 */
__le32
max_frag_entry
;
__le32
max_frag_entry
;
__le32
wmi_service_bitmap
[
WMI_SERVICE_BM_SIZE
];
__le32
wmi_service_bitmap
[
16
];
__le32
num_rf_chains
;
__le32
num_rf_chains
;
/*
/*
...
@@ -1473,7 +1470,6 @@ struct wmi_service_ready_event_10x {
...
@@ -1473,7 +1470,6 @@ struct wmi_service_ready_event_10x {
struct
wlan_host_mem_req
mem_reqs
[
1
];
struct
wlan_host_mem_req
mem_reqs
[
1
];
}
__packed
;
}
__packed
;
#define WMI_SERVICE_READY_TIMEOUT_HZ (5*HZ)
#define WMI_SERVICE_READY_TIMEOUT_HZ (5*HZ)
#define WMI_UNIFIED_READY_TIMEOUT_HZ (5*HZ)
#define WMI_UNIFIED_READY_TIMEOUT_HZ (5*HZ)
...
@@ -2127,7 +2123,6 @@ struct wmi_start_scan_cmd_10x {
...
@@ -2127,7 +2123,6 @@ struct wmi_start_scan_cmd_10x {
*/
*/
}
__packed
;
}
__packed
;
struct
wmi_ssid_arg
{
struct
wmi_ssid_arg
{
int
len
;
int
len
;
const
u8
*
ssid
;
const
u8
*
ssid
;
...
@@ -2188,7 +2183,6 @@ struct wmi_start_scan_arg {
...
@@ -2188,7 +2183,6 @@ struct wmi_start_scan_arg {
/* WMI_SCAN_CLASS_MASK must be the same value as IEEE80211_SCAN_CLASS_MASK */
/* WMI_SCAN_CLASS_MASK must be the same value as IEEE80211_SCAN_CLASS_MASK */
#define WMI_SCAN_CLASS_MASK 0xFF000000
#define WMI_SCAN_CLASS_MASK 0xFF000000
enum
wmi_stop_scan_type
{
enum
wmi_stop_scan_type
{
WMI_SCAN_STOP_ONE
=
0x00000000
,
/* stop by scan_id */
WMI_SCAN_STOP_ONE
=
0x00000000
,
/* stop by scan_id */
WMI_SCAN_STOP_VDEV_ALL
=
0x01000000
,
/* stop by vdev_id */
WMI_SCAN_STOP_VDEV_ALL
=
0x01000000
,
/* stop by vdev_id */
...
@@ -2373,7 +2367,6 @@ struct wmi_single_phyerr_rx_hdr {
...
@@ -2373,7 +2367,6 @@ struct wmi_single_phyerr_rx_hdr {
__le32
nf_list_1
;
__le32
nf_list_1
;
__le32
nf_list_2
;
__le32
nf_list_2
;
/* Length of the frame */
/* Length of the frame */
__le32
buf_len
;
__le32
buf_len
;
}
__packed
;
}
__packed
;
...
@@ -2475,7 +2468,6 @@ struct phyerr_fft_report {
...
@@ -2475,7 +2468,6 @@ struct phyerr_fft_report {
#define SEARCH_FFT_REPORT_REG1_NUM_STR_BINS_IB_MASK 0x000000FF
#define SEARCH_FFT_REPORT_REG1_NUM_STR_BINS_IB_MASK 0x000000FF
#define SEARCH_FFT_REPORT_REG1_NUM_STR_BINS_IB_LSB 0
#define SEARCH_FFT_REPORT_REG1_NUM_STR_BINS_IB_LSB 0
struct
phyerr_tlv
{
struct
phyerr_tlv
{
__le16
len
;
__le16
len
;
u8
tag
;
u8
tag
;
...
@@ -2506,7 +2498,6 @@ struct wmi_echo_cmd {
...
@@ -2506,7 +2498,6 @@ struct wmi_echo_cmd {
__le32
value
;
__le32
value
;
}
__packed
;
}
__packed
;
struct
wmi_pdev_set_regdomain_cmd
{
struct
wmi_pdev_set_regdomain_cmd
{
__le32
reg_domain
;
__le32
reg_domain
;
__le32
reg_domain_2G
;
__le32
reg_domain_2G
;
...
@@ -2555,7 +2546,6 @@ struct wmi_pdev_set_quiet_cmd {
...
@@ -2555,7 +2546,6 @@ struct wmi_pdev_set_quiet_cmd {
__le32
enabled
;
__le32
enabled
;
}
__packed
;
}
__packed
;
/*
/*
* 802.11g protection mode.
* 802.11g protection mode.
*/
*/
...
@@ -4293,7 +4283,6 @@ struct wmi_tbtt_offset_event {
...
@@ -4293,7 +4283,6 @@ struct wmi_tbtt_offset_event {
__le32
tbttoffset_list
[
WMI_MAX_AP_VDEV
];
__le32
tbttoffset_list
[
WMI_MAX_AP_VDEV
];
}
__packed
;
}
__packed
;
struct
wmi_peer_create_cmd
{
struct
wmi_peer_create_cmd
{
__le32
vdev_id
;
__le32
vdev_id
;
struct
wmi_mac_addr
peer_macaddr
;
struct
wmi_mac_addr
peer_macaddr
;
...
@@ -4739,6 +4728,10 @@ int ath10k_wmi_wait_for_service_ready(struct ath10k *ar);
...
@@ -4739,6 +4728,10 @@ int ath10k_wmi_wait_for_service_ready(struct ath10k *ar);
int
ath10k_wmi_wait_for_unified_ready
(
struct
ath10k
*
ar
);
int
ath10k_wmi_wait_for_unified_ready
(
struct
ath10k
*
ar
);
int
ath10k_wmi_connect
(
struct
ath10k
*
ar
);
int
ath10k_wmi_connect
(
struct
ath10k
*
ar
);
struct
sk_buff
*
ath10k_wmi_alloc_skb
(
struct
ath10k
*
ar
,
u32
len
);
int
ath10k_wmi_cmd_send
(
struct
ath10k
*
ar
,
struct
sk_buff
*
skb
,
u32
cmd_id
);
int
ath10k_wmi_pdev_set_channel
(
struct
ath10k
*
ar
,
int
ath10k_wmi_pdev_set_channel
(
struct
ath10k
*
ar
,
const
struct
wmi_channel_arg
*
);
const
struct
wmi_channel_arg
*
);
int
ath10k_wmi_pdev_suspend_target
(
struct
ath10k
*
ar
,
u32
suspend_opt
);
int
ath10k_wmi_pdev_suspend_target
(
struct
ath10k
*
ar
,
u32
suspend_opt
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment