Commit Graph

1400 Commits

Author SHA1 Message Date
Naveen Rawat
209d09342f qcacld-3.0: Fix buffer overflow in hdd_hard_start_xmit
Check STAID value returned by hdd_get_transmit_sta_id against MAX_STA,
before accessing array based on STAID index.

Change-Id: I4ac88e3d95f425ddc3a8690ef5333e0a4e67d328
CRs-Fixed: 1050083
2016-08-05 16:32:29 -07:00
Vishwajith Upendra
d17105a98b Release 5.1.0.23A
Release 5.1.0.23A

Change-Id: I0887db4ed7098dc91635e813eb778d5b639300f7
CRs-Fixed: 688141
2016-08-05 16:32:00 -07:00
Kabilan Kannan
4446dddc3a qcacld-3.0: Fix memory leak in tdls module
TDLS init/exit functions have some dead code and it causes
memory leak for each wlan on/off operation.
Remove the dead code from TDLS init/exit functions.

Change-Id: Ie43057d94a27c34e970293b5cbc75edb6c0f6ca8
CRs-Fixed: 1050841
2016-08-05 16:31:31 -07:00
Kabilan Kannan
989f457e6d qcacld-3.0: Fix timer assert in tdls module
TDLS peer idle timers will be created only for implicit and external
mode operations. But tdls exit operation try to stop these timers
without checking the state of the timers and causes assert in
timer module.
Add changes to validate timer state before calls timer stop
function.

Change-Id: I6d41bbd99b49326b5a6eb8350f67923626d42400
CRs-Fixed: 1050836
2016-08-05 16:30:53 -07:00
Vishwajith Upendra
a4f6bcf384 Release 5.1.0.23
Release 5.1.0.23

Change-Id: I781a355b11c620bfabb0a083c362c53debdd9460
CRs-Fixed: 688141
2016-08-05 16:30:28 -07:00
Selvaraj, Sridhar
172cabce97 qcacld-3.0: Make OEM response events wakeable
qcacld-2.0 to qcacld-3.0 propagation

While RTT ranging happens, userspace application initiates FTM
request via host to  FW. After sending the FTM request, host
might go to sleep mode sometimes so FW will not be able to send
the OEM response event resulting in poor ranging results.
This change registers OEM response event as WOW wakeable so FW
wakes up host whenever it receives OEM response which helps OEM
response to reach userspace application on time for better
ranging results.

Git-commit: 4de9b661e45a0bde4dfefc760edf03d1b8f4dd68
Change-Id: I71b77cfa09c5039b487e9a93490837a084314fb3
CRs-Fixed: 1018887
2016-08-05 16:30:07 -07:00
Vishwajith Upendra
d7d1c9cf24 Release 5.1.0.22Z
Release 5.1.0.22Z

Change-Id: I024f51b47bf105c1ebfc05a0c8a22628012acfa0
CRs-Fixed: 688141
2016-08-05 16:29:29 -07:00
Ravi Joshi
ae8e9a7e09 qcacld-3.0: Enable bus bw request and tcp delayed ack
Bus bandwidth request timer samples the traffic on STA and
P2P client adapters to trigger bandwidth request and also enable
tcp delayed ack trigger to cnss daemon.

CRs-Fixed: 1050190
Change-Id: Iecd8a3f3762aa4c7743fb6ea22a8216fdac2ac8c
2016-08-05 16:28:55 -07:00
Arun Khandavalli
fae9294564 qcacld-3.0: Dynamic Mode changes
Currently MCL driver loads/unloads when user tries to
Switch On/Off from GUI and load process is different
for the static and dynamic built driver.
With this feature, we shall have a uniform behavior for
static and dynamic driver,  where the driver will be
loaded once and unload never.
Mode switch for different modes is supported via sysfs entries.

Change-Id: Ica49dd289d7f1f0ad0c56af76bd7bcfeca433a2e
CRs-Fixed: 1049218
2016-08-05 11:24:29 +05:30
Arun Khandavalli
1496fcb9be qcacld-3.0: Export APIs for power on/off WLAN hardware
Export APIs to WLAN driver to power on/off WLAN hardware.

