159
162
rtlpci->first_init = true;
164
/* for debug level */
165
rtlpriv->dbg.global_debuglevel = rtlpriv->cfg->mod_params->debug;
161
166
/* for LPS & IPS */
162
167
rtlpriv->psc.inactiveps = rtlpriv->cfg->mod_params->inactiveps;
163
168
rtlpriv->psc.swctrl_lps = rtlpriv->cfg->mod_params->swctrl_lps;
164
169
rtlpriv->psc.fwctrl_lps = rtlpriv->cfg->mod_params->fwctrl_lps;
170
if (!rtlpriv->psc.inactiveps)
171
pr_info("rtl8192ce: Power Save off (module option)\n");
172
if (!rtlpriv->psc.fwctrl_lps)
173
pr_info("rtl8192ce: FW Power Save off (module option)\n");
165
174
rtlpriv->psc.reg_fwctrl_lps = 3;
166
175
rtlpriv->psc.reg_max_lps_awakeintvl = 5;
167
176
/* for ASPM, you can close aspm through
186
printk(KERN_INFO "rtl8192se: Driver for Realtek RTL8192SE/RTL8191SE\n"
187
" Loading firmware %s\n", rtlpriv->cfg->fw_name);
195
pr_info("Driver for Realtek RTL8192SE/RTL8191SE\n"
196
"Loading firmware %s\n", rtlpriv->cfg->fw_name);
189
198
err = request_firmware(&firmware, rtlpriv->cfg->fw_name,
190
199
rtlpriv->io.dev);
298
308
.maps[EFUSE_HWSET_MAX_SIZE] = HWSET_MAX_SIZE_92S,
299
309
.maps[EFUSE_MAX_SECTION_MAP] = EFUSE_MAX_SECTION,
300
310
.maps[EFUSE_REAL_CONTENT_SIZE] = EFUSE_REAL_CONTENT_LEN,
311
.maps[EFUSE_OOB_PROTECT_BYTES_LEN] = EFUSE_OOB_PROTECT_BYTES,
302
313
.maps[RWCAM] = REG_RWCAM,
303
314
.maps[WCAMI] = REG_WCAMI,
346
357
.maps[RTL_IMR_ROK] = IMR_ROK,
347
358
.maps[RTL_IBSS_INT_MASKS] = (IMR_BCNINT | IMR_TBDOK | IMR_TBDER),
349
.maps[RTL_RC_CCK_RATE1M] = DESC92S_RATE1M,
350
.maps[RTL_RC_CCK_RATE2M] = DESC92S_RATE2M,
351
.maps[RTL_RC_CCK_RATE5_5M] = DESC92S_RATE5_5M,
352
.maps[RTL_RC_CCK_RATE11M] = DESC92S_RATE11M,
353
.maps[RTL_RC_OFDM_RATE6M] = DESC92S_RATE6M,
354
.maps[RTL_RC_OFDM_RATE9M] = DESC92S_RATE9M,
355
.maps[RTL_RC_OFDM_RATE12M] = DESC92S_RATE12M,
356
.maps[RTL_RC_OFDM_RATE18M] = DESC92S_RATE18M,
357
.maps[RTL_RC_OFDM_RATE24M] = DESC92S_RATE24M,
358
.maps[RTL_RC_OFDM_RATE36M] = DESC92S_RATE36M,
359
.maps[RTL_RC_OFDM_RATE48M] = DESC92S_RATE48M,
360
.maps[RTL_RC_OFDM_RATE54M] = DESC92S_RATE54M,
360
.maps[RTL_RC_CCK_RATE1M] = DESC92_RATE1M,
361
.maps[RTL_RC_CCK_RATE2M] = DESC92_RATE2M,
362
.maps[RTL_RC_CCK_RATE5_5M] = DESC92_RATE5_5M,
363
.maps[RTL_RC_CCK_RATE11M] = DESC92_RATE11M,
364
.maps[RTL_RC_OFDM_RATE6M] = DESC92_RATE6M,
365
.maps[RTL_RC_OFDM_RATE9M] = DESC92_RATE9M,
366
.maps[RTL_RC_OFDM_RATE12M] = DESC92_RATE12M,
367
.maps[RTL_RC_OFDM_RATE18M] = DESC92_RATE18M,
368
.maps[RTL_RC_OFDM_RATE24M] = DESC92_RATE24M,
369
.maps[RTL_RC_OFDM_RATE36M] = DESC92_RATE36M,
370
.maps[RTL_RC_OFDM_RATE48M] = DESC92_RATE48M,
371
.maps[RTL_RC_OFDM_RATE54M] = DESC92_RATE54M,
362
.maps[RTL_RC_HT_RATEMCS7] = DESC92S_RATEMCS7,
363
.maps[RTL_RC_HT_RATEMCS15] = DESC92S_RATEMCS15,
373
.maps[RTL_RC_HT_RATEMCS7] = DESC92_RATEMCS7,
374
.maps[RTL_RC_HT_RATEMCS15] = DESC92_RATEMCS15,
366
377
static struct pci_device_id rtl92se_pci_ids[] __devinitdata = {
377
388
MODULE_AUTHOR("lizhaoming <chaoming_li@realsil.com.cn>");
378
389
MODULE_AUTHOR("Realtek WlanFAE <wlanfae@realtek.com>");
390
MODULE_AUTHOR("Larry Finger <Larry.Finger@lwfinger.net>");
379
391
MODULE_LICENSE("GPL");
380
392
MODULE_DESCRIPTION("Realtek 8192S/8191S 802.11n PCI wireless");
381
393
MODULE_FIRMWARE("rtlwifi/rtl8192sefw.bin");
383
395
module_param_named(swenc, rtl92se_mod_params.sw_crypto, bool, 0444);
396
module_param_named(debug, rtl92se_mod_params.debug, int, 0444);
384
397
module_param_named(ips, rtl92se_mod_params.inactiveps, bool, 0444);
385
398
module_param_named(swlps, rtl92se_mod_params.swctrl_lps, bool, 0444);
386
399
module_param_named(fwlps, rtl92se_mod_params.fwctrl_lps, bool, 0444);
387
MODULE_PARM_DESC(swenc, "using hardware crypto (default 0 [hardware])\n");
388
MODULE_PARM_DESC(ips, "using no link power save (default 1 is open)\n");
389
MODULE_PARM_DESC(swlps, "using linked sw control power save (default 1 is "
400
MODULE_PARM_DESC(swenc, "Set to 1 for software crypto (default 0)\n");
401
MODULE_PARM_DESC(ips, "Set to 0 to not use link power save (default 1)\n");
402
MODULE_PARM_DESC(swlps, "Set to 1 to use SW control power save (default 0)\n");
403
MODULE_PARM_DESC(fwlps, "Set to 1 to use FW control power save (default 1)\n");
404
MODULE_PARM_DESC(debug, "Set debug level (0-5) (default 0)");
406
static const struct dev_pm_ops rtlwifi_pm_ops = {
407
.suspend = rtl_pci_suspend,
408
.resume = rtl_pci_resume,
409
.freeze = rtl_pci_suspend,
410
.thaw = rtl_pci_resume,
411
.poweroff = rtl_pci_suspend,
412
.restore = rtl_pci_resume,
393
415
static struct pci_driver rtl92se_driver = {
394
416
.name = KBUILD_MODNAME,
395
417
.id_table = rtl92se_pci_ids,
396
418
.probe = rtl_pci_probe,
397
419
.remove = rtl_pci_disconnect,
400
.suspend = rtl_pci_suspend,
401
.resume = rtl_pci_resume,
420
.driver.pm = &rtlwifi_pm_ops,
406
423
static int __init rtl92se_module_init(void)