I try to read from a usb device through usb4java api but I get an error: USB error 5: Unable to read data: Entity not found can anybody help me? It has to be noted that the endpoint_in i get it from LibUsb.ENDPOINT_IN and i pass it to the read funtion The device is found is claimed but I cannot move forward to read from the device.
My code is given below:
import java.io.IOException;
import java.io.PipedInputStream;
import java.io.PipedOutputStream;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.IntBuffer;
import javax.swing.JOptionPane;
import org.usb4java.BufferUtils;
import org.usb4java.Context;
import org.usb4java.Device;
import org.usb4java.DeviceDescriptor;
import org.usb4java.DeviceHandle;
import org.usb4java.DeviceList;
import org.usb4java.LibUsb;
import org.usb4java.LibUsbException;
public class Test {
 private static byte endpoint;
   // private static final byte IN_ENDPOINT = 0;
private static Device device;
private static   Context context = new Context();
private static DeviceHandle handle;
    public static void main(String[] args) {
        // Create the libusb context
    LibUsb.init(null);
        findDevice(context, (short) (0x046D), (short) (0xC016));
        // Deinitialize the libusb context
        LibUsb.exit(context);
    }
    public static void findDevice(Context context, short vendorId, short productId) {
        // Initialize the libusb context
        int result = LibUsb.init(context);
        if (result < 0) {
            throw new LibUsbException("Unable to initialize libusb", result);
        }
        // Read the USB device list
        DeviceList list = new DeviceList();
        result = LibUsb.getDeviceList(context, list);
        if (result < 0) {
            throw new LibUsbException("Unable to get device list", result);
        }
        try {
            // Iterate over all devices and list them
            for (Device device : list) {
                int address = LibUsb.getDeviceAddress(device);
                int busNumber = LibUsb.getBusNumber(device);
                DeviceDescriptor descriptor = new DeviceDescriptor();
                result = LibUsb.getDeviceDescriptor(device, descriptor);
                if (result < 0) {
                    throw new LibUsbException(
                            "Unable to read device descriptor", result);
                }
                System.out.format(
                        "Bus %03d, Device %03d: Vendor %04x, Product %04x%n",
                        busNumber, address, descriptor.idVendor(),
                        descriptor.idProduct());
                if (result != LibUsb.SUCCESS) {
                    throw new LibUsbException("Unable to read device descriptor", result);
                }
                if (descriptor.idVendor() == vendorId && descriptor.idProduct() == productId) {
                    System.out.println("Device Found");
                    getDeviceHandle(device);
                    LibUsb.claimInterface(handle, 0);
                }
            }
        } finally {
            // Ensure the allocated device list is freed
            LibUsb.freeDeviceList(list, true);
        }
    }
    public static void getDeviceHandle(Device device) {
         endpoint = (byte)LibUsb.getDeviceAddress(device);
          handle = new DeviceHandle();
          JOptionPane.showMessageDialog(null, "endpoint="+endpoint);
        int result = LibUsb.open(device, handle);
        if (result != LibUsb.SUCCESS) {
            throw new LibUsbException("Unable to open USB device", result);
        }
        try {
            // Use device handle here
            claimDevice(handle, 0);
        } finally {
            LibUsb.close(handle);
        }
    }
    public static void claimDevice(DeviceHandle handle, int interfaceNumber) {
        int result = LibUsb.claimInterface(handle, interfaceNumber);
        if (result != LibUsb.SUCCESS) {
            throw new LibUsbException("Unable to claim interface", result);
        }
        try {
            System.out.println("Device Claimed");
            //sendData(handle);
           // read(handle,1000);
            JOptionPane.showMessageDialog(null, "interface="+interfaceNumber);
           read(handle, 2048);
        } finally {
            result = LibUsb.releaseInterface(handle, interfaceNumber);
            if (result != LibUsb.SUCCESS) {
                throw new LibUsbException("Unable to release interface", result);
            }
        }
    }
    @SuppressWarnings("unused")
    public static void sendData(DeviceHandle handle) {
    char[] initEP = new char[]{0x1b, '@'};
    char[] cutPaper = new char[]{0x1d, 'V', 1};
      String initStr = new String(initEP);
      String cutStr = new String(cutPaper);
        String text = "blabla \n\n\n";
        ByteBuffer buffer = ByteBuffer.allocateDirect(8);
        buffer.put(new byte[] { 1, 2, 3, 4, 5, 6, 7, 8 });
        // SEND INIT BYTE
       int transfered = LibUsb.controlTransfer(handle,
             (byte) (LibUsb.REQUEST_TYPE_CLASS | LibUsb.RECIPIENT_INTERFACE),
             (byte) 0x01, (short) 2, (short) 1, buffer, 5000);
     if (transfered < 0) {
           throw new LibUsbException("Control transfer failed", transfered);
        }
        // SENDT TEXT
        buffer = ByteBuffer.wrap(text.getBytes());
       transfered = LibUsb.controlTransfer(handle,
                (byte) (LibUsb.REQUEST_TYPE_CLASS | LibUsb.RECIPIENT_INTERFACE),
                (byte) 0x01, (short) 2, (short) 1, buffer, 5000);
        if (transfered < 0) {
            throw new LibUsbException("Control transfer failed", transfered);
        }
      /*  // SENDT CUT BYTE
        buffer = ByteBuffer.wrap(text.getBytes());
        transfered = LibUsb.controlTransfer(handle,
                (byte) (LibUsb.REQUEST_TYPE_CLASS | LibUsb.RECIPIENT_INTERFACE),
                (byte) 0x09, (short) 2, (short) 1, buffer, 5000);
        if (transfered < 0) {
            throw new LibUsbException("Control transfer failed", transfered);
        } */
        System.out.println(transfered + " bytes sent");
    }
    public static ByteBuffer read(DeviceHandle handle, int size)
    {
         ByteBuffer buffer = BufferUtils.allocateByteBuffer(size).order(ByteOrder.LITTLE_ENDIAN);
         IntBuffer transferred = BufferUtils.allocateIntBuffer();
       // IntBuffer transferred = BufferUtils.allocateIntBuffer();
        long TIMEOUT = 5000;
        JOptionPane.showMessageDialog(null, "endpoint_in="+ LibUsb.ENDPOINT_IN);
        JOptionPane.showMessageDialog(null, "endpoint_out="+ LibUsb.ENDPOINT_OUT);
        JOptionPane.showMessageDialog(null, "handle="+handle);
        int result = LibUsb.bulkTransfer(handle, (byte)-128, buffer,
            transferred, TIMEOUT);
        JOptionPane.showMessageDialog(null, result);
        if (result != LibUsb.SUCCESS)
        {
            throw new LibUsbException("Unable to read data", result);
        }
        else{System.out.println(transferred.get() + " bytes read from device");
        }
        return buffer;
         }
}
The device is an usb mouse is that the problem?
In order to write i use this code (the write function that I call in my main function):
public static ByteBuffer write(DeviceHandle handle, int size) { ByteBuffer buffer = ByteBuffer.allocateDirect(8); buffer.put(new byte[] { 'p' });
    String text="p";
    //ByteBuffer buffer = ByteBuffer.wrap(text.getBytes());
    IntBuffer transferred = BufferUtils.allocateIntBuffer();
    long TIMEOUT = 5000;
    int result = LibUsb.bulkTransfer(handle, (byte) 0x01, buffer,
            transferred, TIMEOUT);
    if (result != LibUsb.SUCCESS)
    {
        throw new LibUsbException("Unable to write data", result);
    }
    else{System.out.println(transferred.get() + " bytes written to the device");
    }
    return buffer;
}
but I get USB error 5: Unable to write data: Entity not found
Why the entity is not found since I use endpoint 0x01...
URL: https://sourceforge.net/projects/libusbk/
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With