Change-Id: I3743b8fe333d3a64b01109e3e821ce44443bdafd
CRs-Fixed: 1017496
2016-08-05 11:23:56 +05:30
Arun Khandavalli
d4349a9a50 qcacld-3.0: Refactor initialization of cds modules
As a part of the dynamic mode changes, the CDS modules shall be
closed/re-opened several times. Depending on the STATE of the driver,
the modules have to be initialized.

This function shall be invoked when driver state
is OPENED(DRIVER_MODULES_OPENED) and has to be enabled.

Change-Id: Ife4a4d8121bdc5ef9ed92aa9aea1d92ee4554732
CRs-Fixed: 1045626
2016-08-05 11:22:12 +05:30
Vishwajith Upendra
89eedcc754 Release 5.1.0.22Y
Release 5.1.0.22Y

Change-Id: I543495b76ae114969255ac92eeb553d1c55b2ddf
CRs-Fixed: 688141
2016-08-04 12:35:38 -07:00
Krishna Kumaar Natarajan
cc077c2264 qcacld-3.0: Update default INI config value for rm_capability
Update default INI config value for rm_capability to indicate
support for LCI capability.

Change-Id: Id5303ffc4004e58f6302f8692a15b8040231c3a4
CRs-Fixed: 1049333
2016-08-04 12:35:37 -07:00
Krishna Kumaar Natarajan
c1fa17d047 qcacld-3.0: Remove usage of typedef for oem related structures
Remove the usage of typedef for oem data request and oem
data response data structure.

Change-Id: I94f05833baa9b6baaf2272f63a33236437a96bbf
CRs-Fixed: 1038872
2016-08-04 12:35:36 -07:00
Krishna Kumaar Natarajan
bbbf2ef17b qcacld-3.0: Remove unused data structures related to OEM message
Remove unused data structures related to OEM message

Change-Id: I33c5190b78ffff2bf160e57a6edaf4b67189062c
CRs-Fixed: 1038872
2016-08-04 12:35:34 -07:00
Krishna Kumaar Natarajan
ad79826137 qcacld-3.0: Remove global oem data request/response buffer
Remove global oem data request/response buffer.

Change-Id: I95078c985c5034d9d530ad542ace129309d79886
CRs-Fixed: 1038872
2016-08-04 12:35:33 -07:00
Krishna Kumaar Natarajan
73ea9f2259 qcacld-3.0: Remove oem data rsp passing over multiple layers
Remove oem data rsp passing over multiple layers.

This change set sends the OEM data response directly to
SME from WMA instead of going through LIM/MLM.

Change-Id: I3cff10ff7bdbcee39b39bd9ba03b5eff8444b017
CRs-Fixed: 1038872
2016-08-04 12:35:30 -07:00
Krishna Kumaar Natarajan
c5e06accd6 qcacld-3.0: Remove oem data request passing over multiple layers
Remove oem data request passing over multiple layers.

This change set sends the OEM data request directly from
SME to WMA instead of going through LIM/MLM.

Change-Id: I151fa771544e9f74b1b69b18d689176752760621
CRs-Fixed: 1038872
2016-08-04 12:35:28 -07:00
Krishna Kumaar Natarajan
9a78b25103 qcacld-3.0: Remove handling of deprecated OEM related events
Remove handling of deprecated OEM related events since FW and
userspace application will use only TLV based messaging.

Support to handle following events are removed,
WMI_OEM_CAPABILITY_EVENTID
WMI_OEM_MEASUREMENT_REPORT_EVENTID
WMI_OEM_ERROR_REPORT_EVENTID

Change-Id: Ia194f559acde6689a50c56b52078b7dc967c6159
CRs-Fixed: 1038872
2016-08-04 12:35:26 -07:00
Vishwajith Upendra
dc335378ca Release 5.1.0.22X
Release 5.1.0.22X

Change-Id: Ifc771a833269139b85f26c57062fd0ab80ca1fc0
CRs-Fixed: 688141
2016-08-03 18:57:42 -07:00
Selvaraj, Sridhar
258594ca59 qcacld-3.0: Fix uninitialized heap and stack usage
qcacld-2.0 to qcacld-3.0 propagation

Fix uninitialized stack use in csrRoamReadTSF by initializing
variable of struct type tCsrNeighborRoamBSSInfo to zero.

