Re: [PATCH] misc: rtsx: add power saving function and bios guide options

2020-08-31 Thread kernel test robot
Hi,

Thank you for the patch! Perhaps something to improve:

[auto build test WARNING on char-misc/char-misc-testing]
[also build test WARNING on soc/for-next linus/master v5.9-rc3 next-20200828]
[cannot apply to linux/master]
[If your patch is applied to the wrong git tree, kindly drop us a note.
And when submitting patch, we suggest to use '--base' as documented in
https://git-scm.com/docs/git-format-patch]

url:
https://github.com/0day-ci/linux/commits/ricky_wu-realtek-com/misc-rtsx-add-power-saving-function-and-bios-guide-options/20200901-103534
base:   https://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc.git 
dd5597245d35cfbb0890b8a868028aa1d2018701
config: ia64-randconfig-r005-20200831 (attached as .config)
compiler: ia64-linux-gcc (GCC) 9.3.0
reproduce (this is a W=1 build):
wget 
https://raw.githubusercontent.com/intel/lkp-tests/master/sbin/make.cross -O 
~/bin/make.cross
chmod +x ~/bin/make.cross
# save the attached .config to linux build tree
COMPILER_INSTALL_PATH=$HOME/0day COMPILER=gcc-9.3.0 make.cross 
ARCH=ia64 

If you fix the issue, kindly add following tag as appropriate
Reported-by: kernel test robot 

All warnings (new ones prefixed by >>):

   In file included from arch/ia64/include/asm/pgtable.h:154,
from include/linux/pgtable.h:6,
from arch/ia64/include/asm/uaccess.h:40,
from include/linux/uaccess.h:9,
from arch/ia64/include/asm/sections.h:11,
from include/linux/interrupt.h:20,
from include/linux/pci.h:38,
from include/linux/rtsx_pci.h:14,
from drivers/misc/cardreader/rts5249.c:12:
   arch/ia64/include/asm/mmu_context.h: In function 'reload_context':
   arch/ia64/include/asm/mmu_context.h:137:41: warning: variable 'old_rr4' set 
but not used [-Wunused-but-set-variable]
 137 |  unsigned long rr0, rr1, rr2, rr3, rr4, old_rr4;
 | ^~~
   drivers/misc/cardreader/rts5249.c: In function 
'rts52xa_save_content_from_efuse':
>> drivers/misc/cardreader/rts5249.c:157:14: warning: variable 'cv' set but not 
>> used [-Wunused-but-set-variable]
 157 |  u8 cnt, sv, cv;
 |  ^~

# 
https://github.com/0day-ci/linux/commit/7f37b141bf20205913d0efbf1bca25e323489b6b
git remote add linux-review https://github.com/0day-ci/linux
git fetch --no-tags linux-review 
ricky_wu-realtek-com/misc-rtsx-add-power-saving-function-and-bios-guide-options/20200901-103534
git checkout 7f37b141bf20205913d0efbf1bca25e323489b6b
vim +/cv +157 drivers/misc/cardreader/rts5249.c

   154  
   155  static void rts52xa_save_content_from_efuse(struct rtsx_pcr *pcr)
   156  {
 > 157  u8 cnt, sv, cv;
   158  u8 j = 0;
   159  u8 tmp;
   160  u8 val;
   161  int i;
   162  
   163  rtsx_pci_write_register(pcr, RTS524A_PME_FORCE_CTL,
   164  REG_EFUSE_BYPASS | REG_EFUSE_POR, 
REG_EFUSE_POR);
   165  udelay(1);
   166  
   167  pcr_dbg(pcr, "Enable efuse por!");
   168  pcr_dbg(pcr, "save efuse to autoload");
   169  
   170  rtsx_pci_write_register(pcr, RTS525A_EFUSE_ADD, 
REG_EFUSE_ADD_MASK, 0x00);
   171  rtsx_pci_write_register(pcr, RTS525A_EFUSE_CTL,
   172  REG_EFUSE_ENABLE | REG_EFUSE_MODE, 
REG_EFUSE_ENABLE);
   173  /* Wait transfer end */
   174  for (j = 0; j < 1024; j++) {
   175  rtsx_pci_read_register(pcr, RTS525A_EFUSE_CTL, &tmp);
   176  if ((tmp & 0x80) == 0)
   177  break;
   178  }
   179  rtsx_pci_read_register(pcr, RTS525A_EFUSE_DATA, &val);
   180  cnt = val & 0x0F;
   181  sv = val & 0x10;
   182  cv = val & 0x20;
   183  
   184  if (sv) {
   185  for (i = 0; i < 4; i++) {
   186  rtsx_pci_write_register(pcr, RTS525A_EFUSE_ADD,
   187  REG_EFUSE_ADD_MASK, 0x04 + i);
   188  rtsx_pci_write_register(pcr, RTS525A_EFUSE_CTL,
   189  REG_EFUSE_ENABLE | REG_EFUSE_MODE, 
REG_EFUSE_ENABLE);
   190  /* Wait transfer end */
   191  for (j = 0; j < 1024; j++) {
   192  rtsx_pci_read_register(pcr, 
RTS525A_EFUSE_CTL, &tmp);
   193  if ((tmp & 0x80) == 0)
   194  break;
   195  }
   196  rtsx_pci_read_register(pcr, RTS525A_EFUSE_DATA, 
&val);
   197  rtsx_pci_write_register(pcr, 0xFF04 + i, 0xFF, 
val);
   198  }
   199  } else {
   200  rtsx_pci_write_register(pcr, 0xFF04, 0xFF, 
(u8)PCI_VID(pcr)

[PATCH] misc: rtsx: add power saving function and bios guide options

2020-08-31 Thread ricky_wu
From: Ricky Wu 

Added rts5227 rts5249 rts5260 rts5228 power saving functions,
added BIOS guide MMC funciton and U_d3_en register support and
fixed rts5260 driving parameter

Signed-off-by: Ricky Wu 
---
 drivers/misc/cardreader/rts5227.c  | 115 +-
 drivers/misc/cardreader/rts5228.c  |   5 +-
 drivers/misc/cardreader/rts5249.c  | 147 -
 drivers/misc/cardreader/rts5260.c  |  33 ---
 drivers/misc/cardreader/rtsx_pcr.h |  18 
 5 files changed, 289 insertions(+), 29 deletions(-)

diff --git a/drivers/misc/cardreader/rts5227.c 
b/drivers/misc/cardreader/rts5227.c
index f5f392ddf3d6..314037eff17d 100644
--- a/drivers/misc/cardreader/rts5227.c
+++ b/drivers/misc/cardreader/rts5227.c
@@ -72,6 +72,8 @@ static void rts5227_fetch_vendor_settings(struct rtsx_pcr 
*pcr)
 
pci_read_config_dword(pdev, PCR_SETTING_REG2, ®);
pcr_dbg(pcr, "Cfg 0x%x: 0x%x\n", PCR_SETTING_REG2, reg);
+   if (rtsx_check_mmc_support(reg))
+   pcr->extra_caps |= EXTRA_CAPS_NO_MMC;
pcr->sd30_drive_sel_3v3 = rtsx_reg_to_sd30_drive_sel_3v3(reg);
if (rtsx_reg_check_reverse_socket(reg))
pcr->flags |= PCR_REVERSE_SOCKET;
@@ -84,16 +86,78 @@ static void rts5227_force_power_down(struct rtsx_pcr *pcr, 
u8 pm_state)
rtsx_pci_write_register(pcr, AUTOLOAD_CFG_BASE + 2, 0xFF, 0);
rtsx_pci_write_register(pcr, AUTOLOAD_CFG_BASE + 3, 0x01, 0);
 
-   if (pm_state == HOST_ENTER_S3)
-   rtsx_pci_write_register(pcr, pcr->reg_pm_ctrl3, 0x10, 0x10);
+   rtsx_pci_write_register(pcr, pcr->reg_pm_ctrl3, 0x10, 0x10);
 
rtsx_pci_write_register(pcr, FPDCTL, 0x03, 0x03);
 }
 
+static void rts5227_init_from_cfg(struct rtsx_pcr *pcr)
+{
+   struct pci_dev *pdev = pcr->pci;
+   int l1ss;
+   u32 lval;
+   struct rtsx_cr_option *option = &pcr->option;
+
+   l1ss = pci_find_ext_capability(pdev, PCI_EXT_CAP_ID_L1SS);
+   if (!l1ss)
+   return;
+
+   pci_read_config_dword(pdev, l1ss + PCI_L1SS_CTL1, &lval);
+
+   if (CHK_PCI_PID(pcr, 0x522A)) {
+   if (0 == (lval & 0x0F))
+   rtsx_pci_enable_oobs_polling(pcr);
+   else
+   rtsx_pci_disable_oobs_polling(pcr);
+   }
+
+   if (lval & PCI_L1SS_CTL1_ASPM_L1_1)
+   rtsx_set_dev_flag(pcr, ASPM_L1_1_EN);
+   else
+   rtsx_clear_dev_flag(pcr, ASPM_L1_1_EN);
+
+   if (lval & PCI_L1SS_CTL1_ASPM_L1_2)
+   rtsx_set_dev_flag(pcr, ASPM_L1_2_EN);
+   else
+   rtsx_clear_dev_flag(pcr, ASPM_L1_2_EN);
+
+   if (lval & PCI_L1SS_CTL1_PCIPM_L1_1)
+   rtsx_set_dev_flag(pcr, PM_L1_1_EN);
+   else
+   rtsx_clear_dev_flag(pcr, PM_L1_1_EN);
+
+   if (lval & PCI_L1SS_CTL1_PCIPM_L1_2)
+   rtsx_set_dev_flag(pcr, PM_L1_2_EN);
+   else
+   rtsx_clear_dev_flag(pcr, PM_L1_2_EN);
+
+   if (option->ltr_en) {
+   u16 val;
+
+   pcie_capability_read_word(pcr->pci, PCI_EXP_DEVCTL2, &val);
+   if (val & PCI_EXP_DEVCTL2_LTR_EN) {
+   option->ltr_enabled = true;
+   option->ltr_active = true;
+   rtsx_set_ltr_latency(pcr, option->ltr_active_latency);
+   } else {
+   option->ltr_enabled = false;
+   }
+   }
+
+   if (rtsx_check_dev_flag(pcr, ASPM_L1_1_EN | ASPM_L1_2_EN
+   | PM_L1_1_EN | PM_L1_2_EN))
+   option->force_clkreq_0 = false;
+   else
+   option->force_clkreq_0 = true;
+
+}
+
 static int rts5227_extra_init_hw(struct rtsx_pcr *pcr)
 {
u16 cap;
+   struct rtsx_cr_option *option = &pcr->option;
 
+   rts5227_init_from_cfg(pcr);
rtsx_pci_init_cmd(pcr);
 
/* Configure GPIO as output */
@@ -115,9 +179,17 @@ static int rts5227_extra_init_hw(struct rtsx_pcr *pcr)
rts5227_fill_driving(pcr, OUTPUT_3V3);
/* Configure force_clock_req */
if (pcr->flags & PCR_REVERSE_SOCKET)
-   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0xB8, 0xB8);
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0x30, 0x30);
else
-   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0xB8, 0x88);
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0x30, 0x00);
+
+   if (option->force_clkreq_0)
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG,
+   FORCE_CLKREQ_DELINK_MASK, FORCE_CLKREQ_LOW);
+   else
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG,
+   FORCE_CLKREQ_DELINK_MASK, FORCE_CLKREQ_HIGH);
+
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, pcr->reg_pm_ctrl3, 0x10, 0x00);
 
