/openbmc/linux/drivers/net/ethernet/atheros/alx/ |
H A D | hw.c | 39 #include "hw.h" 46 static int alx_wait_mdio_idle(struct alx_hw *hw) in alx_wait_mdio_idle() argument 52 val = alx_read_mem32(hw, ALX_MDIO); in alx_wait_mdio_idle() 61 static int alx_read_phy_core(struct alx_hw *hw, bool ext, u8 dev, in alx_read_phy_core() argument 70 clk_sel = hw->link_speed != SPEED_UNKNOWN ? in alx_read_phy_core() 77 alx_write_mem32(hw, ALX_MDIO_EXTN, val); in alx_read_phy_core() 88 alx_write_mem32(hw, ALX_MDIO, val); in alx_read_phy_core() 90 err = alx_wait_mdio_idle(hw); in alx_read_phy_core() 93 val = alx_read_mem32(hw, ALX_MDIO); in alx_read_phy_core() 98 static int alx_write_phy_core(struct alx_hw *hw, bool ext, u8 dev, in alx_write_phy_core() argument [all …]
|
/openbmc/linux/drivers/net/ethernet/intel/i40e/ |
H A D | i40e_adminq.c | 9 static void i40e_resume_aq(struct i40e_hw *hw); 13 * @hw: pointer to the hardware structure 17 static void i40e_adminq_init_regs(struct i40e_hw *hw) in i40e_adminq_init_regs() argument 20 if (i40e_is_vf(hw)) { in i40e_adminq_init_regs() 21 hw->aq.asq.tail = I40E_VF_ATQT1; in i40e_adminq_init_regs() 22 hw->aq.asq.head = I40E_VF_ATQH1; in i40e_adminq_init_regs() 23 hw->aq.asq.len = I40E_VF_ATQLEN1; in i40e_adminq_init_regs() 24 hw->aq.asq.bal = I40E_VF_ATQBAL1; in i40e_adminq_init_regs() 25 hw->aq.asq.bah = I40E_VF_ATQBAH1; in i40e_adminq_init_regs() 26 hw->aq.arq.tail = I40E_VF_ARQT1; in i40e_adminq_init_regs() [all …]
|
H A D | i40e_prototype.h | 19 int i40e_init_adminq(struct i40e_hw *hw); 20 void i40e_shutdown_adminq(struct i40e_hw *hw); 21 int i40e_clean_arq_element(struct i40e_hw *hw, 25 i40e_asq_send_command(struct i40e_hw *hw, struct i40e_aq_desc *desc, 29 i40e_asq_send_command_v2(struct i40e_hw *hw, 36 i40e_asq_send_command_atomic(struct i40e_hw *hw, struct i40e_aq_desc *desc, 41 i40e_asq_send_command_atomic_v2(struct i40e_hw *hw, 50 void i40e_debug_aq(struct i40e_hw *hw, enum i40e_debug_mask mask, 53 bool i40e_check_asq_alive(struct i40e_hw *hw); 54 int i40e_aq_queue_shutdown(struct i40e_hw *hw, bool unloading); [all …]
|
/openbmc/linux/drivers/isdn/hardware/mISDN/ |
H A D | mISDNinfineon.c | 103 spinlock_t lock; /* HW access lock */ 267 struct inf_hw *hw = dev_id; in diva_irq() local 270 spin_lock(&hw->lock); in diva_irq() 271 val = inb((u32)hw->cfg.start + DIVA_PCI_CTRL); in diva_irq() 273 spin_unlock(&hw->lock); in diva_irq() 276 hw->irqcnt++; in diva_irq() 277 mISDNipac_irq(&hw->ipac, irqloops); in diva_irq() 278 spin_unlock(&hw->lock); in diva_irq() 285 struct inf_hw *hw = dev_id; in diva20x_irq() local 288 spin_lock(&hw->lock); in diva20x_irq() [all …]
|
/openbmc/linux/drivers/net/ethernet/intel/ixgbe/ |
H A D | ixgbe_phy.c | 12 static void ixgbe_i2c_start(struct ixgbe_hw *hw); 13 static void ixgbe_i2c_stop(struct ixgbe_hw *hw); 14 static s32 ixgbe_clock_in_i2c_byte(struct ixgbe_hw *hw, u8 *data); 15 static s32 ixgbe_clock_out_i2c_byte(struct ixgbe_hw *hw, u8 data); 16 static s32 ixgbe_get_i2c_ack(struct ixgbe_hw *hw); 17 static s32 ixgbe_clock_in_i2c_bit(struct ixgbe_hw *hw, bool *data); 18 static s32 ixgbe_clock_out_i2c_bit(struct ixgbe_hw *hw, bool data); 19 static void ixgbe_raise_i2c_clk(struct ixgbe_hw *hw, u32 *i2cctl); 20 static void ixgbe_lower_i2c_clk(struct ixgbe_hw *hw, u32 *i2cctl); 21 static s32 ixgbe_set_i2c_data(struct ixgbe_hw *hw, u32 *i2cctl, bool data); [all …]
|
H A D | ixgbe_x540.c | 19 static s32 ixgbe_update_flash_X540(struct ixgbe_hw *hw); 20 static s32 ixgbe_poll_flash_update_done_X540(struct ixgbe_hw *hw); 21 static s32 ixgbe_get_swfw_sync_semaphore(struct ixgbe_hw *hw); 22 static void ixgbe_release_swfw_sync_semaphore(struct ixgbe_hw *hw); 24 enum ixgbe_media_type ixgbe_get_media_type_X540(struct ixgbe_hw *hw) in ixgbe_get_media_type_X540() argument 29 s32 ixgbe_get_invariants_X540(struct ixgbe_hw *hw) in ixgbe_get_invariants_X540() argument 31 struct ixgbe_mac_info *mac = &hw->mac; in ixgbe_get_invariants_X540() 32 struct ixgbe_phy_info *phy = &hw->phy; in ixgbe_get_invariants_X540() 43 mac->max_msix_vectors = ixgbe_get_pcie_msix_count_generic(hw); in ixgbe_get_invariants_X540() 50 * @hw: pointer to hardware structure [all …]
|
H A D | ixgbe_common.c | 13 static s32 ixgbe_acquire_eeprom(struct ixgbe_hw *hw); 14 static s32 ixgbe_get_eeprom_semaphore(struct ixgbe_hw *hw); 15 static void ixgbe_release_eeprom_semaphore(struct ixgbe_hw *hw); 16 static s32 ixgbe_ready_eeprom(struct ixgbe_hw *hw); 17 static void ixgbe_standby_eeprom(struct ixgbe_hw *hw); 18 static void ixgbe_shift_out_eeprom_bits(struct ixgbe_hw *hw, u16 data, 20 static u16 ixgbe_shift_in_eeprom_bits(struct ixgbe_hw *hw, u16 count); 21 static void ixgbe_raise_eeprom_clk(struct ixgbe_hw *hw, u32 *eec); 22 static void ixgbe_lower_eeprom_clk(struct ixgbe_hw *hw, u32 *eec); 23 static void ixgbe_release_eeprom(struct ixgbe_hw *hw); [all …]
|
H A D | ixgbe_x550.c | 15 static s32 ixgbe_get_invariants_X550_x(struct ixgbe_hw *hw) in ixgbe_get_invariants_X550_x() argument 17 struct ixgbe_mac_info *mac = &hw->mac; in ixgbe_get_invariants_X550_x() 18 struct ixgbe_phy_info *phy = &hw->phy; in ixgbe_get_invariants_X550_x() 19 struct ixgbe_link_info *link = &hw->link; in ixgbe_get_invariants_X550_x() 22 ixgbe_get_invariants_X540(hw); in ixgbe_get_invariants_X550_x() 24 if (mac->ops.get_media_type(hw) != ixgbe_media_type_copper) in ixgbe_get_invariants_X550_x() 32 static s32 ixgbe_get_invariants_X550_x_fw(struct ixgbe_hw *hw) in ixgbe_get_invariants_X550_x_fw() argument 34 struct ixgbe_phy_info *phy = &hw->phy; in ixgbe_get_invariants_X550_x_fw() 37 ixgbe_get_invariants_X540(hw); in ixgbe_get_invariants_X550_x_fw() 44 static s32 ixgbe_get_invariants_X550_a(struct ixgbe_hw *hw) in ixgbe_get_invariants_X550_a() argument [all …]
|
/openbmc/linux/drivers/net/ethernet/intel/iavf/ |
H A D | iavf_adminq.c | 12 * @hw: pointer to the hardware structure 16 static void iavf_adminq_init_regs(struct iavf_hw *hw) in iavf_adminq_init_regs() argument 19 hw->aq.asq.tail = IAVF_VF_ATQT1; in iavf_adminq_init_regs() 20 hw->aq.asq.head = IAVF_VF_ATQH1; in iavf_adminq_init_regs() 21 hw->aq.asq.len = IAVF_VF_ATQLEN1; in iavf_adminq_init_regs() 22 hw->aq.asq.bal = IAVF_VF_ATQBAL1; in iavf_adminq_init_regs() 23 hw->aq.asq.bah = IAVF_VF_ATQBAH1; in iavf_adminq_init_regs() 24 hw->aq.arq.tail = IAVF_VF_ARQT1; in iavf_adminq_init_regs() 25 hw->aq.arq.head = IAVF_VF_ARQH1; in iavf_adminq_init_regs() 26 hw->aq.arq.len = IAVF_VF_ARQLEN1; in iavf_adminq_init_regs() [all …]
|
/openbmc/linux/drivers/clk/sprd/ |
H A D | sc9863a-clk.c | 57 [CLK_MPLL0_GATE] = &mpll0_gate.common.hw, 58 [CLK_DPLL0_GATE] = &dpll0_gate.common.hw, 59 [CLK_LPLL_GATE] = &lpll_gate.common.hw, 60 [CLK_GPLL_GATE] = &gpll_gate.common.hw, 61 [CLK_DPLL1_GATE] = &dpll1_gate.common.hw, 62 [CLK_MPLL1_GATE] = &mpll1_gate.common.hw, 63 [CLK_MPLL2_GATE] = &mpll2_gate.common.hw, 64 [CLK_ISPPLL_GATE] = &isppll_gate.common.hw, 93 static CLK_FIXED_FACTOR_HW(twpll_768m, "twpll-768m", &twpll.common.hw, 2, 1, 0); 94 static CLK_FIXED_FACTOR_HW(twpll_384m, "twpll-384m", &twpll.common.hw, 4, 1, 0); [all …]
|
H A D | ums512-clk.c | 30 /* some pll clocks configure CLK_IGNORE_UNUSED because hw dvfs does not call 31 * clock interface. hw dvfs can not gate the pll clock. 83 [CLK_26M_AUD] = &clk_26m_aud.hw, 84 [CLK_13M] = &clk_13m.hw, 85 [CLK_6M5] = &clk_6m5.hw, 86 [CLK_4M3] = &clk_4m3.hw, 87 [CLK_2M] = &clk_2m.hw, 88 [CLK_1M] = &clk_1m.hw, 89 [CLK_250K] = &clk_250k.hw, 90 [CLK_RCO_25M] = &rco_25m.hw, [all …]
|
/openbmc/linux/drivers/clk/meson/ |
H A D | meson8b.c | 92 .hw.init = &(struct clk_init_data){ 111 .hw.init = &(struct clk_init_data){ 115 &meson8b_fixed_pll_dco.hw 128 .hw.init = &(struct clk_init_data){ 211 .hw.init = &(struct clk_init_data){ 216 &hdmi_pll_dco_in.hw 229 .hw.init = &(struct clk_init_data){ 233 &meson8b_hdmi_pll_dco.hw 247 .hw.init = &(struct clk_init_data){ 251 &meson8b_hdmi_pll_dco.hw [all …]
|
H A D | g12a.c | 65 .hw.init = &(struct clk_init_data){ 82 .hw.init = &(struct clk_init_data){ 86 &g12a_fixed_pll_dco.hw 130 .hw.init = &(struct clk_init_data){ 149 .hw.init = &(struct clk_init_data){ 153 &g12a_sys_pll_dco.hw 189 .hw.init = &(struct clk_init_data){ 208 .hw.init = &(struct clk_init_data){ 212 &g12b_sys1_pll_dco.hw 224 .hw.init = &(struct clk_init_data) { [all …]
|
H A D | gxbb.c | 121 .hw.init = &(struct clk_init_data){ 138 .hw.init = &(struct clk_init_data){ 142 &gxbb_fixed_pll_dco.hw 155 .hw.init = &(struct clk_init_data){ 198 .hw.init = &(struct clk_init_data){ 202 &gxbb_hdmi_pll_pre_mult.hw 252 .hw.init = &(struct clk_init_data){ 274 .hw.init = &(struct clk_init_data){ 278 &gxbb_hdmi_pll_dco.hw 292 .hw.init = &(struct clk_init_data){ [all …]
|
H A D | axg-audio.c | 31 .hw.init = &(struct clk_init_data) { \ 47 .hw.init = &(struct clk_init_data){ \ 63 .hw.init = &(struct clk_init_data){ \ 77 .hw.init = &(struct clk_init_data) { \ 99 .hw.init = &(struct clk_init_data) { \ 127 .hw.init = &(struct clk_init_data) { \ 144 .hw.init = &(struct clk_init_data) { \ 167 .hw.init = &(struct clk_init_data) { \ 646 .hw.init = &(struct clk_init_data) { 662 .hw.init = &(struct clk_init_data) { [all …]
|
/openbmc/linux/drivers/net/ethernet/atheros/atl1c/ |
H A D | atl1c_hw.c | 19 int atl1c_check_eeprom_exist(struct atl1c_hw *hw) in atl1c_check_eeprom_exist() argument 23 AT_READ_REG(hw, REG_TWSI_DEBUG, &data); in atl1c_check_eeprom_exist() 27 AT_READ_REG(hw, REG_MASTER_CTRL, &data); in atl1c_check_eeprom_exist() 33 void atl1c_hw_set_mac_addr(struct atl1c_hw *hw, u8 *mac_addr) in atl1c_hw_set_mac_addr() argument 45 AT_WRITE_REG_ARRAY(hw, REG_MAC_STA_ADDR, 0, value); in atl1c_hw_set_mac_addr() 49 AT_WRITE_REG_ARRAY(hw, REG_MAC_STA_ADDR, 1, value); in atl1c_hw_set_mac_addr() 53 static bool atl1c_read_current_addr(struct atl1c_hw *hw, u8 *eth_addr) in atl1c_read_current_addr() argument 57 AT_READ_REG(hw, REG_MAC_STA_ADDR, &addr[0]); in atl1c_read_current_addr() 58 AT_READ_REG(hw, REG_MAC_STA_ADDR + 4, &addr[1]); in atl1c_read_current_addr() 70 static int atl1c_get_permanent_address(struct atl1c_hw *hw) in atl1c_get_permanent_address() argument [all …]
|
/openbmc/linux/drivers/spi/ |
H A D | spi-altera-core.c | 43 static int altr_spi_writel(struct altera_spi *hw, unsigned int reg, in altr_spi_writel() argument 48 ret = regmap_write(hw->regmap, hw->regoff + reg, val); in altr_spi_writel() 50 dev_err(hw->dev, "fail to write reg 0x%x val 0x%x: %d\n", in altr_spi_writel() 56 static int altr_spi_readl(struct altera_spi *hw, unsigned int reg, in altr_spi_readl() argument 61 ret = regmap_read(hw->regmap, hw->regoff + reg, val); in altr_spi_readl() 63 dev_err(hw->dev, "fail to read reg 0x%x: %d\n", reg, ret); in altr_spi_readl() 75 struct altera_spi *hw = altera_spi_to_hw(spi); in altera_spi_set_cs() local 78 hw->imr &= ~ALTERA_SPI_CONTROL_SSO_MSK; in altera_spi_set_cs() 79 altr_spi_writel(hw, ALTERA_SPI_CONTROL, hw->imr); in altera_spi_set_cs() 80 altr_spi_writel(hw, ALTERA_SPI_TARGET_SEL, 0); in altera_spi_set_cs() [all …]
|
H A D | spi-au1550.c | 52 void (*rx_word)(struct au1550_spi *hw); 53 void (*tx_word)(struct au1550_spi *hw); 55 irqreturn_t (*irq_callback)(struct au1550_spi *hw); 89 static void au1550_spi_bits_handlers_set(struct au1550_spi *hw, int bpw); 101 static u32 au1550_spi_baudcfg(struct au1550_spi *hw, unsigned int speed_hz) in au1550_spi_baudcfg() argument 103 u32 mainclk_hz = hw->pdata->mainclk_hz; in au1550_spi_baudcfg() 124 static inline void au1550_spi_mask_ack_all(struct au1550_spi *hw) in au1550_spi_mask_ack_all() argument 126 hw->regs->psc_spimsk = in au1550_spi_mask_ack_all() 132 hw->regs->psc_spievent = in au1550_spi_mask_ack_all() 139 static void au1550_spi_reset_fifos(struct au1550_spi *hw) in au1550_spi_reset_fifos() argument [all …]
|
H A D | spi-oc-tiny.c | 61 struct tiny_spi *hw = tiny_spi_to_hw(spi); in tiny_spi_baud() local 63 return min(DIV_ROUND_UP(hw->freq, hz * 2), (1U << hw->baudwidth)) - 1; in tiny_spi_baud() 69 struct tiny_spi *hw = tiny_spi_to_hw(spi); in tiny_spi_setup_transfer() local 70 unsigned int baud = hw->baud; in tiny_spi_setup_transfer() 73 if (t->speed_hz && t->speed_hz != hw->speed_hz) in tiny_spi_setup_transfer() 76 writel(baud, hw->base + TINY_SPI_BAUD); in tiny_spi_setup_transfer() 77 writel(hw->mode, hw->base + TINY_SPI_CONTROL); in tiny_spi_setup_transfer() 83 struct tiny_spi *hw = tiny_spi_to_hw(spi); in tiny_spi_setup() local 85 if (spi->max_speed_hz != hw->speed_hz) { in tiny_spi_setup() 86 hw->speed_hz = spi->max_speed_hz; in tiny_spi_setup() [all …]
|
/openbmc/linux/drivers/vdpa/ifcvf/ |
H A D | ifcvf_base.c | 13 u16 ifcvf_set_vq_vector(struct ifcvf_hw *hw, u16 qid, int vector) in ifcvf_set_vq_vector() argument 15 struct virtio_pci_common_cfg __iomem *cfg = hw->common_cfg; in ifcvf_set_vq_vector() 23 u16 ifcvf_set_config_vector(struct ifcvf_hw *hw, int vector) in ifcvf_set_config_vector() argument 25 struct virtio_pci_common_cfg __iomem *cfg = hw->common_cfg; in ifcvf_set_config_vector() 32 static void __iomem *get_cap_addr(struct ifcvf_hw *hw, in get_cap_addr() argument 43 IFCVF_DBG(hw->pdev, in get_cap_addr() 48 if (offset + length > pci_resource_len(hw->pdev, bar)) { in get_cap_addr() 49 IFCVF_DBG(hw->pdev, in get_cap_addr() 55 return hw->base[bar] + offset; in get_cap_addr() 72 static u16 ifcvf_get_vq_size(struct ifcvf_hw *hw, u16 qid) in ifcvf_get_vq_size() argument [all …]
|
/openbmc/linux/drivers/scsi/csiostor/ |
H A D | csio_init.c | 68 struct csio_hw *hw = file->private_data - mem; in csio_mem_read() local 83 ret = hw->chip_ops->chip_mc_read(hw, 0, pos, in csio_mem_read() 86 ret = hw->chip_ops->chip_edc_read(hw, mem, pos, in csio_mem_read() 112 void csio_add_debugfs_mem(struct csio_hw *hw, const char *name, in csio_add_debugfs_mem() argument 115 debugfs_create_file_size(name, S_IRUSR, hw->debugfs_root, in csio_add_debugfs_mem() 116 (void *)hw + idx, &csio_mem_debugfs_fops, in csio_add_debugfs_mem() 120 static int csio_setup_debugfs(struct csio_hw *hw) in csio_setup_debugfs() argument 124 if (IS_ERR_OR_NULL(hw->debugfs_root)) in csio_setup_debugfs() 127 i = csio_rd_reg32(hw, MA_TARGET_MEM_ENABLE_A); in csio_setup_debugfs() 129 csio_add_debugfs_mem(hw, "edc0", MEM_EDC0, 5); in csio_setup_debugfs() [all …]
|
H A D | csio_isr.c | 47 struct csio_hw *hw = (struct csio_hw *) dev_id; in csio_nondata_isr() local 51 if (unlikely(!hw)) in csio_nondata_isr() 54 if (unlikely(pci_channel_offline(hw->pdev))) { in csio_nondata_isr() 55 CSIO_INC_STATS(hw, n_pcich_offline); in csio_nondata_isr() 59 spin_lock_irqsave(&hw->lock, flags); in csio_nondata_isr() 60 csio_hw_slow_intr_handler(hw); in csio_nondata_isr() 61 rv = csio_mb_isr_handler(hw); in csio_nondata_isr() 63 if (rv == 0 && !(hw->flags & CSIO_HWF_FWEVT_PENDING)) { in csio_nondata_isr() 64 hw->flags |= CSIO_HWF_FWEVT_PENDING; in csio_nondata_isr() 65 spin_unlock_irqrestore(&hw->lock, flags); in csio_nondata_isr() [all …]
|
H A D | csio_hw.c | 102 static void csio_hw_initialize(struct csio_hw *hw); 103 static void csio_evtq_stop(struct csio_hw *hw); 104 static void csio_evtq_start(struct csio_hw *hw); 106 int csio_is_hw_ready(struct csio_hw *hw) in csio_is_hw_ready() argument 108 return csio_match_state(hw, csio_hws_ready); in csio_is_hw_ready() 111 int csio_is_hw_removing(struct csio_hw *hw) in csio_is_hw_removing() argument 113 return csio_match_state(hw, csio_hws_removing); in csio_is_hw_removing() 119 * @hw: the HW module 133 csio_hw_wait_op_done_val(struct csio_hw *hw, int reg, uint32_t mask, in csio_hw_wait_op_done_val() argument 138 val = csio_rd_reg32(hw, reg); in csio_hw_wait_op_done_val() [all …]
|
/openbmc/linux/drivers/clk/qcom/ |
H A D | clk-rpmh.c | 37 * @hw: handle between common and hardware-specific interfaces 51 struct clk_hw hw; member 84 .hw.init = &(struct clk_init_data){ \ 102 .hw.init = &(struct clk_init_data){ \ 126 .hw.init = &(struct clk_init_data){ \ 134 return container_of(_hw, struct clk_rpmh, hw); in to_clk_rpmh() 213 static int clk_rpmh_prepare(struct clk_hw *hw) in clk_rpmh_prepare() argument 215 struct clk_rpmh *c = to_clk_rpmh(hw); in clk_rpmh_prepare() 225 static void clk_rpmh_unprepare(struct clk_hw *hw) in clk_rpmh_unprepare() argument 227 struct clk_rpmh *c = to_clk_rpmh(hw); in clk_rpmh_unprepare() [all …]
|
/openbmc/linux/drivers/net/ethernet/intel/ixgbevf/ |
H A D | mbx.c | 9 * @hw: pointer to the HW structure 13 static s32 ixgbevf_poll_for_msg(struct ixgbe_hw *hw) in ixgbevf_poll_for_msg() argument 15 struct ixgbe_mbx_info *mbx = &hw->mbx; in ixgbevf_poll_for_msg() 21 while (countdown && mbx->ops.check_for_msg(hw)) { in ixgbevf_poll_for_msg() 31 * @hw: pointer to the HW structure 35 static s32 ixgbevf_poll_for_ack(struct ixgbe_hw *hw) in ixgbevf_poll_for_ack() argument 37 struct ixgbe_mbx_info *mbx = &hw->mbx; in ixgbevf_poll_for_ack() 43 while (countdown && mbx->ops.check_for_ack(hw)) { in ixgbevf_poll_for_ack() 53 * @hw: pointer to the HW structure 58 static u32 ixgbevf_read_mailbox_vf(struct ixgbe_hw *hw) in ixgbevf_read_mailbox_vf() argument [all …]
|