diff mbox

[V3.18] rtlwifi: Add check for get_btc_status callback

Message ID 544A80B5.1090604@lwfinger.net
State Awaiting Upstream, archived
Delegated to: David Miller
Headers show

Commit Message

Larry Finger Oct. 24, 2014, 4:39 p.m. UTC
On 10/23/2014 09:09 PM, Mike Galbraith wrote:
> On Thu, 2014-10-23 at 13:23 -0500, Larry Finger wrote:
>
>> I know "rtl8192se:rtl92se_get_desc(): ERR rxdesc :4 not process" messages will
>> be fixed by the attached patch. Please send the logs after this is applied.
>
> Both applied.
>
> [   17.717226] cfg80211: World regulatory domain updated:
> [   17.719760] cfg80211:  DFS Master region: unset
> [   17.719801] cfg80211:   (start_freq - end_freq @ bandwidth), (max_antenna_gain, max_eirp), (dfs_cac_time)
> [   17.724656] cfg80211:   (2402000 KHz - 2472000 KHz @ 40000 KHz), (300 mBi, 2000 mBm), (N/A)
> [   17.727087] cfg80211:   (2457000 KHz - 2482000 KHz @ 40000 KHz), (300 mBi, 2000 mBm), (N/A)
> [   17.729422] cfg80211:   (2474000 KHz - 2494000 KHz @ 20000 KHz), (300 mBi, 2000 mBm), (N/A)
> [   17.731592] cfg80211:   (5170000 KHz - 5250000 KHz @ 40000 KHz), (300 mBi, 2000 mBm), (N/A)
> [   17.733702] cfg80211:   (5735000 KHz - 5835000 KHz @ 40000 KHz), (300 mBi, 2000 mBm), (N/A)
> [   17.858132] input: HDA Digital PCBeep as /devices/pci0000:00/0000:00:1b.0/sound/card0/hdaudioC0D0/input13
> [   17.861052] input: HDA Intel Mic as /devices/pci0000:00/0000:00:1b.0/sound/card0/input14
> [   17.863153] input: HDA Intel Headphone as /devices/pci0000:00/0000:00:1b.0/sound/card0/input15
> [   17.865356] input: HDA Intel HDMI/DP,pcm=3 as /devices/pci0000:00/0000:00:1b.0/sound/card0/input16
> [   18.259078] toshiba_acpi: Unknown key 401
> [   18.661507] Adding 2096476k swap on /dev/sda2.  Priority:-1 extents:1 across:2096476k FS
> [   18.984217] rtl8192se 0000:08:00.0: enabling device (0000 -> 0003)
> [   19.025036] rtl8192se: FW Power Save off (module option)
> [   19.027195] rtl8192se: Driver for Realtek RTL8192SE/RTL8191SE
> [   19.027195] Loading firmware rtlwifi/rtl8192sefw.bin
> [   19.095134] ieee80211 phy0: Selected rate control algorithm 'rtl_rc'
> [   19.152305] ------------[ cut here ]------------
> [   19.154367] WARNING: CPU: 0 PID: 59 at fs/sysfs/dir.c:31 sysfs_warn_dup+0x68/0x80()
> [   19.156445] sysfs: cannot create duplicate filename '/devices/pci0000:00/0000:00:1c.5/0000:08:00.0/ieee80211/phy0'
> [   19.158562] Modules linked in: arc4 rtl8192se rtl_pci rtlwifi mac80211 snd_hda_codec_hdmi snd_hda_codec_conexant snd_hda_codec_generic uvcvideo btusb videobuf2_core coretemp snd_hda_intel snd_hda_controller snd_hda_codec iTCO_wdt iTCO_vendor_support bluetooth cfg80211 v4l2_common snd_hwdep microcode snd_pcm videodev lpc_ich snd_seq serio_raw snd_timer joydev i2c_i801 videobuf2_vmalloc videobuf2_memops mfd_core snd_seq_device toshiba_acpi sparse_keymap rfkill battery ac snd wmi toshiba_bluetooth toshiba_haps soundcore acpi_cpufreq sg autofs4 i915 drm_kms_helper drm i2c_algo_bit thermal video processor thermal_sys button scsi_dh_rdac scsi_dh_alua scsi_dh_emc scsi_dh_hp_sw scsi_dh netconsole atl1c
> [   19.170633] CPU: 0 PID: 59 Comm: kworker/0:3 Not tainted 3.18.0-master #52
> [   19.173036] Hardware name: TOSHIBA ��������������������������������/��������������������������������, BIOS V1.70    09/29/2009
> [   19.175634] Workqueue: events request_firmware_work_func
> [   19.178247]  0000000000000009 ffff8800379d7a98 ffffffff815878e0 0000000000000001
> [   19.180947]  ffff8800379d7ae8 ffff8800379d7ad8 ffffffff8104c801 00000000000035e0
> [   19.183573]  ffff88003706e000 ffff8800aff86d80 ffff8800b0093d48 ffff88013b027098
> [   19.186231] Call Trace:
> [   19.188885]  [<ffffffff815878e0>] dump_stack+0x46/0x58
> [   19.191545]  [<ffffffff8104c801>] warn_slowpath_common+0x81/0xa0
> [   19.194173]  [<ffffffff8104c866>] warn_slowpath_fmt+0x46/0x50
> [   19.196707]  [<ffffffff811d06c8>] ? kernfs_path+0x48/0x60
> [   19.199138]  [<ffffffff811d3b48>] sysfs_warn_dup+0x68/0x80
> [   19.201587]  [<ffffffff811d3bee>] sysfs_create_dir_ns+0x8e/0xa0
> [   19.204057]  [<ffffffff81286879>] kobject_add_internal+0xc9/0x400
> [   19.206495]  [<ffffffff81286fe0>] kobject_add+0x60/0xb0
> [   19.208938]  [<ffffffff8158c226>] ? mutex_lock+0x16/0x37
> [   19.211321]  [<ffffffff81380d54>] device_add+0x104/0x600
> [   19.213692]  [<ffffffff8114b98e>] ? lazy_max_pages+0x1e/0x30
> [   19.216100]  [<ffffffffa02e9d0d>] wiphy_register+0x3fd/0x710 [cfg80211]
> [   19.218504]  [<ffffffff8114d352>] ? __vunmap+0xc2/0x110
> [   19.220957]  [<ffffffffa0457cfc>] ? ieee80211_register_hw+0x1ec/0x9a0 [mac80211]
> [   19.223447]  [<ffffffffa0457e78>] ieee80211_register_hw+0x368/0x9a0 [mac80211]
> [   19.225916]  [<ffffffffa050a26b>] rtl92se_fw_cb+0xab/0x1d0 [rtl8192se]
> [   19.228362]  [<ffffffff81393d80>] request_firmware_work_func+0x30/0x60
> [   19.230779]  [<ffffffff8106270d>] process_one_work+0x14d/0x3d0
> [   19.233167]  [<ffffffff81062ab1>] worker_thread+0x121/0x480
> [   19.235498]  [<ffffffff81062990>] ? process_one_work+0x3d0/0x3d0
> [   19.237861]  [<ffffffff81067319>] kthread+0xc9/0xe0
> [   19.240213]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   19.242534]  [<ffffffff8158e26c>] ret_from_fork+0x7c/0xb0
> [   19.244830]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   19.247125] ---[ end trace 0734244a9269eff8 ]---
> [   19.249416] ------------[ cut here ]------------
> [   19.251626] WARNING: CPU: 0 PID: 59 at lib/kobject.c:240 kobject_add_internal+0x294/0x400()
> [   19.253876] kobject_add_internal failed for phy0 with -EEXIST, don't try to register things with the same name in the same directory.
> [   19.256197] Modules linked in: arc4 rtl8192se rtl_pci rtlwifi mac80211 snd_hda_codec_hdmi snd_hda_codec_conexant snd_hda_codec_generic uvcvideo btusb videobuf2_core coretemp snd_hda_intel snd_hda_controller snd_hda_codec iTCO_wdt iTCO_vendor_support bluetooth cfg80211 v4l2_common snd_hwdep microcode snd_pcm videodev lpc_ich snd_seq serio_raw snd_timer joydev i2c_i801 videobuf2_vmalloc videobuf2_memops mfd_core snd_seq_device toshiba_acpi sparse_keymap rfkill battery ac snd wmi toshiba_bluetooth toshiba_haps soundcore acpi_cpufreq sg autofs4 i915 drm_kms_helper drm i2c_algo_bit thermal video processor thermal_sys button scsi_dh_rdac scsi_dh_alua scsi_dh_emc scsi_dh_hp_sw scsi_dh netconsole atl1c
> [   19.269327] CPU: 0 PID: 59 Comm: kworker/0:3 Tainted: G        W      3.18.0-master #52
> [   19.271976] Hardware name: TOSHIBA ��������������������������������/��������������������������������, BIOS V1.70    09/29/2009
> [   19.274674] Workqueue: events request_firmware_work_func
> [   19.277301]  0000000000000009 ffff8800379d7af8 ffffffff815878e0 0000000000000001
> [   19.279875]  ffff8800379d7b48 ffff8800379d7b38 ffffffff8104c801 ffff8800379d7b38
> [   19.282376]  ffff880137730350 00000000ffffffef ffff880036a9c940 ffff88013b027098
> [   19.284844] Call Trace:
> [   19.287151]  [<ffffffff815878e0>] dump_stack+0x46/0x58
> [   19.289474]  [<ffffffff8104c801>] warn_slowpath_common+0x81/0xa0
> [   19.291751]  [<ffffffff8104c866>] warn_slowpath_fmt+0x46/0x50
> [   19.293979]  [<ffffffff81286a44>] kobject_add_internal+0x294/0x400
> [   19.296192]  [<ffffffff81286fe0>] kobject_add+0x60/0xb0
> [   19.298381]  [<ffffffff8158c226>] ? mutex_lock+0x16/0x37
> [   19.300578]  [<ffffffff81380d54>] device_add+0x104/0x600
> [   19.302734]  [<ffffffff8114b98e>] ? lazy_max_pages+0x1e/0x30
> [   19.304909]  [<ffffffffa02e9d0d>] wiphy_register+0x3fd/0x710 [cfg80211]
> [   19.307110]  [<ffffffff8114d352>] ? __vunmap+0xc2/0x110
> [   19.309305]  [<ffffffffa0457cfc>] ? ieee80211_register_hw+0x1ec/0x9a0 [mac80211]
> [   19.311512]  [<ffffffffa0457e78>] ieee80211_register_hw+0x368/0x9a0 [mac80211]
> [   19.313767]  [<ffffffffa050a26b>] rtl92se_fw_cb+0xab/0x1d0 [rtl8192se]
> [   19.315998]  [<ffffffff81393d80>] request_firmware_work_func+0x30/0x60
> [   19.318260]  [<ffffffff8106270d>] process_one_work+0x14d/0x3d0
> [   19.320501]  [<ffffffff81062ab1>] worker_thread+0x121/0x480
> [   19.322732]  [<ffffffff81062990>] ? process_one_work+0x3d0/0x3d0
> [   19.324987]  [<ffffffff81067319>] kthread+0xc9/0xe0
> [   19.327246]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   19.329517]  [<ffffffff8158e26c>] ret_from_fork+0x7c/0xb0
> [   19.331757]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   19.334039] ---[ end trace 0734244a9269eff9 ]---
> [   19.336275] rtl8192se:rtl92se_fw_cb():<0-0> Can't register mac80211 hw
> [   20.108822] EXT4-fs (sda1): mounted filesystem with ordered data mode. Opts: acl
> [   24.761182] BUG: unable to handle kernel NULL pointer dereference at           (null)
> [   24.762764] IP: [<          (null)>]           (null)
> [   24.764106] PGD 0
> [   24.764106] Oops: 0010 [#1] SMP
> [   24.764106] Modules linked in: arc4 rtl8192se rtl_pci rtlwifi mac80211 snd_hda_codec_hdmi snd_hda_codec_conexant snd_hda_codec_generic uvcvideo btusb videobuf2_core coretemp snd_hda_intel snd_hda_controller snd_hda_codec iTCO_wdt iTCO_vendor_support bluetooth cfg80211 v4l2_common snd_hwdep microcode snd_pcm videodev lpc_ich snd_seq serio_raw snd_timer joydev i2c_i801 videobuf2_vmalloc videobuf2_memops mfd_core snd_seq_device toshiba_acpi sparse_keymap rfkill battery ac snd wmi toshiba_bluetooth toshiba_haps soundcore acpi_cpufreq sg autofs4 i915 drm_kms_helper drm i2c_algo_bit thermal video processor thermal_sys button scsi_dh_rdac scsi_dh_alua scsi_dh_emc scsi_dh_hp_sw scsi_dh netconsole atl1c
> [   24.764106] CPU: 1 PID: 54 Comm: kworker/1:2 Tainted: G        W      3.18.0-master #52
> [   24.764106] Hardware name: TOSHIBA ��������������������������������/��������������������������������, BIOS V1.70    09/29/2009
> [   24.764106] Workqueue: rtl92s_pci rtl_watchdog_wq_callback [rtlwifi]
> [   24.764106] task: ffff88013614c350 ti: ffff880136150000 task.ti: ffff880136150000
> [   24.764106] RIP: 0010:[<0000000000000000>]  [<          (null)>]           (null)
> [   24.764106] RSP: 0018:ffff880136153d80  EFLAGS: 00010293
> [   24.764106] RAX: ffffffffa05103c0 RBX: ffff8801377319c0 RCX: 0000000000000000
> [   24.764106] RDX: 0000000000000001 RSI: 000000000000005d RDI: ffff880137730620
> [   24.764106] RBP: ffff880136153df8 R08: ffff88013fd12380 R09: 0000000000000001
> [   24.764106] R10: 0000000000000002 R11: 0000000000000293 R12: ffff880137730620
> [   24.764106] R13: 0000000000000000 R14: 0000000000000000 R15: 0000000000000000
> [   24.764106] FS:  0000000000000000(0000) GS:ffff88013fd00000(0000) knlGS:0000000000000000
> [   24.764106] CS:  0010 DS: 0000 ES: 0000 CR0: 000000008005003b
> [   24.764106] CR2: 0000000000000000 CR3: 000000013b249000 CR4: 00000000000407e0
> [   24.764106] Stack:
> [   24.764106]  ffffffffa051e51e ffff88013fd12b00 0000000000000000 ffff88013fd12b00
> [   24.764106]  0000000000000000 0000000000000000 0000000000000000 0000000000000000
> [   24.764106]  0000000000000000 ffff880136153e38 ffff880137731be0 ffff880136126b80
> [   24.764106] Call Trace:
> [   24.764106]  [<ffffffffa051e51e>] ? rtl_watchdog_wq_callback+0xfe/0x420 [rtlwifi]
> [   24.764106]  [<ffffffff8106270d>] process_one_work+0x14d/0x3d0
> [   24.764106]  [<ffffffff81062ab1>] worker_thread+0x121/0x480
> [   24.764106]  [<ffffffff81062990>] ? process_one_work+0x3d0/0x3d0
> [   24.764106]  [<ffffffff81067319>] kthread+0xc9/0xe0
> [   24.764106]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   24.764106]  [<ffffffff8158e26c>] ret_from_fork+0x7c/0xb0
> [   24.764106]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   24.764106] Code:  Bad RIP value.
> [   24.764106] RIP  [<          (null)>]           (null)
> [   24.764106]  RSP <ffff880136153d80>
> [   24.764106] CR2: 0000000000000000
> [   24.764106] ---[ end trace 0734244a9269effa ]---
> [   24.855146] IPv6: ADDRCONF(NETDEV_UP): wlan0: link is not ready
> [   24.857620] BUG: unable to handle kernel paging request at ffffffffffffffd8
> [   24.859873] IP: [<ffffffff810678f1>] kthread_data+0x11/0x20
> [   24.861381] PGD 1a16067 PUD 1a18067 PMD 0
> [   24.861381] Oops: 0000 [#2] SMP
> [   24.861381] Modules linked in: arc4 rtl8192se rtl_pci rtlwifi mac80211 snd_hda_codec_hdmi snd_hda_codec_conexant snd_hda_codec_generic uvcvideo btusb videobuf2_core coretemp snd_hda_intel snd_hda_controller snd_hda_codec iTCO_wdt iTCO_vendor_support bluetooth cfg80211 v4l2_common snd_hwdep microcode snd_pcm videodev lpc_ich snd_seq serio_raw snd_timer joydev i2c_i801 videobuf2_vmalloc videobuf2_memops mfd_core snd_seq_device toshiba_acpi sparse_keymap rfkill battery ac snd wmi toshiba_bluetooth toshiba_haps soundcore acpi_cpufreq sg autofs4 i915 drm_kms_helper drm i2c_algo_bit thermal video processor thermal_sys button scsi_dh_rdac scsi_dh_alua scsi_dh_emc scsi_dh_hp_sw scsi_dh netconsole atl1c
> [   24.861381] CPU: 1 PID: 54 Comm: kworker/1:2 Tainted: G      D W      3.18.0-master #52
> [   24.861381] Hardware name: TOSHIBA ��������������������������������/��������������������������������, BIOS V1.70    09/29/2009
> [   24.861381] task: ffff88013614c350 ti: ffff880136150000 task.ti: ffff880136150000
> [   24.861381] RIP: 0010:[<ffffffff810678f1>]  [<ffffffff810678f1>] kthread_data+0x11/0x20
> [   24.861381] RSP: 0018:ffff880136153990  EFLAGS: 00010092
> [   24.861381] RAX: 0000000000000000 RBX: 0000000000000001 RCX: 0000000171a414dc
> [   24.861381] RDX: 0000000000000000 RSI: 0000000000000001 RDI: ffff88013614c350
> [   24.861381] RBP: ffff8801361539a8 R08: ffff88013614fcd0 R09: 00000000000003d9
> [   24.861381] R10: 000000000000bc00 R11: 0000000000008ddc R12: ffff88013fd12b00
> [   24.861381] R13: 0000000000000001 R14: 0000000000000000 R15: ffff88013614c350
> [   24.861381] FS:  0000000000000000(0000) GS:ffff88013fd00000(0000) knlGS:0000000000000000
> [   24.861381] CS:  0010 DS: 0000 ES: 0000 CR0: 000000008005003b
> [   24.861381] CR2: 0000000000000028 CR3: 0000000035eba000 CR4: 00000000000407e0
> [   24.861381] Stack:
> [   24.861381]  ffffffff81063145 ffff8801361539a8 ffff88013614c350 ffff880136153a18
> [   24.861381]  ffffffff8158a1ae ffff88013614c350 0000000000012b00 ffff880136153fd8
> [   24.861381]  0000000000012b00 ffff880136153a08 ffff88013614c350 ffff88013614c350
> [   24.861381] Call Trace:
> [   24.861381]  [<ffffffff81063145>] ? wq_worker_sleeping+0x15/0xa0
> [   24.861381]  [<ffffffff8158a1ae>] __schedule+0x53e/0x810
> [   24.861381]  [<ffffffff8158a4a9>] schedule+0x29/0x70
> [   24.861381]  [<ffffffff8104dfa2>] do_exit+0x6a2/0x9e0
> [   24.861381]  [<ffffffff8100645e>] oops_end+0x8e/0xd0
> [   24.861381]  [<ffffffff815829aa>] no_context+0x248/0x298
> [   24.861381]  [<ffffffff81582a67>] __bad_area_nosemaphore+0x6d/0x1c6
> [   24.861381]  [<ffffffff81582bd3>] bad_area_nosemaphore+0x13/0x15
> [   24.861381]  [<ffffffff8103d67c>] __do_page_fault+0x9c/0x530
> [   24.861381]  [<ffffffff812843c0>] ? cpumask_next_and+0x30/0x50
> [   24.861381]  [<ffffffff8107a24e>] ? load_balance+0x23e/0x830
> [   24.861381]  [<ffffffff8103db1c>] do_page_fault+0xc/0x10
> [   24.861381]  [<ffffffff8158fe22>] page_fault+0x22/0x30
> [   24.861381]  [<ffffffffa051e51e>] ? rtl_watchdog_wq_callback+0xfe/0x420 [rtlwifi]
> [   24.861381]  [<ffffffff8106270d>] process_one_work+0x14d/0x3d0
> [   24.861381]  [<ffffffff81062ab1>] worker_thread+0x121/0x480
> [   24.861381]  [<ffffffff81062990>] ? process_one_work+0x3d0/0x3d0
> [   24.861381]  [<ffffffff81067319>] kthread+0xc9/0xe0
> [   24.861381]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   24.861381]  [<ffffffff8158e26c>] ret_from_fork+0x7c/0xb0
> [   24.861381]  [<ffffffff81067250>] ? kthread_create_on_node+0x180/0x180
> [   24.861381] Code: 48 89 e5 5d 48 8b 40 c8 48 c1 e8 02 83 e0 01 c3 66 2e 0f 1f 84 00 00 00 00 00 66 66 66 66 90 48 8b 87 60 04 00 00 55 48 89 e5 5d <48> 8b 40 d8 c3 66 2e 0f 1f 84 00 00 00 00 00 66 66 66 66 90 55
> [   24.861381] RIP  [<ffffffff810678f1>] kthread_data+0x11/0x20
> [   24.861381]  RSP <ffff880136153990>
> [   24.861381] CR2: ffffffffffffffd8
> [   24.861381] ---[ end trace 0734244a9269effb ]---
> [   24.861381] Fixing recursive fault but reboot is needed!
> [   24.861381] Kernel panic - not syncing: Watchdog detected hard LOCKUP on cpu 1
> [   24.861381] Shutting down cpus with NMI
> [   24.861381] Kernel Offset: 0x0 from 0xffffffff81000000 (relocation range: 0xffffffff80000000-0xffffffff9fffffff)
> [   24.861381] drm_kms_helper: panic occurred, switching back to text console
> [   24.861381] Rebooting in 60 seconds..