return rtsx_pci_send_cmd(pcr, 100);
@@ -373,6 +445,27 @@ static int rts522a_switch_output_voltage(struct rtsx_pcr 
*pcr, u8 voltag

[PATCH] misc: rtsx: add power saving function and bios guide options

2020-08-31 Thread ricky_wu
From: Ricky Wu 

Added rts5227 rts5249 rts5260 rts5228 power saving functions,
added BIOS guide MMC funciton and U_d3_en register support and
fixed rts5260 driving parameter

Signed-off-by: Ricky Wu 
---
 drivers/misc/cardreader/rts5227.c  | 115 +-
 drivers/misc/cardreader/rts5228.c  |   5 +-
 drivers/misc/cardreader/rts5249.c  | 147 -
 drivers/misc/cardreader/rts5260.c  |  33 ---
 drivers/misc/cardreader/rtsx_pcr.h |  18 
 5 files changed, 289 insertions(+), 29 deletions(-)

diff --git a/drivers/misc/cardreader/rts5227.c 
b/drivers/misc/cardreader/rts5227.c
index f5f392ddf3d6..314037eff17d 100644
--- a/drivers/misc/cardreader/rts5227.c
+++ b/drivers/misc/cardreader/rts5227.c
@@ -72,6 +72,8 @@ static void rts5227_fetch_vendor_settings(struct rtsx_pcr 
*pcr)
 
pci_read_config_dword(pdev, PCR_SETTING_REG2, ®);
pcr_dbg(pcr, "Cfg 0x%x: 0x%x\n", PCR_SETTING_REG2, reg);
+   if (rtsx_check_mmc_support(reg))
+   pcr->extra_caps |= EXTRA_CAPS_NO_MMC;
pcr->sd30_drive_sel_3v3 = rtsx_reg_to_sd30_drive_sel_3v3(reg);
if (rtsx_reg_check_reverse_socket(reg))
pcr->flags |= PCR_REVERSE_SOCKET;
@@ -84,16 +86,78 @@ static void rts5227_force_power_down(struct rtsx_pcr *pcr, 
u8 pm_state)
rtsx_pci_write_register(pcr, AUTOLOAD_CFG_BASE + 2, 0xFF, 0);
rtsx_pci_write_register(pcr, AUTOLOAD_CFG_BASE + 3, 0x01, 0);
 
-   if (pm_state == HOST_ENTER_S3)
-   rtsx_pci_write_register(pcr, pcr->reg_pm_ctrl3, 0x10, 0x10);
+   rtsx_pci_write_register(pcr, pcr->reg_pm_ctrl3, 0x10, 0x10);
 
rtsx_pci_write_register(pcr, FPDCTL, 0x03, 0x03);
 }
 
