Prolific USB to Serial Cable - Windows 10 PL2303 HXD Chipset

This Tronix branded USB to Serial Cable Adapter with enhanced Prolific PL2303 HXD chipset provides an external plug & play RS-232 serial connection with your computer via the USB port. Based on the enhanced Prolific PL2303 HXD, it provides excellent compatibility with superb OS and Windows 10 drivers.
** See also similar item here (USB to Serial Adapter - Windows 10 - PL2303HXD)

For drivers that have no bus-specific fields (i.e. Don’t have a bus-specific driver structure), they would use driverregister and pass a pointer to their struct devicedriver object. Most drivers, however, will have a bus-specific structure and will need to register with the bus using something like pcidriverregister. QuickNet ISDN Varix 14, Varix 200, Varix 840, TA 33 USB available: according to the manufacturer: Aasta-Matra: NeXspan XC, XS 12, XS, XL, 50, NeXspan Communication Server Agfeo 0736: AC 12 USB, AC 14, AC. After the device-specific driver is installed, Windows 10 will select that driver instead of the standard USB audio 2.0 driver when you first connect the device. Note See the device manufacturer's user guide for specific instructions about how to install the driver.

Features and Applications

Prolific PL2303 HXD Revision D Chipset device that works on Windows 7, 8, Windows 10 32 & 64 Bit.
This USB to Serial Adapter is designed for connections to GPS Systems, PDAs, Digital Cameras, Modems, ISDN Terminal Adapters, our DACIO 300 devices and many more devices that require a Serial Port.
Users have the capability to utilise the USB to RS232 adapter with serial port interface in an easy-to-use environment.
Supports automatic handshake mode.
Supports remote wake-up and power management 96 byte buffer each for upstream and downstream data flow.
Frees your RS-232 port for other uses.
No IRQs required, no IRQ conflicts.
Installed as a standard Windows COM port, Full RS-232 modem control signals,
RS-232 data signals; TxD, RxD, RTS, CTS, DSR, DTR, DCD, RI, GND.
Full compliance with the USB Specification Revision 1.1 and supports USB 2.0, USB 3.0

Cable Length is approx 55-60cm from USB connector to RS232 Moulding.
This device is also known as a USB to Serial Adapter & USB to RS232 Adapter.

Works on Windows 7, Windows 8, Windows 10, Android, Mac OS and Linux

ChipsetPl2303 HXD
Length (m)0.67
No of ports1
  • Model No.: 2440
  • Availability: In Stock
  • £7.67

  • Ex VAT: £6.39

0 reviews / Write a review

See the kerneldoc for the struct device_driver.


Device drivers are statically allocated structures. Though there maybe multiple devices in a system that a driver supports, structdevice_driver represents the driver as a whole (not a particulardevice instance).


The driver must initialize at least the name and bus fields. It shouldalso initialize the devclass field (when it arrives), so it may obtainthe proper linkage internally. It should also initialize as many ofthe callbacks as possible, though each is optional.


As stated above, struct device_driver objects are staticallyallocated. Below is an example declaration of the eepro100driver. This declaration is hypothetical only; it relies on the driverbeing converted completely to the new model:

Most drivers will not be able to be converted completely to the newmodel because the bus they belong to has a bus-specific structure withbus-specific fields that cannot be generalized.

The most common example of this are device ID structures. A drivertypically defines an array of device IDs that it supports. The formatof these structures and the semantics for comparing device IDs arecompletely bus-specific. Defining them as bus-specific entities wouldsacrifice type-safety, so we keep bus-specific structures around.

Bus-specific drivers should include a generic struct device_driver inthe definition of the bus-specific driver. Like this:

A definition that included bus-specific fields would look like(using the eepro100 driver again):


Some may find the syntax of embedded struct initialization awkward oreven a bit ugly. So far, it’s the best way we’ve found to do what we want…


Agfeo isdn usb plug driver adapter

The driver registers the structure on startup. For drivers that haveno bus-specific fields (i.e. don’t have a bus-specific driverstructure), they would use driver_register and pass a pointer to theirstruct device_driver object.

Most drivers, however, will have a bus-specific structure and willneed to register with the bus using something like pci_driver_register.

It is important that drivers register their driver structure as early aspossible. Registration with the core initializes several fields in thestruct device_driver object, including the reference count and thelock. These fields are assumed to be valid at all times and may beused by the device model core or the bus driver.

Transition Bus Drivers¶

By defining wrapper functions, the transition to the new model can bemade easier. Drivers can ignore the generic structure altogether andlet the bus wrapper fill in the fields. For the callbacks, the bus candefine generic callbacks that forward the call to the bus-specificcallbacks of the drivers.