Please try the attached patch. It replaces the second one I sent you. I will 
probably redo it before submitting the final copy, but this should work.

Larry

Comments

Murilo Opsfelder Araújo Oct. 24, 2014, 6:13 p.m. UTC | #1
On 10/24/2014 02:39 PM, Larry Finger wrote:
[...]
>
> Please try the attached patch. It replaces the second one I sent you. I
> will probably redo it before submitting the final copy, but this should
> work.
>
> Larry
>
Hi, Larry.

I've tried your patch on top of next-20141023 and it is still crashing 
on my laptop:

http://opsfelder.com/~murilo/lkml/next-20141023_plus_larry_patch_v2.jpg
diff mbox

Patch

diff --git a/drivers/net/wireless/rtlwifi/base.c b/drivers/net/wireless/rtlwifi/base.c
index 58ba718..a23ff78 100644
--- a/drivers/net/wireless/rtlwifi/base.c
+++ b/drivers/net/wireless/rtlwifi/base.c
@@ -1234,7 +1234,8 @@  EXPORT_SYMBOL_GPL(rtl_action_proc);
 static void setup_arp_tx(struct rtl_priv *rtlpriv, struct rtl_ps_ctl *ppsc)
 {
 	rtlpriv->ra.is_special_data = true;
-	if (rtlpriv->cfg->ops->get_btc_status())
+	if (rtlpriv->cfg->ops->get_btc_status &&
+	    rtlpriv->cfg->ops->get_btc_status())
 		rtlpriv->btcoexist.btc_ops->btc_special_packet_notify(
 					rtlpriv, 1);
 	rtlpriv->enter_ps = false;
@@ -1629,7 +1630,8 @@  void rtl_watchdog_wq_callback(void *data)
 		}
 	}
 