Git-commit: d39cf92e69222e03f89238313f5b8c100ecd4ecc
Change-Id: I4211b41b5e30d414e45691a5bab4048587cc8499
CRs-Fixed: 1018486
2016-08-03 18:57:35 -07:00
Vishwajith Upendra
c3ba2aacba Release 5.1.0.22W
Release 5.1.0.22W

Change-Id: I0ab541e388344f6635bca51386caeaa299c675ae
CRs-Fixed: 688141
2016-08-03 18:57:27 -07:00
Selvaraj, Sridhar
b5cce8783e qcacld-3.0: Fix crash in wlan_hdd_tdls_check_power_save_prohibited
qcacld-2.0 to qcacld-3.0 propagation

Due to pre-emption there could be probability that tdls context
is accessed in wlan_hdd_tdls_check_power_save_prohibited after it's
released. This will result in kernel panic.

Protect tdls context with mutex lock before accessing

Change-Id: I33369320de5b0aadae661d7d27fbc5ba18e9e409
CRs-Fixed: 990645
2016-08-03 18:57:22 -07:00
Selvaraj, Sridhar
bc950df65f qcacld-3.0: Fix stack corruption issue in sme_RrmProcessNeighborReport
qcacld-2.0 to qcacld-3.0 propagation

When STA process Neighbor report from AP, session_id is declared
as one byte variable and its overwritten with four bytes value
in csrRoamGetSessionIdFromBSSID. This is observed on enabling stack
protection in kernel config(CONFIG_CC_STACKPROTECTOR).

Fix is to declare session_id as four bytes variable.

Git-commit: 96646d1eb48c4f3bf45555b8f636f90cf925b8b8
Change-Id: I6b2fd40a5466fe5dd72d394abb682229a550e0b1
CRs-Fixed: 1025272
2016-08-03 18:57:16 -07:00
Rajeev Kumar
348ed99339 qcacld-3.0: Add memory allocation failure check for BPF instructions
Add check for BPF instructions memory allocation failure and fail
the request gracefully if memory allocation fails.

Change-Id: Ifa6cab73c59aa4a7c587fa0b7d38e9b8523a3b1c
CRs-Fixed: 1047209
2016-08-03 18:57:10 -07:00
Rajeev Kumar
e5a1682c3e qcacld-3.0: memset bpf load to zero, update the bpf enabled correctly
Propagation from qcacld-2.0 to qcacld-3.0

- Current length of bpf is not set during the reset filter. set offload
  is allocated through malloc, so invalid values for current_length
  are recieved during reset. Memset set_bpfload to zero after
  allocation.
- update the bpf service to hdd correctly depending on the
  wmi service bitmap recieved from the firmware.

Change-Id: Iaf4774865cf0698a2deebac5cea62c873146e838
CRs-Fixed: 985562
2016-08-03 18:55:55 -07:00
Vishwajith Upendra
7a6f175c1f Release 5.1.0.22V
Release 5.1.0.22V

Change-Id: I793a88218490fc765d1a9e1da80b782f9032d80c
CRs-Fixed: 688141
2016-08-03 18:34:50 -07:00
Rajeev Kumar
a78a0a4578 qcacld-3.0: Add unit test framework to validate WLAN suspend/resume features
WLAN suspend/resume feature has tight dependency on APPS platform
suspend/resume support. On new targets APPS suspend/resume is not
supported until target is feature complete. In absence of APPS
suspend/resume support testing WLAN offload features become
difficult. Add unit test framework to test WLAN suspend/resume
features using private IOCTL command by simulating APPS
suspend/resume behaviour.

Trigger WLAN suspend:
iwpriv wlan0 wlan_suspend 0 0

To resume WLAN run a ping test from access point side and very 1st
ping request unicast packet should trigger wake up.

If FW is not waking up APPS then use below command to do a manual
wake up:

Trigger WLAN resume:
iwpriv wlan0 wlan_resume 0 0

This unit test framework is only for SNOC.

Change-Id: I177a0047f460aa2a305a9e4e46fbfaa94a81dced
CRs-Fixed: 1042205
2016-08-03 18:34:46 -07:00
Vishwajith Upendra
24ec5e9a87 Release 5.1.0.22U
Release 5.1.0.22U

