In inkjet printing systems, it is desirable to have several characteristics of each print cartridge easily identifiable by a controller, and it is desirable to have such identification information supplied directly by the print cartridge. The “identification information”, for example, can provide information to the printer controller to adjust the operation of the printer and ensure correct operation. A print cartridge can store this identification information using a small, non-volatile memory, such as an erasable programmable read-only memory (EPROM). As print technology evolves, it is desirable to expand the EPROM to store more information. Larger EPROMs, however, lead to longer testing time during manufacture. Longer testing times results in a significant increase in manufacturing cost.
Some embodiments of the invention are described with respect to the following figures:
Addressing an EPROM on a printhead is described. In an example, a printhead for a printer, such as an inkjet printer, includes an EPROM having a plurality of cells arranged in rows and columns. Each cell has a addressing port, a row select port, and a column select port. A conductor is coupled to the addressing port of each of the cells. A column shift register is coupled to the column select ports of the cells and includes a register location for each column of the cells. A row shift register is coupled to the row select ports of the cells and includes a register location for each row of the cells. The column shift register receives an input having a first data signal, and the row shift register receives an input having a second data signal. In operation, a row of the cells is selected by shifting an active logic state into a particular register location of the row shift register. A column of the cells is selected by shifting an active logic state into a particular register location of the column shift register. The conductor can be used to access a cell to retrieve its state (e.g., sense either logic ‘1’ or logic ‘0’ state) if selected by the column shift register and the row shift register.
In this manner, the row and column shift registers can be loaded in parallel to generate an address for the EPROM cell array. This is more efficient than a design having only a scheme of serial shift registers. While a single serial shift register scheme may require less control signals for the printhead, the address must be generated by serially shifting first the row portion and then the column portion. The larger the EPROM cell array, the longer it takes to generate a single address (e.g., in terms of clock cycles) and the longer it takes to read the EPROM (e.g., during testing). The dual bit-shift design described herein reduces the time it takes to generate a single address and thus the time it takes to read the EPROM.
The printhead 104 also includes an electronically programmable read only memory (EPROM) 106 and a dual bit-shift (DBS) address circuit 110. The EPROM 106 can be used to store various information related to the printhead 104 (or IPH), such as identification information, serial numbers, security information, feature information, and the like. As used herein, “EPROM” refers to a non-volatile memory having an array of cells arranged in rows and columns, where each cell can store a single bit of information. Each cell can be programmed with a particular logic state that is retained even when power is removed from the printhead 104. Once programmed, the EPROM 106 can be erased using a known process (e.g., exposure to a strong ultraviolet light source). However, in the context of the printhead 104, the EPROM 106 can be programmed during manufacture and thereafter remain programmed for the life of the printhead 104. Various circuitry for the cells can be used, such as configurations of floating gate field effect transistors (FETs) along with corresponding row and column select FETs. An example cell is shown in
The EPROM 106 can be of a particular size, e.g., configured to store a particular number of bits. The DBS address circuit 110 can be used to address the EPROM 106 and select particular bits for access. As described below, the DBS address circuit 110 provides separate shift registers for row and column selection, which is more efficient in terms of access time than using a single shift register.
The controller 102 is configured to provide a plurality of signals to the printhead 104. The printhead 104 includes an external interface 120 for receiving the external signals from the controller 102 and providing the signals for use by the EPROM 106, the DBS address circuits 110, and the nozzles and circuits 108. The external interface 120 can include, for example, a sense line (referred to herein as ID line 112), data line(s) 114, clock line(s) 116, fire lines 118, and the like. The ID line 112 can be coupled to each cell in the EPROM 106 and can be used to access each cell (e.g., to read data). The data lines 114 can be used to drive the DBS address circuits 110 for addressing the EPROM 106. The clock lines 116 can be used to provide clock signals for use by logic on the printhead (e.g., the DBS address circuits 110). The fire lines 118 can be used to provide energy for ejecting ink from the nozzles 108. The external interface 120 shown in
The banks 204-1 through 204-K receive row and column select signals from address generators 202-1 through 202-K (collectively address generators 202). Each of the address generators 202 includes a row shift register 206 and a column shift register 208. Each of the address generators receives clock signal(s) on the clock line(s) 116 and data signal(s) on the data line(s) 114. The row shift register 206 can include a plurality of register locations equal to the number of rows in the array of cells 210. The column shift register 208 can include a plurality of register locations equal to the number of columns in the array of cells 210.
The data signals (also referred to as control signals) can be used to push data into the row and column shift registers 206 and 208 using clock signals. For example, an active logic state (e.g., logic ‘1’) can be pushed into the row shift register 206 to an Xth register location for selecting row X. An active logic state can be pushed into the column shift register 208 to a Yth register location for selecting column Y. In this manner, an address is generated for a cell 210 located in row X, column Y, allowing said cell to be accessed on the ID line 112. Notably, the row and column shift registers 206 and 208 can be configured in parallel in order to generate the desired address. This is more efficient than if a single shift register is used to generate both the row and column address, which would require row and column address information to be loaded serially.
The shift register 302 receives a signal D1, and the shift register 306 receives a signal D2. The signals D1 and D2 may be provided on data lines, as described above. Clock inputs are omitted for clarity, but are shown in
The transistor Q3 is a floating-gate transistor in that the transistor Q3 includes two gates that are separated from one another by an oxide layer that acts as a dielectric. One of the gates is called a “floating gate” and the other is called a control gate or input gate. The floating gate's only link to the addressing port is through the control gate. A blank EPROM cell has all gates fully open, giving each cell a value of logic ‘0’ (low resistance state). That is, the floating gate initially has no charge, which causes the threshold voltage to be low. To change the value of the bit to logic ‘1’ (high resistance state), a programming voltage is applied to the control gate and drain (assuming the transistors Q1 and Q2 are switched on). The programming voltage draws excited electrons to the floating gate, thereby increasing the threshold voltage. The excited electrons are pushed through and trapped on the other side of the thin oxide layer, giving it a negative charge. These negatively charged electrons act as a barrier between the control gate and the floating gate. During use of the EPROM cell, a cell sensor can monitor the threshold voltage of the cell (assuming the transistors Q1 and Q2 are switched on). If the threshold voltage is low (below the threshold level), the cell has a value of logic ‘0’. If the threshold voltage is high (above the threshold level), the cell as a value of logic ‘1’.
Referring to
In another example, a decoder can be used to multiplex data signals for the column shift register, rather than the row shift register. In another example, decoders can be used to multiplex data signals for both the column shift register and the row shift register.
In various examples described above, the EPROM can be divided into uniquely addressable banks of cells. Such a configuration requires a set of address generating row and column shift registers for each bank of EPROM cells. As each set of row and column shift registers utilize the same clock signals and potentially the same data signals (given data signal multiplexing), busses are required on the printhead to convey the signals among the different circuits. Referring to
For example, consider an example where there are 8 banks of 8×8 EPROM cells for a 512-bit EPROM. For each bank, row and column shift registers would have 8 register locations. The same 512-bit EPROM can be configured into a single bank of EPROM cells having, for example, 16 columns and 32 rows. In such an example, the row shift register would have 32 register locations and the column shift register would have 16 register locations. Busses could be eliminated as only a single set of row and column shift registers are used.
The EPROM banks 706 are addressed using a logical combination of the data signals (e.g., data signals D1-D4 or any subset thereof). The decoders 702 are configured to detect particular logical combinations where each logical combination uniquely identifies a particular EPROM bank 706. For example, when the decoder 702-1 detects a particular logical combination of data signals associated with EPROM bank 706-1, then EPROM bank 706-1 will be addressed and the other EPROM banks 706 are not addressed. For the non-addressed EPROM banks 706, the respective decoders 702 effectively disable address signals for the non-addressed EPROM banks 706. For the addressed EPROM bank 706-1, the decoder 702-1 enables address signals for the EPROM bank 706-1. Any of the EPROM banks 706 can be addressed similarly. In this manner, more EPROM banks 706 can be addressed by a given set of data signals as compared to using one data signal per bank.
In an example, the decoders 702 each generate input signals for their respective shift registers 704. The shift registers 704 sample the input signals to generate address data for their respective banks. To select a cell in an EPROM bank, an asserted logic value is shifted into particular locations of the associated shift register to identify a particular row and column in that bank. When a decoder 702 detects its particular logic combination of the data signals, the decoder 702 generates an input signal that includes the asserted logic value that can be sampled by the respective shift register 704. Otherwise, the decoder 702 generates an input signal that is always de-asserted logically.
In an example, each shift register circuit 704 includes a single shift register for addressing both the row and column of a particular bank. In another example, as discussed above, the shift register circuit 704 can include both a row shift register and a column shift register. In such an example, one of the row and column shift registers can sample the decoder output, while the other shift register can sample a separate data signal (see
The decoder 802 includes transistors Q1 through Q3, and the shift register 804 includes transistors Q4 through Q9. Each of the transistors Q1 through Q9 comprises an N-channel field effect transistor (FET). In the decoder 802, the sources of Q2 and Q3 are coupled to a reference voltage (e.g., electrical ground or GND). The drains of Q2 and Q3 are coupled to a node M0. The gate of Q2 receives signal data signal D2, and the gate of Q3 receives clock signal S3. The source of transistor Q1 is coupled to the node M0. The drain and gate of transistor Q1 receive data signal D1 and clock signal 1, respectively.
In the shift register 804, the gate and drain of transistor Q4 receive clock signal S1. The source of transistor Q4 is coupled to the node Y0. The gate and drain of transistor Q7 receive clock signal S3. The source of transistor Q7 is coupled to the node Y. The drains of transistors Q5 and Q8 are coupled to the nodes Y0 and Y, respectively. The sources of transistors Q5 and Q8 are coupled to the drains of transistors Q6 and Q9, respectively. The sources of transistors Q6 and Q9 are coupled to the reference voltage (e.g., GND). The gate of transistor Q6 is coupled to the node M0, and the gate of transistor Q9 is coupled to the node Y0.
Consider the circuit of
When bank B3 is addressed, both D1 and D2 are logic 1. Since D2 is logic 1, the transistor Q2 is on and the node M0 is discharged (logic 0) and operation proceeds as above in the bank B2 example. Hence, the bank B1 will not be addressed while the bank B3 is being addressed.
When bank B4 is a addressed, both D1 and D2 are logic 0. Since D1 is logic 0, the transistor Q1 will pass logic 0 to the node M0. Since M0 is discharged during S2, operation proceeds as above in the banks B2 and B3 examples. Hence, the bank B1 will not be addressed while the bank B4 is being addressed.
For the bank B3, the decoder 1004 includes transistors Q13 through Q15. The transistor Q15 is coupled between a node M2 and the reference voltage. The transistors Q13 and Q14 are serially coupled between D2 and the node M2. The gates of transistors Q13, Q14, and Q15 are driven by S1, D2, and S3, respectively. If D1 and D2 are both logic 1, then M2 will be charged (logic 1) when S2 occurs and bank 3 will be addressed as described above in the bank B1 example. Note than in other logic combinations of D1 and D2, the node M2 will be discharged during S2 and bank B3 will not be addressed.
For the bank B4, the decoder 1006 includes transistors Q16 through Q19. The transistors Q17 through Q19 are coupled between a node M3 and the reference voltage. The transistor Q16 is serially coupled between S1 and M3. The gates of transistors Q16 through Q19 are driven by S1, D1, D2, and S3 respectively. If D1 and D3 are both logic 0, then M3 will be charged (logic 1) when S2 occurs and bank 4 will be addressed as described above in the bank B1 example. Note than in other logic combinations of D1 and D2, the node M3 will be discharged during S2 and bank B4 will not be addressed.
In the foregoing description, numerous details are set forth to provide an understanding of the present invention. However, it will be understood by those skilled in the art that the present invention may be practiced without these details. While the invention has been disclosed with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover such modifications and variations as fall within the true spirit and scope of the invention.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2014/034456 | 4/17/2014 | WO | 00 |