-	if (rtlpriv->cfg->ops->get_btc_status())
+	if (rtlpriv->cfg->ops->get_btc_status &&
+	    rtlpriv->cfg->ops->get_btc_status())
 		rtlpriv->btcoexist.btc_ops->btc_periodical(rtlpriv);
 
 	rtlpriv->link_info.bcn_rx_inperiod = 0;
diff --git a/drivers/net/wireless/rtlwifi/core.c b/drivers/net/wireless/rtlwifi/core.c
index f6179bc..686d256 100644
--- a/drivers/net/wireless/rtlwifi/core.c
+++ b/drivers/net/wireless/rtlwifi/core.c
@@ -1133,7 +1133,8 @@  static void rtl_op_bss_info_changed(struct ieee80211_hw *hw,
 		ppsc->report_linked = (mstatus == RT_MEDIA_CONNECT) ?
 				      true : false;
 
-		if (rtlpriv->cfg->ops->get_btc_status())
+		if (rtlpriv->cfg->ops->get_btc_status &&
+		    rtlpriv->cfg->ops->get_btc_status())
 			rtlpriv->btcoexist.btc_ops->btc_mediastatus_notify(
 							rtlpriv, mstatus);
 	}
@@ -1373,7 +1374,8 @@  static void rtl_op_sw_scan_start(struct ieee80211_hw *hw)
 		return;
 	}
 
