Lines Matching +full:pulse +full:- +full:width
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright (C) 2004 - 2006 rt2x00 SourceForge Project
24 eeprom->reg_data_clock = 1; in eeprom_93cx6_pulse_high()
25 eeprom->register_write(eeprom); in eeprom_93cx6_pulse_high()
28 * Add a short delay for the pulse to work. in eeprom_93cx6_pulse_high()
37 eeprom->reg_data_clock = 0; in eeprom_93cx6_pulse_low()
38 eeprom->register_write(eeprom); in eeprom_93cx6_pulse_low()
41 * Add a short delay for the pulse to work. in eeprom_93cx6_pulse_low()
53 eeprom->register_read(eeprom); in eeprom_93cx6_startup()
54 eeprom->reg_data_in = 0; in eeprom_93cx6_startup()
55 eeprom->reg_data_out = 0; in eeprom_93cx6_startup()
56 eeprom->reg_data_clock = 0; in eeprom_93cx6_startup()
57 eeprom->reg_chip_select = 1; in eeprom_93cx6_startup()
58 eeprom->drive_data = 1; in eeprom_93cx6_startup()
59 eeprom->register_write(eeprom); in eeprom_93cx6_startup()
62 * kick a pulse. in eeprom_93cx6_startup()
73 eeprom->register_read(eeprom); in eeprom_93cx6_cleanup()
74 eeprom->reg_data_in = 0; in eeprom_93cx6_cleanup()
75 eeprom->reg_chip_select = 0; in eeprom_93cx6_cleanup()
76 eeprom->register_write(eeprom); in eeprom_93cx6_cleanup()
79 * kick a pulse. in eeprom_93cx6_cleanup()
90 eeprom->register_read(eeprom); in eeprom_93cx6_write_bits()
95 eeprom->reg_data_in = 0; in eeprom_93cx6_write_bits()
96 eeprom->reg_data_out = 0; in eeprom_93cx6_write_bits()
97 eeprom->drive_data = 1; in eeprom_93cx6_write_bits()
102 for (i = count; i > 0; i--) { in eeprom_93cx6_write_bits()
106 eeprom->reg_data_in = !!(data & BIT(i - 1)); in eeprom_93cx6_write_bits()
111 eeprom->register_write(eeprom); in eeprom_93cx6_write_bits()
114 * Kick a pulse. in eeprom_93cx6_write_bits()
120 eeprom->reg_data_in = 0; in eeprom_93cx6_write_bits()
121 eeprom->register_write(eeprom); in eeprom_93cx6_write_bits()
130 eeprom->register_read(eeprom); in eeprom_93cx6_read_bits()
135 eeprom->reg_data_in = 0; in eeprom_93cx6_read_bits()
136 eeprom->reg_data_out = 0; in eeprom_93cx6_read_bits()
137 eeprom->drive_data = 0; in eeprom_93cx6_read_bits()
142 for (i = count; i > 0; i--) { in eeprom_93cx6_read_bits()
145 eeprom->register_read(eeprom); in eeprom_93cx6_read_bits()
150 eeprom->reg_data_in = 0; in eeprom_93cx6_read_bits()
155 if (eeprom->reg_data_out) in eeprom_93cx6_read_bits()
156 buf |= BIT(i - 1); in eeprom_93cx6_read_bits()
165 * eeprom_93cx6_read - Read a word from eeprom
170 * This function will read the eeprom data as host-endian word
186 command = (PCI_EEPROM_READ_OPCODE << eeprom->width) | word; in eeprom_93cx6_read()
188 PCI_EEPROM_WIDTH_OPCODE + eeprom->width); in eeprom_93cx6_read()
208 * eeprom_93cx6_multiread - Read multiple words from eeprom
235 * eeprom_93cx6_readb - Read a byte from eeprom
257 command = (PCI_EEPROM_READ_OPCODE << (eeprom->width + 1)) | byte; in eeprom_93cx6_readb()
259 PCI_EEPROM_WIDTH_OPCODE + eeprom->width + 1); in eeprom_93cx6_readb()
280 * eeprom_93cx6_multireadb - Read multiple bytes from eeprom
300 * eeprom_93cx6_wren - set the write enable state
317 command <<= (eeprom->width - 2); in eeprom_93cx6_wren()
320 PCI_EEPROM_WIDTH_OPCODE + eeprom->width); in eeprom_93cx6_wren()
327 * eeprom_93cx6_write - write data to the EEPROM
347 command = PCI_EEPROM_WRITE_OPCODE << eeprom->width; in eeprom_93cx6_write()
352 PCI_EEPROM_WIDTH_OPCODE + eeprom->width); in eeprom_93cx6_write()
358 eeprom->drive_data = 0; in eeprom_93cx6_write()
359 eeprom->reg_chip_select = 1; in eeprom_93cx6_write()
360 eeprom->register_write(eeprom); in eeprom_93cx6_write()
362 /* wait at-least 250ns to get DO to be the busy signal */ in eeprom_93cx6_write()
368 eeprom->register_read(eeprom); in eeprom_93cx6_write()
370 if (eeprom->reg_data_out) in eeprom_93cx6_write()
375 if (--timeout <= 0) { in eeprom_93cx6_write()