Change-Id: I890cb59fc99d9cbb5dfd1f64feff923521a09dab
CRs-Fixed: 688141
2016-08-03 18:34:44 -07:00
Arif Hussain
a915f49b93 qcacld-3.0: Fix memory leak in wma_roam_scan_filter
In function wma_roam_scan_filter, memory is allocated to local variable
params. And in default case of the switch, we are returning from the function
without freeing the params memory, this cause memory leak.

To fix this, free params memory before return in switch case.

Change-Id: I0a8825b44f4bcd9b05f0e1f0e6cdd0d114af0a01
CRs-Fixed: 1048116
2016-08-03 18:34:41 -07:00
Arif Hussain
d3bf1115ef qcacld-3.0: Fix memory leak in csr_update_lost_link1_cmd
In function csr_update_lost_link1_cmd, memory is allocated to
local variable struct scan_filter, further we passing this
variable to csr_roam_prepare_filter_from_profile function and
allocating memory to the members of the scan_filter. At some
point in the function we are returning without freeing memory
allocated to scan_filter, which causes memory leak.

Make sure to free scan_filter’s memory before returning.

Change-Id: I448cf0d4bb16d4769b50c96495038684909e0739
CRs-Fixed: 1048116
2016-08-03 18:34:39 -07:00
Arif Hussain
3812b9b896 qcacld-3.0: Fix out of bound access in convert_qos_mapset_frame
In function convert_qos_mapset_frame, restrict dscp_exceptions array
access index to size of array

Change-Id: I31ed8edaee1a9b3715f66686a8a45d5f2ffd4532
CRs-Fixed: 1042968
2016-08-03 18:34:36 -07:00
Vishwajith Upendra
8678fd2cae Release 5.1.0.22T
Release 5.1.0.22T

Change-Id: I68afefead63233a63ceed4f442219277ba061782
CRs-Fixed: 688141
2016-08-03 18:34:33 -07:00
Deepak Dhamdhere
5fda0e46fb Revert "qcacld-3.0: Allow Re-assoc to same AP only in open security mode"
Change-Id I35d802f564e41ee0b30386ee7b74d2b44eb80ecf

Revert this change to allow re-association to same AP which is
required for HS certification.

Change-Id: I75114b5e36b4ce6def602b9054481845ac09c56a
CRs-Fixed: 936342
2016-08-03 18:34:31 -07:00
Vishwajith Upendra
2992c8a6bd Release 5.1.0.22S
Release 5.1.0.22S

Change-Id: I102cc524c81deafbb9737be5f63635dc1878327e
CRs-Fixed: 688141
2016-08-03 18:34:28 -07:00
Rajeev Kumar
30cb676a45 qcacld-3.0: Reduce unnecessary error log levels from suspend path
Reduce some of error log levels to info level in suspend path to avoid
logging them to console.

Change-Id: I61096bdbf757cd21f959fa716f35f65cd27cc9cc
CRs-Fixed: 1048395
2016-08-03 18:34:23 -07:00
Vishwajith Upendra
695547deaa Release 5.1.0.22R
Release 5.1.0.22R

Change-Id: I36091d1f7d04ce2f8785fae30949424a2adf00de
CRs-Fixed: 688141
2016-08-03 18:34:20 -07:00
Manjeet Singh
d295b1d8fd qcacld-3.0: Reduce hdd_hostapd_sap_event_cb frame size
In function hdd_hostapd_sap_event_cb frame size exceeds 1024 bytes
due to changes to some structures in msm-4.4 kernel, so compilation
for 32-bit systems might fail
Thus, reduce structure allocations on heap instead of stack in
hdd_hostapd_sap_event_cb.

Change-Id: Ie710afbd6c066a3d770c6c9aac0cfd675ea57f53
CRs-fixed: 1046882
2016-08-03 18:34:16 -07:00
Sandeep Puligilla
d180c5ece8 qcacld-3.0: Fix compiler warning when p2p_debug disabled
Unused variable compiler warning when WLAN_FEATURE_P2P_DEBUG disabled.

Create conditionally defined functions for debugging code.