-	if (rtlpriv->cfg->ops->get_btc_status())
+	if (rtlpriv->cfg->ops->get_btc_status &&
+	    rtlpriv->cfg->ops->get_btc_status())
 		rtlpriv->btcoexist.btc_ops->btc_scan_notify(rtlpriv, 1);
 
 	if (rtlpriv->dm.supp_phymode_switch) {
@@ -1425,7 +1427,8 @@  static void rtl_op_sw_scan_complete(struct ieee80211_hw *hw)
 	}
 
 	rtlpriv->cfg->ops->scan_operation_backup(hw, SCAN_OPT_RESTORE);
-	if (rtlpriv->cfg->ops->get_btc_status())
+	if (rtlpriv->cfg->ops->get_btc_status &&
+	    rtlpriv->cfg->ops->get_btc_status())
 		rtlpriv->btcoexist.btc_ops->btc_scan_notify(rtlpriv, 0);
 }
 
diff --git a/drivers/net/wireless/rtlwifi/pci.c b/drivers/net/wireless/rtlwifi/pci.c
index 25daa87..ed3364d 100644
--- a/drivers/net/wireless/rtlwifi/pci.c
+++ b/drivers/net/wireless/rtlwifi/pci.c
@@ -1833,7 +1833,8 @@  static void rtl_pci_stop(struct ieee80211_hw *hw)
 	unsigned long flags;
 	u8 RFInProgressTimeOut = 0;
 
