The present application claims the benefit of Chinese Patent Application No. 201910381978.X, filed on May 8, 2019, the contents of which are hereby incorporated by reference.
The present disclosure relates to the technical field of USB debugging, and in particular, to a universal debugging method for a USB device and a USB device.
Due to the plug-and-play feature of USB itself, more and more peripheral accessories have been made into with USB interfaces, and the USB ports of hosts such as personal computers (PCs), tablets are used to energize, identify and operate the accessories.
What follows is the need for debugging USB devices. The traditional debugging methods are as follows:
1) leading out serial cables on the USB devices, and using console mechanism of the Linux (A set of free-use and free-spread Unix-like operating system, which is a multi-user, multi-tasking, multi-threading and multi-CPU operating system based on POSIX and UNIX. It can run major UNIX tool softwares, applications and network protocols.) to debug the devices.
The disadvantages are:
Hardware external serial cable is required. During the sales phase of the devices, the serial cable will be removed, and the device cannot be debugged at this time.
Hackers can obtain important information about the device by viewing the print information through an external serial port, and may even crack the password mechanism of the serial port to obtain system debugging permission.
2) using ADB debugging method of android (a Linux-based free and open-source operating system).
The disadvantages are:
It is needed to install ADB driver on the hosts such as PCs to use the ADB function normally, and the configuration is a little more cumbersome;
The ADB function requires two additional bulk endpoints in order to implement the ADB GADGET function, which requires more endpoint resources of the USB devices;
During the sales phase of the devices, it is not expected that the device will enumerate one more ADB device, which is not conducive to the use of the user, and also has security risks.
The technical problem to be solved by the present disclosure is to provide a universal debugging method for a USB device and a USB device, wherein, using a USB interface to implement a HID device can realize drive-free execution, and at the same time, by using the endpoint of the HID device, endpoints needed for additional debugging and driving can be saved.
To solve the above problems, an embodiment of the present disclosure provides a universal debugging method for a USB device, including:
receiving input information of the terminal through a HID device;
when report ID of the input information is a serial port ID, transmitting the input information to a buffer of a virtual serial port TTY device;
extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path.
Furthermore, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
Furthermore, the method also includes:
implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs;
correspondingly, implementing a serial port debugging tool of the HID device on the terminal for performing debugging communication with the USB device to be debugged, and the report ID in the debugging communication process being a serial port ID.
Furthermore, the method also includes:
when the report ID of the input information is a service ID, performing normal service.
An embodiment of the disclosure further provides a universal debugging method for a USB device, including:
sending input information to the USB device to be debugged, so that the USB device to be debugged performing the following steps:
receiving input information of a terminal through a HID device;
when report ID of the input information is a serial port ID, transmitting the input information to a buffer of a virtual serial port TTY device;
extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path.
Furthermore, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
Furthermore, the method also includes:
implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs.
correspondingly, implementing a serial port debugging tool of the HID device on the terminal for performing debugging communication with the USB device to be debugged, and the report ID in the debugging communication process being a serial port ID.
An embodiment of the present disclosure further provides a USB device, including:
a communication module for receiving input information of a terminal through a HID device;
a debugging module for transmitting the input information to a buffer of a virtual serial port TTY device when report ID of the input information is a serial port ID; extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path.
Furthermore, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
Furthermore, the USB device also includes:
a HID device implementation module for implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs.
The embodiments of the present disclosure have the following beneficial effects:
The present disclosure provides a universal debugging method for a USB device and a USB device. In one embodiment: receiving input information of the terminal through a HID device; when report ID of the input information is a serial port ID, transmitting the input information to a buffer of a virtual serial port TTY device; extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path. Based on the teachings of this embodiment, using a USB interface to implement a HID device can realize drive-free execution, and at the same time, by using the endpoint of the HID device, endpoints needed for additional debugging and driving can be saved.
In the following, the technical solutions in the embodiments of the present disclosure are clearly and completely described with reference to the drawings in the embodiments of the present disclosure. Obviously, the described embodiments are only a part of the embodiments of the present disclosure, but not all of the embodiments. Based on the embodiments of the present disclosure, all other embodiments obtained by those skilled in the art without creative efforts are within the scope of the present disclosure.
It should be understood that when used in this description and the appended claims, the terms “including” and “comprising” indicate the presence of described features, entireties, steps, operations, elements and/or components; but do not exclude the presence or addition of one or more other features, entireties, steps, operations, elements, components and/or collections thereof.
It should also be understood that the term used in the description of the disclosure herein is for the purpose of describing particular embodiments only and is not intended to limit the disclosure. As used in the description and appended claims of the disclosure, the singular forms “a”, “an” and “the” are intended to include the plural forms unless clearly indicates in the context otherwise.
It should be further understood that the term “and/or” used in the description and appended claims of the disclosure means any combination and all possible combinations of one or more of the items relatedly listed.
It should be noted that the step numbers used in the text are only for the convenience of description, and are not intended to limit the order of the execution of the steps.
Referring to
S11, receiving input information of a terminal through a HID device.
The category of the HID device is the first USB category supported by Windows.
HID (Human Interface Device) is a device that interacts directly with human, such as a keyboard, mouse and joystick. However, the devices that conforming to the HID category specification are all HID devices, and do not necessarily have a human interface.
USB (Universal Serial Bus) is a serial bus standard that connecting computer systems and external devices, and also a technical specification of input and output interfaces. It is widely used in information communication products such as personal computers and mobile devices, and extended to other related fields such as photographic equipment, digital TV, game consoles, etc.
Preferably, the terminal referred to in these embodiments should be a personal computer PC end. Said terminal should be understood to include at least one of the followings: a smart phone, a tablet personal computer (Pc), a mobile phone, a video phone, an e-book reader, a desktop PC, a laptop PC, a netbook computer, a Personal Digital Assistant (PDA), a Portable Multimedia Player (PMP), a Moving Picture Experts Group (MPEG-1 or MPEG-2), an Audio Layer (MP3) Player, a Mobile Medical Device, a Camera or a Wearable Device (e.g., Headset Device (HMD) (such as electronic glass), electronic clothing, an electronic bracelet, an electronic necklace, an electronic application accessory, an electronic tattoo, a smart watch, etc.).
In a specific USB device debugging process, the input information of the terminal should be understood as debugging information. The debugging information may be instruction information for debugging the USB device to be debugged, instruction information for debugging the software, and the USB device to be debugged can response to the debugging information, process the specific content of the debugging information, and complete the instruction corresponding to the debugging information.
Said instruction information for debugging the USB device to be debugged is used to complete the debugging of the USB device (chip) under the condition of instruction information of debugging the USB device. Said instruction information for debugging the software is used to complete the debugging of the USB device (chip) software under the condition of instruction information of debugging the software in the USB device (chip). Preferably, when the debugging information is instruction information for debugging the software, in addition to performing software debugging, software upgrade should also be included.
S12, when the report ID of the input information is a serial port ID, transmitting the input information to a buffer of a virtual serial port TTY device.
In a specific embodiment, a virtual serial port TTY device is implemented in the USB device to be debugged, and the node is /dev/ttyHID0. The virtual serial port TTY device is used to implement the Linux console debugging serial port mechanism, and interact with the user input (through the terminal) through the GETTTY program.
S13, extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path.
Wherein, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
The debugging of the USB device to be debugged depends on the SHELL support of Linux itself. In this embodiment, the virtual serial port TTY device is used as the serial terminal of GETTTY. After logging in, you enter the SHELL, execute the shell command on the terminal, support the binary command execution of Linux, and return the debugging results to the terminal.
Because the USB device to be debugged obtains debugging information by implementing the HID device, on the one hand, the driver-free is implemented directly without the need to install an additional driver, and on the other hand, the endpoint of the HID device is directly used, which saves the endpoints needed to implement additional debugging drivers.
It should be noted that only when the service of the USB device to be debugged is also implemented with the HID endpoint, the endpoint can be saved. For example, the function of the USB device to be debugged is a screen projector. If the USB device to be debugged uses other types of endpoints, such as a BULK endpoint, an isochronous endpoint, to implement the function of the USB device to be debugged, a HID device must be enumerated using the HID endpoint except for the function. It should be understood that when the report ID of the input information is a service ID, there is no need to implement a HID device.
Referring to
S10, Implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs. Correspondingly, implementing a serial port debugging tool of the HID device on the terminal for performing debugging communication with the USB device to be debugged, and the report ID in the debugging communication process being a serial port ID.
The USB device to be debugged contains two FUNC descriptors. The report IDs of these two descriptors are different, wherein, one is a serial port ID and the other is a service ID. These two IDs can be customized as long as they are different.
In a preferred embodiment, the method further includes:
when the report ID of the input information is a service ID, performing normal service.
The normal service is actually related to the function of the USB device to be debugged. For example, when the function of the USB device to be debugged is a screen projector, the normal service refers to the transmission of the screen projection data and the control information.
When the terminal sends the display data and audio data that need to be screened to the USB device to be debugged through the service ID, at this time, the USB device to be debugged can judge that the report ID is the service ID, perform normal service processing, and transmit the display data and the audio data to other devices (such as monitors).
An embodiment of the present disclosure further provides a universal debugging method for a USB device, including:
sending input information to the USB device to be debugged, so that the USB device to be debugged performing the following steps:
receiving the input information of a terminal by a HID device.
The terminal referred to in this embodiment should preferably be a personal computer PC end. Said terminal should be understood to include at least one of the followings: a smart phone, a tablet personal computer (Pc), a mobile phone, a video phone, an e-book reader, a desktop PC, a laptop PC, a netbook computer, an Personal Digital Assistant (PDA), a Portable Multimedia Player (PMP), a Moving Picture Experts Group (MPEG-1 or MPEG-2), an Audio Layer (MP3) Player, a Mobile Medical Device, a Camera or a Wearable Device (e.g., Headset Device (HMD) (such as electronic glass), electronic clothing, an electronic bracelet, an electronic necklace, an electronic application accessory, an electronic tattoo, a smart watch, etc.).
In a specific USB device debugging process, the input information of the terminal should be understood as debugging information. The debugging information may be instruction information for debugging the USB device to be debugged, instruction information for debugging the software, and the USB device to be debugged can response to the debugging information, process the specific content of the debugging information, and complete the instruction corresponding to the debugging information.
Said instruction information for debugging the USB device to be debugged is used to complete the debugging of the USB device (chip) under the condition of instruction information of debugging the USB device. Said instruction information for debugging the software is used to complete the debugging of the USB device (chip) software under the condition of instruction information of debugging the software in the USB device (chip). Preferably, when the debugging information is instruction information for debugging the software, in addition to performing software debugging, software upgrade should also be included.
when the report ID of the input information is a serial port ID, transmitting the input information to a buffer of a virtual serial port TTY device.
In a specific embodiment, a virtual serial port TTY device is implemented in the USB device to be debugged, and the node is /dev/ttyHID0. The virtual serial port TTY device is used to implement the Linux console debugging serial port mechanism, and interact with the user input (through the terminal) through the GETTTY program.
extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning execution result to the terminal through the original path.
Wherein, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
The debugging of the USB device to be debugged depends on the SHELL support of Linux itself. In this embodiment, the virtual serial port TTY device is used as the serial terminal of GETTTY. After logging in, you enter the SHELL, execute the shell command on the terminal, support the binary command execution of Linux, and return the debugging results to the terminal.
Because the USB device to be debugged obtains debugging information by implementing the HID device, on the one hand, the driver-free is implemented directly without the need to install an additional driver, and on the other hand, the endpoint of the HID device is directly used, which saves the endpoints needed to implement additional debugging drivers.
It should be noted that only when the service of the USB device to be debugged is also implemented with the HID endpoint, the endpoint can be saved. For example, the function of the USB device to be debugged is a screen projector. If the USB device to be debugged uses other types of endpoints, such as a BULK endpoint, an isochronous endpoint, to implement the function of the USB device to be debugged, a HID device must be enumerated using the HID endpoint except for the function. It should be understood that when the report ID of the input information is a service ID, there is no need to implement a HID device.
In a preferred embodiment, the method further includes:
implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs.
The USB device to be debugged contains two FUNC descriptors. The report IDs of these two descriptors are different, wherein, one is a serial port ID and the other is a service ID. These two IDs can be customized as long as they are different.
correspondingly, implementing a serial port debugging tool of the HID device on the terminal for performing debugging communication with the USB device to be debugged, and the report ID in the debugging communication process being a serial port ID.
In a preferred embodiment, the method further includes:
when the report ID of the input information is a service ID, performing normal service.
The normal service is actually related to the function of the USB device to be debugged. For example, when the function of the USB device to be debugged is a screen projector, the normal service refers to the transmission of the screen projection data and the control information.
When the terminal sends the display data and audio data that need to be screened to the USB device to be debugged through the service ID, at this time, the USB device to be debugged can judge that the report ID is the service ID, perform normal service processing, and transmit the display data and the audio data to other devices (such as monitors).
Referring to
a communication module 41 for receiving input information of a terminal through a HID device.
Preferably, the terminal referred to in this embodiment should be a personal computer PC end. Said terminal should be understood to include at least one of the followings: a smart phone, a tablet personal computer (Pc), a mobile phone, a video phone, an e-book reader, a desktop PC, a laptop PC, a netbook computer, a personal Digital Assistant (PDA), a Portable Multimedia Player (PMP), a Moving Picture Experts Group (MPEG-1 or MPEG-2), an Audio Layer (MP3) Player, a Mobile Medical Device, a Camera or a Wearable Device (e g, Head-mounted Device (HMD) (such as electronic glass), electronic clothing, an electronic bracelet, an electronic necklace, an electronic application accessory, an electronic tattoo, a smart watch, etc.).
In a specific USB device debugging process, the input information of the terminal should be understood as debugging information. The debugging information may be instruction information for debugging the USB device to be debugged, instruction information for debugging the software, and the USB device to be debugged can response to the debugging information, process the specific content of the debugging information, and complete the instruction corresponding to the debugging information.
Said instruction information for debugging the USB device to be debugged is used to complete the debugging of the USB device (chip) under the condition of instruction information of debugging the USB device. Said instruction information for debugging the software is used to complete the debugging of the USB device (chip) software under the condition of instruction information of debugging the software in the USB device (chip). Preferably, when the debugging information is instruction information for debugging the software, in addition to performing software debugging, software upgrade should also be included.
a debugging module 42 for transmitting the input information to a buffer of a virtual serial port TTY device when the report ID of the input information is a serial port ID; extracting the input information of the terminal from the buffer of the virtual serial port TTY device, executing a shell command on the input information, and returning the execution result to the terminal through the original path.
In a specific embodiment, a virtual serial port TTY device is implemented in the USB device to be debugged, and the node is /dev/ttyHID0. The virtual serial port TTY device is used to implement the Linux console debugging serial port mechanism, and interacts with the user input (through the terminal) through the GETTTY program.
Wherein, said extracting the input information of the terminal from the buffer of the virtual serial port TTY device specifically means that the GETTTY program extracts the input information of the terminal from the buffer of the virtual serial port TTY device by means of /dev/ttyHID0 of the virtual serial port TTY device.
The debugging of the USB device to be debugged depends on the SHELL support of Linux itself. In this embodiment, the virtual serial port TTY device is used as a serial terminal of GETTTY. After logging in, you enter the SHELL, execute the shell command on the terminal, support the binary command execution of Linux, and return the debugging results to the terminal.
Because the USB device to be debugged obtains debugging information by implementing the HID device, on the one hand, the driver-free is implemented directly without the need to install an additional driver, and on the other hand, the endpoint of the HID device is directly used, which saves the endpoints needed to implement additional debugging drivers.
It should be noted that only when the service of the USB device to be debugged is also implemented with the HID endpoint, the endpoint can be saved. For example, the function of the USB device to be debugged is a screen projector. If the USB device to be debugged uses other types of endpoints, such as a BULK endpoint, an isochronous endpoint, to implement the function of the USB device to be debugged, a HID device must be enumerated using the HID endpoint except for the function. It should be understood that when the report ID of the input information is a service ID, there is no need to implement a HID device.
Referring to
a HID device implementation module 43 for implementing a HID device on the USB device to be debugged, wherein said HID device contains two descriptors with different report IDs.
The USB device to be debugged contains two FUNC descriptors. The report IDs of these two descriptors are different, wherein, one is a serial port ID and the other is a service ID. These two IDs can be customized as long as they are different.
correspondingly, implementing a serial port debugging tool of the HID device on the terminal for performing debugging communication with the USB device to be debugged, and the report ID in the debugging communication process being a serial port ID.
In a preferred embodiment, the communication module is further used to perform normal service when the report ID of the input information is a service ID.
The normal service is actually related to the function of the USB device to be debugged. For example, when the function of the USB device to be debugged is a screen projector, the normal service refers to the transmission of the screen projection data and the control information.
When the terminal sends the display data and audio data that need to be screened to the USB device to be debugged through the service ID, at this time, the USB device to be debugged can judge that the report ID is the service ID, perform normal service processing, and transmit the display data and the audio data to other devices (such as monitors).
A person of ordinary skill in the art can understand that all or part of the processes in the methods of the foregoing embodiments can be implemented by using a computer program to instruct related hardware. The program can be stored in a computer-readable storage medium. When the program is executed, the processes of the embodiments of the methods described above may be included. The storage medium may be a magnetic disk, an optical disk, a read-only memory (ROM) or a random access memory (RAM) etc.
The above is preferred embodiments of the present disclosure, and it should be noted that those skilled in the art can also make several improvements and retouches without departing from the principles of the present disclosure. These improvements and retouches are also in the protection scope of the present disclosure.
Number | Date | Country | Kind |
---|---|---|---|
201910381978.X | May 2019 | CN | national |