+static void rts5227_init_from_cfg(struct rtsx_pcr *pcr)
+{
+   struct pci_dev *pdev = pcr->pci;
+   int l1ss;
+   u32 lval;
+   struct rtsx_cr_option *option = &pcr->option;
+
+   l1ss = pci_find_ext_capability(pdev, PCI_EXT_CAP_ID_L1SS);
+   if (!l1ss)
+   return;
+
+   pci_read_config_dword(pdev, l1ss + PCI_L1SS_CTL1, &lval);
+
+   if (CHK_PCI_PID(pcr, 0x522A)) {
+   if (0 == (lval & 0x0F))
+   rtsx_pci_enable_oobs_polling(pcr);
+   else
+   rtsx_pci_disable_oobs_polling(pcr);
+   }
+
+   if (lval & PCI_L1SS_CTL1_ASPM_L1_1)
+   rtsx_set_dev_flag(pcr, ASPM_L1_1_EN);
+   else
+   rtsx_clear_dev_flag(pcr, ASPM_L1_1_EN);
+
+   if (lval & PCI_L1SS_CTL1_ASPM_L1_2)
+   rtsx_set_dev_flag(pcr, ASPM_L1_2_EN);
+   else
+   rtsx_clear_dev_flag(pcr, ASPM_L1_2_EN);
+
+   if (lval & PCI_L1SS_CTL1_PCIPM_L1_1)
+   rtsx_set_dev_flag(pcr, PM_L1_1_EN);
+   else
+   rtsx_clear_dev_flag(pcr, PM_L1_1_EN);
+
+   if (lval & PCI_L1SS_CTL1_PCIPM_L1_2)
+   rtsx_set_dev_flag(pcr, PM_L1_2_EN);
+   else
+   rtsx_clear_dev_flag(pcr, PM_L1_2_EN);
+
+   if (option->ltr_en) {
+   u16 val;
+
+   pcie_capability_read_word(pcr->pci, PCI_EXP_DEVCTL2, &val);
+   if (val & PCI_EXP_DEVCTL2_LTR_EN) {
+   option->ltr_enabled = true;
+   option->ltr_active = true;
+   rtsx_set_ltr_latency(pcr, option->ltr_active_latency);
+   } else {
+   option->ltr_enabled = false;
+   }
+   }
+
+   if (rtsx_check_dev_flag(pcr, ASPM_L1_1_EN | ASPM_L1_2_EN
+   | PM_L1_1_EN | PM_L1_2_EN))
+   option->force_clkreq_0 = false;
+   else
+   option->force_clkreq_0 = true;
+
+}
+
 static int rts5227_extra_init_hw(struct rtsx_pcr *pcr)
 {
u16 cap;
+   struct rtsx_cr_option *option = &pcr->option;
 
+   rts5227_init_from_cfg(pcr);
rtsx_pci_init_cmd(pcr);
 
/* Configure GPIO as output */
@@ -115,9 +179,17 @@ static int rts5227_extra_init_hw(struct rtsx_pcr *pcr)
rts5227_fill_driving(pcr, OUTPUT_3V3);
/* Configure force_clock_req */
if (pcr->flags & PCR_REVERSE_SOCKET)
-   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0xB8, 0xB8);
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0x30, 0x30);
else
-   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0xB8, 0x88);
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG, 0x30, 0x00);
+
+   if (option->force_clkreq_0)
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG,
+   FORCE_CLKREQ_DELINK_MASK, FORCE_CLKREQ_LOW);
+   else
+   rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, PETXCFG,
+   FORCE_CLKREQ_DELINK_MASK, FORCE_CLKREQ_HIGH);
+
rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, pcr->reg_pm_ctrl3, 0x10, 0x00);
 
return rtsx_pci_send_cmd(pcr, 100);
@@ -373,6 +445,27 @@ static int rts522a_switch_output_voltage(struct rtsx_pcr 
*pcr, u8 voltag