-	if (rtlpriv->cfg->ops->get_btc_status())
+	if (rtlpriv->cfg->ops->get_btc_status &&
+	    rtlpriv->cfg->ops->get_btc_status())
 		rtlpriv->btcoexist.btc_ops->btc_halt_notify();
 
 	/*
diff --git a/drivers/net/wireless/rtlwifi/ps.c b/drivers/net/wireless/rtlwifi/ps.c
index b69321d..2278af9 100644
--- a/drivers/net/wireless/rtlwifi/ps.c
+++ b/drivers/net/wireless/rtlwifi/ps.c
@@ -261,7 +261,8 @@  void rtl_ips_nic_off_wq_callback(void *data)
 			ppsc->in_powersavemode = true;
 
 			/* call before RF off */
-			if (rtlpriv->cfg->ops->get_btc_status())
+			if (rtlpriv->cfg->ops->get_btc_status &&
+			    rtlpriv->cfg->ops->get_btc_status())
 				rtlpriv->btcoexist.btc_ops->btc_ips_notify(rtlpriv,
 									ppsc->inactive_pwrstate);
 
@@ -306,7 +307,8 @@  void rtl_ips_nic_on(struct ieee80211_hw *hw)
 			ppsc->in_powersavemode = false;
 			_rtl_ps_inactive_ps(hw);
 			/* call after RF on */
