Some side tracking fixing undefined behaviour and memory vulnurabilities
This commit is contained in:
@@ -27,12 +27,13 @@
|
||||
#include "libusbwrap/interface/IUsbDevice.hpp"
|
||||
|
||||
namespace libusbwrap {
|
||||
UsbDevice::UsbDevice(libusb_context* ctx, libusb_device* dev) : mLibusbCtx(ctx), mLibusbDev(dev) {
|
||||
UsbDevice::UsbDevice(libusb_context* ctx, usbDevice_ptr dev)
|
||||
: mLibusbCtx(ctx), mLibusbDev(std::move(dev)) {
|
||||
if (mLibusbCtx == nullptr || mLibusbDev == nullptr) {
|
||||
throw std::invalid_argument("ctx or device are nullptr");
|
||||
}
|
||||
|
||||
libusb_get_device_descriptor(dev, &mLibusbDevDesc);
|
||||
libusb_get_device_descriptor(mLibusbDev.get(), &mLibusbDevDesc);
|
||||
}
|
||||
|
||||
UsbDevice::~UsbDevice() {
|
||||
@@ -44,7 +45,7 @@ UsbDevice::~UsbDevice() {
|
||||
}
|
||||
|
||||
bool UsbDevice::open() {
|
||||
int openStatus = libusb_open(mLibusbDev, &mLibusbDevHandle);
|
||||
int openStatus = libusb_open(mLibusbDev.get(), &mLibusbDevHandle);
|
||||
if (openStatus != 0) {
|
||||
mLastError = static_cast<Error>(openStatus);
|
||||
return false;
|
||||
@@ -109,15 +110,15 @@ const usbId UsbDevice::getUsbId() {
|
||||
}
|
||||
|
||||
const device::Speed UsbDevice::getSpeed() {
|
||||
return static_cast<device::Speed>(libusb_get_device_speed(mLibusbDev));
|
||||
return static_cast<device::Speed>(libusb_get_device_speed(mLibusbDev.get()));
|
||||
}
|
||||
|
||||
const uint8_t UsbDevice::getBusNumber() {
|
||||
return libusb_get_bus_number(mLibusbDev);
|
||||
return libusb_get_bus_number(mLibusbDev.get());
|
||||
}
|
||||
|
||||
const uint8_t UsbDevice::getPortNumber() {
|
||||
return libusb_get_port_number(mLibusbDev);
|
||||
return libusb_get_port_number(mLibusbDev.get());
|
||||
}
|
||||
|
||||
const Error UsbDevice::getLastError() {
|
||||
|
||||
Reference in New Issue
Block a user