Lines Matching full:pcr
90 #define rtsx_pci_writel(pcr, reg, value) \ argument
91 iowrite32(value, (pcr)->remap_addr + reg)
92 #define rtsx_pci_readl(pcr, reg) \ argument
93 ioread32((pcr)->remap_addr + reg)
94 #define rtsx_pci_writew(pcr, reg, value) \ argument
95 iowrite16(value, (pcr)->remap_addr + reg)
96 #define rtsx_pci_readw(pcr, reg) \ argument
97 ioread16((pcr)->remap_addr + reg)
98 #define rtsx_pci_writeb(pcr, reg, value) \ argument
99 iowrite8(value, (pcr)->remap_addr + reg)
100 #define rtsx_pci_readb(pcr, reg) \ argument
101 ioread8((pcr)->remap_addr + reg)
1074 #define rtsx_pci_init_cmd(pcr) ((pcr)->ci = 0) argument
1082 struct rtsx_pcr *pcr; member
1086 int (*write_phy)(struct rtsx_pcr *pcr, u8 addr, u16 val);
1087 int (*read_phy)(struct rtsx_pcr *pcr, u8 addr, u16 *val);
1088 int (*extra_init_hw)(struct rtsx_pcr *pcr);
1089 int (*optimize_phy)(struct rtsx_pcr *pcr);
1090 int (*turn_on_led)(struct rtsx_pcr *pcr);
1091 int (*turn_off_led)(struct rtsx_pcr *pcr);
1092 int (*enable_auto_blink)(struct rtsx_pcr *pcr);
1093 int (*disable_auto_blink)(struct rtsx_pcr *pcr);
1094 int (*card_power_on)(struct rtsx_pcr *pcr, int card);
1095 int (*card_power_off)(struct rtsx_pcr *pcr, int card);
1096 int (*switch_output_voltage)(struct rtsx_pcr *pcr,
1098 unsigned int (*cd_deglitch)(struct rtsx_pcr *pcr);
1100 void (*fetch_vendor_settings)(struct rtsx_pcr *pcr);
1101 void (*force_power_down)(struct rtsx_pcr *pcr, u8 pm_state, bool runtime);
1102 void (*stop_cmd)(struct rtsx_pcr *pcr);
1104 void (*set_aspm)(struct rtsx_pcr *pcr, bool enable);
1105 void (*set_l1off_cfg_sub_d0)(struct rtsx_pcr *pcr, int active);
1106 void (*enable_ocp)(struct rtsx_pcr *pcr);
1107 void (*disable_ocp)(struct rtsx_pcr *pcr);
1108 void (*init_ocp)(struct rtsx_pcr *pcr);
1109 void (*process_ocp)(struct rtsx_pcr *pcr);
1110 int (*get_ocpstat)(struct rtsx_pcr *pcr, u8 *val);
1111 void (*clear_ocpstat)(struct rtsx_pcr *pcr);
1275 #define CHK_PCI_PID(pcr, pid) ((pcr)->pci->device == (pid)) argument
1276 #define PCI_VID(pcr) ((pcr)->pci->vendor) argument
1277 #define PCI_PID(pcr) ((pcr)->pci->device) argument
1278 #define is_version(pcr, pid, ver) \ argument
1279 (CHK_PCI_PID(pcr, pid) && (pcr)->ic_version == (ver))
1280 #define is_version_higher_than(pcr, pid, ver) \ argument
1281 (CHK_PCI_PID(pcr, pid) && (pcr)->ic_version > (ver))
1282 #define pcr_dbg(pcr, fmt, arg...) \ argument
1283 dev_dbg(&(pcr)->pci->dev, fmt, ##arg)
1288 #define SDR104_TX_PHASE(pcr) SDR104_PHASE((pcr)->tx_initial_phase) argument
1289 #define SDR50_TX_PHASE(pcr) SDR50_PHASE((pcr)->tx_initial_phase) argument
1290 #define DDR50_TX_PHASE(pcr) DDR50_PHASE((pcr)->tx_initial_phase) argument
1291 #define SDR104_RX_PHASE(pcr) SDR104_PHASE((pcr)->rx_initial_phase) argument
1292 #define SDR50_RX_PHASE(pcr) SDR50_PHASE((pcr)->rx_initial_phase) argument
1293 #define DDR50_RX_PHASE(pcr) DDR50_PHASE((pcr)->rx_initial_phase) argument
1297 void rtsx_pci_start_run(struct rtsx_pcr *pcr);
1298 int rtsx_pci_write_register(struct rtsx_pcr *pcr, u16 addr, u8 mask, u8 data);
1299 int rtsx_pci_read_register(struct rtsx_pcr *pcr, u16 addr, u8 *data);
1300 int rtsx_pci_write_phy_register(struct rtsx_pcr *pcr, u8 addr, u16 val);
1301 int rtsx_pci_read_phy_register(struct rtsx_pcr *pcr, u8 addr, u16 *val);
1302 void rtsx_pci_stop_cmd(struct rtsx_pcr *pcr);
1303 void rtsx_pci_add_cmd(struct rtsx_pcr *pcr,
1305 void rtsx_pci_send_cmd_no_wait(struct rtsx_pcr *pcr);
1306 int rtsx_pci_send_cmd(struct rtsx_pcr *pcr, int timeout);
1307 int rtsx_pci_transfer_data(struct rtsx_pcr *pcr, struct scatterlist *sglist,
1309 int rtsx_pci_dma_map_sg(struct rtsx_pcr *pcr, struct scatterlist *sglist,
1311 void rtsx_pci_dma_unmap_sg(struct rtsx_pcr *pcr, struct scatterlist *sglist,
1313 int rtsx_pci_dma_transfer(struct rtsx_pcr *pcr, struct scatterlist *sglist,
1315 int rtsx_pci_read_ppbuf(struct rtsx_pcr *pcr, u8 *buf, int buf_len);
1316 int rtsx_pci_write_ppbuf(struct rtsx_pcr *pcr, u8 *buf, int buf_len);
1317 int rtsx_pci_card_pull_ctl_enable(struct rtsx_pcr *pcr, int card);
1318 int rtsx_pci_card_pull_ctl_disable(struct rtsx_pcr *pcr, int card);
1319 int rtsx_pci_switch_clock(struct rtsx_pcr *pcr, unsigned int card_clock,
1321 int rtsx_pci_card_power_on(struct rtsx_pcr *pcr, int card);
1322 int rtsx_pci_card_power_off(struct rtsx_pcr *pcr, int card);
1323 int rtsx_pci_card_exclusive_check(struct rtsx_pcr *pcr, int card);
1324 int rtsx_pci_switch_output_voltage(struct rtsx_pcr *pcr, u8 voltage);
1325 unsigned int rtsx_pci_card_exist(struct rtsx_pcr *pcr);
1326 void rtsx_pci_complete_unfinished_transfer(struct rtsx_pcr *pcr);
1328 static inline u8 *rtsx_pci_get_cmd_data(struct rtsx_pcr *pcr) in rtsx_pci_get_cmd_data() argument
1330 return (u8 *)(pcr->host_cmds_ptr); in rtsx_pci_get_cmd_data()
1333 static inline void rtsx_pci_write_be32(struct rtsx_pcr *pcr, u16 reg, u32 val) in rtsx_pci_write_be32() argument
1335 rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg, 0xFF, val >> 24); in rtsx_pci_write_be32()
1336 rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 1, 0xFF, val >> 16); in rtsx_pci_write_be32()
1337 rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 2, 0xFF, val >> 8); in rtsx_pci_write_be32()
1338 rtsx_pci_add_cmd(pcr, WRITE_REG_CMD, reg + 3, 0xFF, val); in rtsx_pci_write_be32()
1341 static inline int rtsx_pci_update_phy(struct rtsx_pcr *pcr, u8 addr, in rtsx_pci_update_phy() argument
1347 err = rtsx_pci_read_phy_register(pcr, addr, &val); in rtsx_pci_update_phy()
1351 return rtsx_pci_write_phy_register(pcr, addr, (val & mask) | append); in rtsx_pci_update_phy()