-			if (rtlpriv->cfg->ops->get_btc_status())
+			if (rtlpriv->cfg->ops->get_btc_status &&
+			    rtlpriv->cfg->ops->get_btc_status())
 				rtlpriv->btcoexist.btc_ops->btc_ips_notify(rtlpriv,
 									ppsc->inactive_pwrstate);
 		}
@@ -390,14 +392,16 @@  void rtl_lps_set_psmode(struct ieee80211_hw *hw, u8 rt_psmode)
 			if (ppsc->p2p_ps_info.opp_ps)
 				rtl_p2p_ps_cmd(hw , P2P_PS_ENABLE);
 
-			if (rtlpriv->cfg->ops->get_btc_status())
+			if (rtlpriv->cfg->ops->get_btc_status &&
+			    rtlpriv->cfg->ops->get_btc_status())
 				rtlpriv->btcoexist.btc_ops->btc_lps_notify(rtlpriv, rt_psmode);
 		} else {
 			if (rtl_get_fwlps_doze(hw)) {
 				RT_TRACE(rtlpriv, COMP_RF, DBG_DMESG,
 					 "FW LPS enter ps_mode:%x\n",
 					 ppsc->fwctrl_psmode);
-				if (rtlpriv->cfg->ops->get_btc_status())
+				if (rtlpriv->cfg->ops->get_btc_status &&
+				    rtlpriv->cfg->ops->get_btc_status())
 					rtlpriv->btcoexist.btc_ops->btc_lps_notify(rtlpriv, rt_psmode);
 				enter_fwlps = true;
 				ppsc->pwr_mode = ppsc->fwctrl_psmode;
diff --git a/drivers/net/wireless/rtlwifi/rtl8192se/def.h b/drivers/net/wireless/rtlwifi/rtl8192se/def.h
index 83c9867..593646e 100644
--- a/drivers/net/wireless/rtlwifi/rtl8192se/def.h
+++ b/drivers/net/wireless/rtlwifi/rtl8192se/def.h
@@ -453,6 +453,9 @@ 
 	 GET_RX_STATUS_DESC_RX_MCS(_pdesc) == DESC92_RATE5_5M ||\
 	 GET_RX_STATUS_DESC_RX_MCS(_pdesc) == DESC92_RATE11M)
 
+#define GET_RX_STATUS_DESC_BUFF_ADDR(__pdesc)			\
+	SHIFT_AND_MASK_LE(__pdesc + 24, 0, 32)
+
 enum rf_optype {
 	RF_OP_BY_SW_3WIRE = 0,
 	RF_OP_BY_FW,
diff --git a/drivers/net/wireless/rtlwifi/rtl8192se/sw.c b/drivers/net/wireless/rtlwifi/rtl8192se/sw.c
index 1bff2a0..aa99d97 100644
--- a/drivers/net/wireless/rtlwifi/rtl8192se/sw.c
+++ b/drivers/net/wireless/rtlwifi/rtl8192se/sw.c
@@ -87,11 +87,8 @@  static void rtl92s_init_aspm_vars(struct ieee80211_hw *hw)
 static void rtl92se_fw_cb(const struct firmware *firmware, void *context)
 {
 	struct ieee80211_hw *hw = context;
-	struct rtl_pci_priv *pcipriv = rtl_pcipriv(hw);
 	struct rtl_priv *rtlpriv = rtl_priv(hw);
-	struct rtl_pci *rtlpci = rtl_pcidev(pcipriv);
 	struct rt_firmware *pfirmware = NULL;
-	int err;
 
 	RT_TRACE(rtlpriv, COMP_ERR, DBG_LOUD,
 			 "Firmware callback routine entered!\n");
@@ -112,20 +109,6 @@  static void rtl92se_fw_cb(const struct firmware *firmware, void *context)
 	memcpy(pfirmware->sz_fw_tmpbuffer, firmware->data, firmware->size);
 	pfirmware->sz_fw_tmpbufferlen = firmware->size;
 	release_firmware(firmware);
-
-	err = ieee80211_register_hw(hw);
-	if (err) {
-		RT_TRACE(rtlpriv, COMP_ERR, DBG_EMERG,
-			 "Can't register mac80211 hw\n");
-		return;
-	} else {
-		rtlpriv->mac80211.mac80211_registered = 1;
-	}
-	rtlpci->irq_alloc = 1;
-	set_bit(RTL_STATUS_INTERFACE_START, &rtlpriv->status);
-
-	/*init rfkill */
-	rtl_init_rfkill(hw);
 }
 
 static int rtl92s_init_sw_vars(struct ieee80211_hw *hw)
diff --git a/drivers/net/wireless/rtlwifi/rtl8192se/trx.c b/drivers/net/wireless/rtlwifi/rtl8192se/trx.c
index b358ebc..672fd3b 100644
--- a/drivers/net/wireless/rtlwifi/rtl8192se/trx.c
+++ b/drivers/net/wireless/rtlwifi/rtl8192se/trx.c
@@ -640,6 +640,9 @@  u32 rtl92se_get_desc(u8 *desc, bool istx, u8 desc_name)
 		case HW_DESC_RXPKT_LEN:
 			ret = GET_RX_STATUS_DESC_PKT_LEN(desc);
 			break;
+		case HW_DESC_RXBUFF_ADDR:
+			ret = GET_RX_STATUS_DESC_BUFF_ADDR(desc);
+			break;
 		default:
 			RT_ASSERT(false, "ERR rxdesc :%d not process\n",
 				  desc_name);