Change-Id: I310bffef89b879c964a7c47a58f905503df709d2
CRs-Fixed: 1027738
2016-08-03 18:32:20 -07:00
Vishwajith Upendra
40512207de Release 5.1.0.22Q
Release 5.1.0.22Q

Change-Id: Iada9a919252568fa84397a90b7ccc8c2e047b50c
CRs-Fixed: 688141
2016-08-01 16:31:44 -07:00
Vishwajith Upendra
206a927bf8 Release 5.1.0.22P
Release 5.1.0.22P

Change-Id: Ibfaf4d623086015d682b6a1149871c84aa84f48f
CRs-Fixed: 688141
2016-08-01 13:33:25 -07:00
Sandeep Puligilla
0241f010fe qcacld-3.0: Handle eCSR_ROAM_CANCELLED at HDD
connection status is not updated at HDD because
eCSR_ROAM_CANCELLED is not handled at hdd callback.

Added support for eCSR_ROAM_CANCELLED so that HDD updates
connection status to upper layers.

Change-Id: I4c185bb3a370a0562de6431fde8952c68789de53
CRs-Fixed: 1043090
2016-08-01 13:33:24 -07:00
Vishwajith Upendra
3d2540f06b Release 5.1.0.22O
Release 5.1.0.22O

Change-Id: Iea513d766d38222c5d912e4fb133ee4498b45005
CRs-Fixed: 688141
2016-08-01 12:34:06 -07:00
Mohit Khanna
3aee13142b qcacld-3.0: Debug commit to track peer refcount
Add prints to track how peer->ref_cnt and peer_id_ref_cnt change

Change-Id: I518f58ec053e53ec2d82bcce85f872cd48029c99
CRs-Fixed: 1046458
2016-08-01 12:34:05 -07:00
Vishwajith Upendra
7f2d07eede Release 5.1.0.22N
Release 5.1.0.22N

Change-Id: I9abf19890db0fad51a9d2779620a8dc9afa4ef18
CRs-Fixed: 688141
2016-07-31 01:06:22 -07:00
Arif Hussain
174c3fcf46 qcacld-3.0: Avoid sending invalid frequency to ieee80211_frequency_to_channel
Avoid converting invalid frequency i.e zero frequency to channel using
ieee80211_frequency_to_channel() function.

Change-Id: I4a32591e313183348180a1d30a950b4b174a27cc
CRs-Fixed: 1047642
2016-07-31 01:06:22 -07:00
Arif Hussain
49a5ffc904 qcacld-3.0: Fix debug log in wma_send_peer_assoc
In function wma_send_peer_assoc, logging error when wmi_unified_peer_assoc_send
failed. But error type used in this log is wrong, use "status" instead of "ret".

Change-Id: I8dbdd68e16d665e5a7749e10c7006da9f96a6fd7
CRs-Fixed: 1042968
2016-07-31 01:06:21 -07:00
Arif Hussain
b8fef841a7 qcacld-3.0: Fix uninitialized variable use in wma_get_mcs_idx
In function wma_get_mcs_idx variable "match_rate"  is not initialized.
Initialize "match_rate" to avoid dereferencing uninitialized variable.

Change-Id: Id4c7e1913628007087c58149e4b7033320d4cc79
CRs-Fixed: 1042968
2016-07-31 01:06:20 -07:00
Arif Hussain
89697c49b0 qcacld-3.0: Fix possible uninitialized variable access in wma_add_bss_sta_mode
In function wma_add_bss_sta_mode, variable "peer" is not initialized.
Possibly we may pass this variable to wma_remove_peer function as is
and that can be dereferenced inside wma_remove_peer function.

So initialize peer with NULL to avoid dereferencing uninitialized variable.

Change-Id: Ibc484759b5e92052a3500137464e47287ccad939
CRs-Fixed: 1042968
2016-07-31 01:06:19 -07:00
Arif Hussain
a86aa4362b qcacld-3.0: Code clean-up in rrm_process_beacon_report_xmit
Remove extra variable "flag_bss_present" used to indicate if scan
result present based on pointer "bss_desc". Instead use "bss_desc"
itself.

Change-Id: I3fe5474d41219b44cbe38fa88c51013526c081c9
CRs-Fixed: 1042968
2016-07-31 01:06:17 -07:00