|Publication number||US7380705 B2|
|Application number||US 10/650,182|
|Publication date||Jun 3, 2008|
|Filing date||Aug 28, 2003|
|Priority date||Aug 28, 2003|
|Also published as||CN1842778A, DE602004018343D1, EP1668526A1, EP1668526B1, US20050045726, WO2005024641A1, WO2005024641B1|
|Publication number||10650182, 650182, US 7380705 B2, US 7380705B2, US-B2-7380705, US7380705 B2, US7380705B2|
|Inventors||Jeffrey J. Terlizzi, Rizwan Ahmad Alladin, Tong-Hsiao Chang, John Joseph Fioriglio, Peter Musteric, Robert W. DiGiovanna|
|Original Assignee||Symbol Technologies, Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (11), Non-Patent Citations (4), Referenced by (5), Classifications (12), Legal Events (9)|
|External Links: USPTO, USPTO Assignment, Espacenet|
1. Field of the Invention
The present invention relates generally to a data acquisition system, and more particularly, to a system and method for interfacing a data acquisition device to a host device via a plurality of interfaces.
2. Description of the Related Art
Various types of data acquisition devices exist which allow a user to collect and transmit data to a host computing device. Data acquisition devices may be terminals, with keypad entry means and a display. In addition, data acquisition devices may be bar code scanners in a stand alone configuration or integrated with a terminal. Various types of bar code scanning devices are known in the art which optically scan a bar code printed on a substrate for capture of data encoded in the bar code. Laser bar code scanning devices use a laser light source such as a visible laser diode to scan the bar code by sweeping the laser source across the bar code with a mechanically oscillating reflecting element such as a mirror. The light reflected from the bar code is collected by a photosensor directly from the bar code or retroreflectively off of a portion of the scanning mirror. The analog waveform output by the photosensor has an amplitude which represents the amount of laser light reflected off the bar code. Thus, the varying amplitude of the analog waveform represents the relative spacing of the various bars and spaces of the bar code, which in turn represents the data encoded therein. The analog signal is processed, digitized and decoded into data representative of that which had been encoded into the target bar code.
Bar code scanning devices are also known in the art which are based on solid state imagers such as charge coupled devices (CCDs). CCD based bar code readers are either one-dimensional or two-dimensional. One-dimensional CCD bar code scanners use a linear array of photosensors to capture an image of a cross section of the entire linear bar code at once and produce an analog waveform whose amplitude is representative of the darkness and lightness of the bars and spaces of the captured image. The electric charge stored in each element of the CCD array as a function of the amount of light sensed by an area covered by each element is shifted out serially to form electric signals for further processing, digitizing and decoding. Two dimensional CCD bar code readers operate similarly to capture an image of an entire two-dimensional bar code symbol at once and process it accordingly. The waveform is digitized and decoded in a means similar to laser scanners.
The decoded signals are typically transmitted to a host device for processing, storage, and the like. Many types of host devices exist, depending on the particular application desired by the user. For example, scanners are used at POS cash register terminals to scan in the bar code of a product, where the terminal uses the bar code data as a pointer to look up the price and item description in memory. Scanners are also used to interface to personal computers with keyboard wedges, where the scanner is inserted in the path between the keyboard and the computer, and the scanner input must be configured to appear the same to the computer as keyed input from the keyboard. Scanners are also used to drive RS-232 computer interfaces in other applications.
In most cases, each different type of host device implements a different type of input/output interface, thus requiring different mechanical connectors, different electrical and data formats and protocols, etc. depending on the user's application. Prior art devices were thus usually configured by the manufacturer to interface with one or more host devices. This custom type of scanner-host device matching is costly and inefficient.
In U.S. Pat. No. 5,258,604, a system is suggested which implements a bar code scanning device which is configured to accept any of a plurality of differently configured interface boards in its handle, wherein each type of interface board is specially adapted to mate with an associated host device. The decoder in the scanner polls the interface board upon power-up and reads an identification code from the particular interface board which the user has inserted. The identification code is used by the decoder to access configuration and formatting data from an on-board memory in order to transmit data to the interface board and ultimately to the host device in the required manner. This requires a user to have to swap electrical boards inside the scanner device whenever he desires to use the scanner with a different host device, which is unwieldy and potentially damaging to the boards due to electrostatic discharge (ESD) phenomena. In addition, when a new type of host device is desired to be used with a scanner already in use in the field, the scanner must be physically reconfigured in order to be able to recognize a new identification code from a new type of interface board and to properly format the decoded data for transfer to the new type of host device.
It is also desired in the field of data acquisition such as bar code scanning to be able to use a particular data acquisition device with different host devices at different times by simply connecting the data acquisition device to the host device in a “plug and play” environment, without having to physically reconfigure the data acquisition device with different internal interface boards as in the prior art. This may occur, for example, with a data acquisition device that is used to scan bar codes during the daytime at a POS terminal, and then is used at night time for inventory collection purposes in a storage room with a different host device.
A system and method for interfacing a data acquisition device to a host device via a plurality of interfaces are provided. The present invention is enabled by a multi-interface controller which enables the data acquisition device to interface to a plurality of host devices having different interfaces, e.g., RS232, USB, keyboard wedge, IBM4683, wand emulation, synapse, undecoded, etc.
According to one aspect of the present invention, an interface controller for interfacing a data acquisition device to at least one host device is provided. The interface controller comprises a microcomputer for translating received data from the data acquisition device and outputting a host device type signal; and a switching circuit for electrically coupling the microcomputer to the at least one host device based on the host device type signal and transmitting the received data to the host device.
In another aspect of the present invention, a data acquisition device comprises a scan engine for optically acquiring encoded data from a substrate; a decoder for receiving input data from the scan engine and decoding the received input data according to a predetermined symbology; and an interface controller for interfacing the data acquisition device to at least one host device based on a type of the at least one host device.
In a further aspect of the present invention, a data acquisition system is provided comprising a data acquisition device for acquiring data from a substrate; at least one host device for receiving and processing the acquired data; and an interface controller for interfacing the data acquisition device to at least one host device based on a type of the at least one host device.
In another aspect of the present invention, a method for interfacing a data acquisition device to at least one host device is provided, the method comprising the steps of coupling the data acquisition device to the at least one host device with an interface controller; determining a type of the at least one host device; and configuring the interface controller based on the type of the at least one host device.
The above and other aspects, features, and advantages of the present invention will become more apparent in light of the following detailed description when taken in conjunction with the accompanying drawings in which:
Preferred embodiments of the present invention will be described hereinbelow with reference to the accompanying drawings. In the following description, well-known functions or constructions are not described in detail to avoid obscuring the invention in unnecessary detail.
The data acquisition device 120 in one embodiment is a scanner integrated terminal and comprises a bar code scan engine and a decoder. The bar code scan engine may be of any type known in the art as described above which produces a digitized signal (digital bar pattern DBP) which is representative of the relative spacing of the bars and spaces of the bar code which is scanned. The decoder may also be of any type known in the art which operates on the digital bar pattern via various algorithms stored in an associated memory to decode the digital bar pattern to a digital data signal in accordance with the particular symbology being implemented. The decoder may be configured to decode bar code symbols in any one symbology desired, or it may be configured in an autodiscrimination mode to automatically detect and decode bar codes of more than one symbology and provide the digital data accordingly.
The host interface cable 130 includes a data acquisition device coupler 132 for coupling the interface cable 130 to the data acquisition device 120, a plurality of electrical conductors 134 for transmitting and receiving information to and from the host device 140 and a host-specific coupler 136 for coupling the interface cable 130 to the host device 140. Preferably, the data acquisition device coupler 132 is a ten pin RJ45-type connector. It is to be understood that each host will require a differently configured host-specific coupler 136.
The microcomputer 302 will also include the necessary peripheral function blocks for communicating with a plurality of host devices. For example, the microcomputer will include three serial communication interface (SCI) ports for serial communications, a USB transceiver and USB module to process standard USB commands which allows the microcomputer 302 to tend to other tasks while attached to a USB host device, a direct memory access (DMA) controller, and a data transfer controller (DTC) for automated transfer of data for background loading of captured barcode data.
To ensure proper operation of the microcomputer 302, the multi-interface controller 202 will include a voltage regulator 312 for regulating a power supply voltage provided to the microcomputer 302 and a reset circuit 314 for monitoring the power supply voltage and providing a reset signal to the microcomputer 302 whenever the power supply voltage falls below a predetermined threshold.
Furthermore, the multi-interface controller 202 will include a download detect circuit 316 for downloading the program instructions for the microcomputer 302. A FLASH download procedure is initiated when a download cable is connected to the multi-interface controller 202. The download cable's configuration is illustrated in
The microcomputer 302 will determine a type of host device to be interface to in two ways. First, the host type will be auto-detected upon connecting the host interface cable 130 to the host device 140. For example, when connecting to a host device using a USB or synapse interface, the microcomputer 302 will automatically determine the type of host device connected. Alternatively, the data acquisition device will scan a bar code or other symbology and send a host device type signal to the microcomputer 302. Furthermore, a default host type can also be preconfigured with application software e.g. “123Scan” software commercially available from Symbol Technologies of Holtsville, N.Y.
Once the microcomputer 302 has determined the type of host device connected, the microcomputer 302 will send the host device type signal to the interface circuitry 304 for configuring the multi-interface controller 202 for the specific host device.
Once the switching circuit 404 has been configured for a specific host device, the data acquisition device will communicate to the host device 140 over a specific host interface cable 130.
Operations of the multiplexer 402 and switching circuit 404 will now be described in detail with reference to
The multiplexer 402 and switching circuit 404 enables one printed circuit board (PCB) configuration to support a plurality of interfaces, e.g., RS232 (TTL), USB, Synapse, Wand, Keyboard Wedge and IBM 468X/9X, and communications via each of the plurality of interfaces.
The multi-interface controller 202 is configured for a RS232 host device when the “RS232—Standard Host” parameter bar code is scanned. A RS232 host interface cable is also required to connect to the host correctly, the configuration of which is shown in
When configured for an RS232 host device, the multi-interface controller 202 communicates via 4 signals:
Once the control signal RS232_EN* is driven low via the microcomputer 302, inverting line driver U30 (gates at pins 11 & 9 and pins 13 & 7) is activated allowing for communication on the TXD and RTS from the microcomputer 302 to the host device. The driver U30 is a TTL to CMOS inverting line driver with output enable. The driver U30 has two sets of four inverting gates with an output enable for each set of four. The remaining two inverter gates controlled by RS232_EN* are used for voltage level translation since the interface circuitry 304 communicates to the host device at 5V levels and the microcomputer 302 operates at 3.3V. Also note that the additional set (U30 pins: 8 & 12, 6 & 14, 4 & 16, 2 & 18) are used for 3.3V to 5V level translation.
Based on the standard RS232 specification host transceivers can be transmitting up to +/−25V, thus circuit protection is required for integrated circuits operating off of the +5V rail. Pins 2, 3 9, & 10 of switch U6 and pins 2 & 6 of switch U14 are protected by voltage clamping circuitry. The voltage clamp circuit is comprised of zener diode CR6 and schotky diodes CR4 and CR5. Voltage at output connector J1 pins 5 and 7 will be clamped to approximately ground and 5V. Current limit through the clamp circuit is based on the output impedance of the RS232 driver. This impedance is specified as a minimum of 300 Ohms and is typically in the order of multiple MOhms.
As shown in
Resistors R9 and R10 are chosen to allow for compliance with the USB signal quality tests and also note the bulk board capacitance has been chosen to hold surge currents within the USB surge current requirements.
If the USB Bus state is idle for more than 3 ms, the multi-interface controller 202 is required to go into a suspend mode, drawing less than 500 μA within 10 mS of bus inactivity. The microcomputer 302 must configure all ports to reduce idle current before going into the microcomputer 302 sleep mode. The SUSPEND* signal must be driven low, and all signals driving the TTL to CMOS inverting line driver U30 must be driven low. This disables driver U30 and significantly reduces the device quiescent current and allows the interface controller to comply with a <500 μA suspend current requirement for low power consumption. Also note, resistor network RN1 keeps the multi-interface controller 202 in USB mode while driver U30 is disabled.
Synapse is a proprietary interface between a data acquisition device and a Synpase host device. It is a 5V bi-directional signaling scheme. A “1” level is passively generated from a pull-up resistor and the “0” level is actively driven low by a transistor, e.g., a BJT open-collector drive.
When a the Synapse host interface cable is plugged in, the microcomputer 302 attempts to automatically identify the Synapse host device by communicating on the following lines:
The Synapse autodiscrimation process determines if the multi-interface controller 202 is connected to a Synapse host device. Once it completes this process successfully, communication begins on the above signals. Inverters U9:10,11 and U9:1,2 are 5V tolerant inverters and are used to level shift from 5V to 3.3V logic.
When configured for Wand Emulation, the multi-interface controller 202 communicates to the host device via 3 signals:
When the multi-interface controller 202 is configured for keyboard wedge mode and desires to send data, the microcomputer 302 drives the WEDGE_EN* signal of the multiplexer 402 high and communicates to the host device on the following lines:
When the data acquisition device is not sending data, the WEDGE_EN* is driven low and the analog switches U6:10,11,12 and U6:3,4,5 are closed. This is the pass through mode and allows normal communication to flow between the keyboard and the host device.
The IBM 468X interface is based on a half duplex RS485 signaling scheme. U13 is a differential bus transceiver and is controlled by the following signals:
Also note, transistor Q14:1,2,6 controls the supply current to transceiver U13. During USB suspend mode, SUSPEND_CTL is pulled high which turns off transistor Q14 and removes the supply voltage from the transceiver U13 (VCC—485). This allows the multi-interface controller 202 to comply with the <500 μA suspend current requirement for low power consumption.
Once the type of host device connected has been determined (step 808), the microcomputer 302 will send a host device type signal to the interface circuitry 304 for configuring the multi-interface controller 202 (step 810). The multiplexer 402 will receive the host device type signal and outputs a plurality of signals relating to the host device type to the switching circuit 404. The switching circuit 404 then sets the appropriate switches to couple outputs of the microcomputer 302 to the output connector 406 of the interface circuitry 304. Additionally, the microcomputer 302 will load a host-specific translation module from the Flash memory for translating the data received from the data acquisition device 20 to a format required by the host device 140 (step 812).
While the invention has been shown and described with reference to certain preferred embodiments thereof, it will be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of the invention as defined by the appended claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5258604||Jan 28, 1992||Nov 2, 1993||Psc, Inc.||Bar code scanner|
|US5579489||Jul 26, 1994||Nov 26, 1996||Elonex I.P. Holdings, Ltd.||Hand-held portable computer having capability for external expansion of an internal bus|
|US5703347 *||Sep 9, 1996||Dec 30, 1997||Spectra-Physics Scanning Systems, Inc.||Multiple-interface selection system for computer peripherals|
|US5832244||Feb 20, 1996||Nov 3, 1998||Iomega Corporation||Multiple interface input/output port for a peripheral device|
|US5905249 *||Oct 21, 1997||May 18, 1999||Spectra-Physics Scanning Systems, Inc.||Multiple-interface selection system for computer peripherals|
|US6115678 *||Feb 23, 1999||Sep 5, 2000||Symbol Technologies, Inc.||Universal host interface for data acquisition systems|
|US6415341||Jan 29, 1999||Jul 2, 2002||Tekserve Pos, Llc||Point-of-sale terminal adapter|
|US6705527 *||Jun 1, 2001||Mar 16, 2004||Psc Scanning, Inc.||Universal interface driver system for data reader|
|US20020038378||Mar 30, 2001||Mar 28, 2002||Arnulf Simmon||Multi-tier data acquisition and management system comprising at least one touch-screen enabled portable computing device operably coupled to computers via wireless communication for accessing data records stored in local databases coupled to the computers|
|US20030121981 *||Dec 28, 2001||Jul 3, 2003||Michael Slutsky||Lighthouse ASIC|
|WO1999022305A1||Oct 23, 1998||May 6, 1999||Microsoft Corporation||System and method for interaction between a desktop computer and multiple mobile devices|
|1||International Search Report (4 pages).|
|2||PCT International Preliminary Examination Report, PCT/IPEA/416 and 409 dated May 16, 2006.|
|3||Symbol Product Reference Guide, LS 2501, First Ed., Mar. 1991.|
|4||*||Wikipedia article "Flash memory" available at http://www.wikipedia.org. Retrieved Mar. 17, 2007.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7866549 *||Mar 23, 2006||Jan 11, 2011||Picacho Partners LLC||Identification data decoder|
|US8302865||Jan 31, 2011||Nov 6, 2012||Metrologic Instruments, Inc.||Method, apparatus, and system for programming a barcode symbol scanning terminal with two-dimensional programming code|
|US20070221723 *||Mar 23, 2006||Sep 27, 2007||Wayne Worthington||Identification data decoder|
|US20090167099 *||Dec 1, 2008||Jul 2, 2009||Chung-Ta Chin||Switch Device for Switching Different Type Signals|
|WO2015103676A1 *||Jan 13, 2015||Jul 16, 2015||Guan Jeffery||An interface device, server processing system, method, processing system, mobile communication device and computer program|
|U.S. Classification||235/462.15, 235/462.01, 235/454|
|International Classification||G06F13/38, G06K7/14, G06F17/00, G06K7/10, G06F13/40|
|Cooperative Classification||G06F13/4022, G06K7/10881|
|European Classification||G06K7/10S9F, G06F13/40D2|
|Aug 28, 2003||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, INC., NEW YORK
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:TERLIZZI, JEFFREY J.;REEL/FRAME:014477/0869
Effective date: 20030825
|May 22, 2006||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, INC., NEW YORK
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ALLADIN, RIZWAN AHMAD;CHANG, TONG-HSIAO;FIORIGLIO, JOHN JOSEPH;REEL/FRAME:018211/0979
Effective date: 20060518
|Jan 8, 2007||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, INC., NEW YORK
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TERLIZZI, JEFFREY J.;ALLADIN, RIZWAN AHMAD;CHANG, TONG-HSIAO;AND OTHERS;REEL/FRAME:018775/0524;SIGNING DATES FROM 20060518 TO 20070102
|Oct 17, 2007||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, INC., NEW YORK
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TERLIZZI, JEFFREY J.;ALLADIN, RIZWAN AHMAD;CHANG, TONG-HSIAO;AND OTHERS;REEL/FRAME:020014/0617;SIGNING DATES FROM 20071004 TO 20071015
|Sep 23, 2011||FPAY||Fee payment|
Year of fee payment: 4
|Oct 31, 2014||AS||Assignment|
Owner name: MORGAN STANLEY SENIOR FUNDING, INC. AS THE COLLATE
Free format text: SECURITY AGREEMENT;ASSIGNORS:ZIH CORP.;LASER BAND, LLC;ZEBRA ENTERPRISE SOLUTIONS CORP.;AND OTHERS;REEL/FRAME:034114/0270
Effective date: 20141027
|Jul 8, 2015||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, LLC, NEW YORK
Free format text: CHANGE OF NAME;ASSIGNOR:SYMBOL TECHNOLOGIES, INC.;REEL/FRAME:036083/0640
Effective date: 20150410
|Aug 17, 2015||AS||Assignment|
Owner name: SYMBOL TECHNOLOGIES, INC., NEW YORK
Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:MORGAN STANLEY SENIOR FUNDING, INC.;REEL/FRAME:036371/0738
Effective date: 20150721
|Nov 26, 2015||FPAY||Fee payment|
Year of fee payment: 8