This solution is intended to be only temporary. In order to get classinformation in the driver, the drivers must be modified anyway. Sinceconverting drivers to the new model should reduce some infrastructuralcomplexity and code size, it is recommended that they are converted asclass information is added.


Once the object has been registered, it may access the common fields ofthe object, like the lock and the list of devices:

The devices field is a list of all the devices that have been bound tothe driver. The LDM core provides a helper function to operate on allthe devices a driver controls. This helper locks the driver on eachnode access, and does proper reference counting on each device as itaccesses it.


When a driver is registered, a sysfs directory is created in itsbus’s directory. In this directory, the driver can export an interfaceto userspace to control operation of the driver on a global basis;e.g. toggling debugging output in the driver.

A future feature of this directory will be a ‘devices’ directory. Thisdirectory will contain symlinks to the directories of devices itsupports.

Agfeo Isdn Usb Plug Drivers


The probe() entry is called in task context, with the bus’s rwsem lockedand the driver partially bound to the device. Drivers commonly usecontainer_of() to convert “dev” to a bus-specific type, both in probe()and other routines. That type often provides device resource data, suchas pci_dev.resource[] or platform_device.resources, which is used inaddition to dev->platform_data to initialize the driver.

This callback holds the driver-specific logic to bind the driver to agiven device. That includes verifying that the device is present, thatit’s a version the driver can handle, that driver data structures canbe allocated and initialized, and that any hardware can be initialized.Drivers often store a pointer to their state with dev_set_drvdata().When the driver has successfully bound itself to that device, then probe()returns zero and the driver model code will finish its part of bindingthe driver to that device.

A driver’s probe() may return a negative errno value to indicate thatthe driver did not bind to this device, in which case it should havereleased all resources it allocated:

sync_state is called only once for a device. It’s called when all the consumerdevices of the device have successfully probed. The list of consumers of thedevice is obtained by looking at the device links connecting that device to itsconsumer devices.

The first attempt to call sync_state() is made during late_initcall_sync() togive firmware and drivers time to link devices to each other. During the firstattempt at calling sync_state(), if all the consumers of the device at thatpoint in time have already probed successfully, sync_state() is called rightaway. If there are no consumers of the device during the first attempt, thattoo is considered as “all consumers of the device have probed” and sync_state()is called right away.


Agfeo Isdn Usb Plug Driver Updater

If during the first attempt at calling sync_state() for a device, there arestill consumers that haven’t probed successfully, the sync_state() call ispostponed and reattempted in the future only when one or more consumers of thedevice probe successfully. If during the reattempt, the driver core finds thatthere are one or more consumers of the device that haven’t probed yet, thensync_state() call is postponed again.

A typical use case for sync_state() is to have the kernel cleanly take overmanagement of devices from the bootloader. For example, if a device is left onand at a particular hardware configuration by the bootloader, the device’sdriver might need to keep the device in the boot configuration until all theconsumers of the device have probed. Once all the consumers of the device haveprobed, the device’s driver can synchronize the hardware state of the device tomatch the aggregated software state requested by all the consumers. Hence thename sync_state().

While obvious examples of resources that can benefit from sync_state() includeresources such as regulator, sync_state() can also be useful for complexresources like IOMMUs. For example, IOMMUs with multiple consumers (deviceswhose addresses are remapped by the IOMMU) might need to keep their mappingsfixed at (or additive to) the boot configuration until all its consumers haveprobed.

Agfeo Isdn Usb Plug Driver Vga

Agfeo isdn usb plug driver adapter

While the typical use case for sync_state() is to have the kernel cleanly takeover management of devices from the bootloader, the usage of sync_state() isnot restricted to that. Use it whenever it makes sense to take an action afterall the consumers of a device have probed.

int (*remove) (struct device *dev);

remove is called to unbind a driver from a device. This may becalled if a device is physically removed from the system, if thedriver module is being unloaded, during a reboot sequence, orin other cases.

It is up to the driver to determine if the device is present ornot. It should free any resources allocated specifically for thedevice; i.e. anything in the device’s driver_data field.

If the device is still present, it should quiesce the device and placeit into a supported low-power state:

suspend is called to put the device in a low power state:

Resume is used to bring a device back from a low power state.

Agfeo Isdn Usb Plug Driver Adapter


Device drivers can export attributes via their sysfs directories.Drivers can declare attributes using a DRIVER_ATTR_RW and DRIVER_ATTR_ROmacro that works identically to the DEVICE_ATTR_RW and DEVICE_ATTR_ROmacros.


This is equivalent to declaring:

This can then be used to add and remove the attribute from thedriver’s directory using:

Coments are closed
Scroll to top