mirror of
https://github.com/aaru-dps/aaruremote.git
synced 2025-12-16 19:24:37 +00:00
171 lines
4.6 KiB
C
171 lines
4.6 KiB
C
|
|
/*
|
||
|
|
* This file is part of the DiscImageChef Remote Server.
|
||
|
|
* Copyright (c) 2019 Natalia Portillo.
|
||
|
|
*
|
||
|
|
* This program is free software: you can redistribute it and/or modify
|
||
|
|
* it under the terms of the GNU General Public License as published by
|
||
|
|
* the Free Software Foundation, version 3.
|
||
|
|
*
|
||
|
|
* This program is distributed in the hope that it will be useful, but
|
||
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
|
* General Public License for more details.
|
||
|
|
*
|
||
|
|
* You should have received a copy of the GNU General Public License
|
||
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||
|
|
*/
|
||
|
|
|
||
|
|
#include "linux.h"
|
||
|
|
|
||
|
|
#include <stdint.h>
|
||
|
|
#include <stdio.h>
|
||
|
|
#include <string.h>
|
||
|
|
#include <sys/stat.h>
|
||
|
|
#include <unistd.h>
|
||
|
|
|
||
|
|
uint8_t linux_get_usb_data(const char* devicePath,
|
||
|
|
uint16_t* descLen,
|
||
|
|
char* descriptors,
|
||
|
|
uint16_t* idVendor,
|
||
|
|
uint16_t* idProduct,
|
||
|
|
char* manufacturer,
|
||
|
|
char* product,
|
||
|
|
char* serial)
|
||
|
|
{
|
||
|
|
char* devPath;
|
||
|
|
char tmpPath[4096];
|
||
|
|
char resolvedLink[4096];
|
||
|
|
struct stat sb;
|
||
|
|
ssize_t len;
|
||
|
|
char* rchr;
|
||
|
|
int found = 1;
|
||
|
|
FILE* file;
|
||
|
|
|
||
|
|
*descLen = 0;
|
||
|
|
*idVendor = 0;
|
||
|
|
*idProduct = 0;
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
memset(resolvedLink, 0, 4096);
|
||
|
|
|
||
|
|
if(strncmp(devicePath, "/dev/sd", 7) != 0 && strncmp(devicePath, "/dev/sr", 7) != 0 &&
|
||
|
|
strncmp(devicePath, "/dev/st", 7) != 0)
|
||
|
|
return 0;
|
||
|
|
|
||
|
|
devPath = (char*)devicePath + 5;
|
||
|
|
|
||
|
|
snprintf(tmpPath, 4096, "/sys/block/%s", devPath);
|
||
|
|
|
||
|
|
if(stat(tmpPath, &sb) != 0 || !S_ISDIR(sb.st_mode)) { return 0; }
|
||
|
|
|
||
|
|
len = readlink(tmpPath, resolvedLink, 4096);
|
||
|
|
|
||
|
|
if(len == 0) return 0;
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "/sys%s", resolvedLink + 2);
|
||
|
|
memcpy(resolvedLink, tmpPath, 4096);
|
||
|
|
|
||
|
|
while(strstr(resolvedLink, "usb") != NULL)
|
||
|
|
{
|
||
|
|
rchr = strrchr(resolvedLink, '/');
|
||
|
|
|
||
|
|
if(rchr == NULL) break;
|
||
|
|
|
||
|
|
*rchr = '\0';
|
||
|
|
|
||
|
|
if(strlen(resolvedLink) == 0) break;
|
||
|
|
|
||
|
|
snprintf(tmpPath, 4096, "%s/descriptors", resolvedLink);
|
||
|
|
if(access(tmpPath, R_OK) != 0) found = 0;
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
|
||
|
|
snprintf(tmpPath, 4096, "%s/idProduct", resolvedLink);
|
||
|
|
if(access(tmpPath, R_OK) != 0) found = 0;
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
|
||
|
|
snprintf(tmpPath, 4096, "%s/idVendor", resolvedLink);
|
||
|
|
if(access(tmpPath, R_OK) != 0) found = 0;
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
|
||
|
|
if(!found) continue;
|
||
|
|
|
||
|
|
snprintf(tmpPath, 4096, "%s/descriptors", resolvedLink);
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
|
||
|
|
if(file == NULL) break;
|
||
|
|
|
||
|
|
*descLen = (uint16_t)fread(descriptors, 4096, 1, file);
|
||
|
|
|
||
|
|
fclose(file);
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "%s/idProduct", resolvedLink);
|
||
|
|
|
||
|
|
if(access(tmpPath, R_OK) == 0)
|
||
|
|
{
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
if(file != NULL)
|
||
|
|
{
|
||
|
|
fscanf(file, "%4hx", idProduct);
|
||
|
|
fclose(file);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "%s/idVendor", resolvedLink);
|
||
|
|
|
||
|
|
if(access(tmpPath, R_OK) == 0)
|
||
|
|
{
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
if(file != NULL)
|
||
|
|
{
|
||
|
|
fscanf(file, "%4hx", idVendor);
|
||
|
|
fclose(file);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "%s/manufacturer", resolvedLink);
|
||
|
|
|
||
|
|
if(access(tmpPath, R_OK) == 0)
|
||
|
|
{
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
if(file != NULL)
|
||
|
|
{
|
||
|
|
fread(manufacturer, 256, 1, file);
|
||
|
|
fclose(file);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "%s/product", resolvedLink);
|
||
|
|
|
||
|
|
if(access(tmpPath, R_OK) == 0)
|
||
|
|
{
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
if(file != NULL)
|
||
|
|
{
|
||
|
|
fread(product, 256, 1, file);
|
||
|
|
fclose(file);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
memset(tmpPath, 0, 4096);
|
||
|
|
snprintf(tmpPath, 4096, "%s/serial", resolvedLink);
|
||
|
|
|
||
|
|
if(access(tmpPath, R_OK) == 0)
|
||
|
|
{
|
||
|
|
file = fopen(tmpPath, "r");
|
||
|
|
if(file != NULL)
|
||
|
|
{
|
||
|
|
fread(serial, 256, 1, file);
|
||
|
|
fclose(file);
|
||
|
|
}
|
||
|
|
}
|
||
|
|
|
||
|
|
break;
|
||
|
|
}
|
||
|
|
|
||
|
|
return descLen != 0;
|
||
|
|
}
|