-
Notifications
You must be signed in to change notification settings - Fork 50
/
knowndrives.h
74 lines (59 loc) · 2.25 KB
/
knowndrives.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
/*
* knowndrives.h
*
* Home page of code is: https://www.smartmontools.org
*
* Copyright (C) 2003-11 Philip Williams, Bruce Allen
* Copyright (C) 2008-21 Christian Franke
*
* SPDX-License-Identifier: GPL-2.0-or-later
*/
#ifndef KNOWNDRIVES_H_
#define KNOWNDRIVES_H_
#define KNOWNDRIVES_H_CVSID "$Id$\n"
// Structure to store drive database entries, see drivedb.h for a description.
struct drive_settings {
const char * modelfamily;
const char * modelregexp;
const char * firmwareregexp;
const char * warningmsg;
const char * presets;
};
// info returned by lookup_usb_device()
struct usb_dev_info
{
std::string usb_device; // Device name, empty if unknown
std::string usb_bridge; // USB bridge name, empty if unknown
std::string usb_type; // Type string ('-d' option).
};
// Search drivedb for USB device with vendor:product ID.
int lookup_usb_device(int vendor_id, int product_id, int bcd_device,
usb_dev_info & info, usb_dev_info & info2);
// Shows the presets (if any) that are available for the given drive.
void show_presets(const ata_identify_device * drive);
// Shows all presets for drives in knowndrives[].
// Returns #syntax errors.
int showallpresets();
// Shows all matching presets for a drive in knowndrives[].
// Returns # matching entries.
int showmatchingpresets(const char *model, const char *firmware);
// Searches drive database and sets preset vendor attribute
// options in defs and firmwarebugs.
// Values that have already been set will not be changed.
// Returns pointer to database entry or nullptr if none found.
const drive_settings * lookup_drive_apply_presets(
const ata_identify_device * drive, ata_vendor_attr_defs & defs,
firmwarebug_defs & firmwarebugs, std::string & dbversion);
// Get path for additional database file
const char * get_drivedb_path_add();
#ifdef SMARTMONTOOLS_DRIVEDBDIR
// Get path for default database file
const char * get_drivedb_path_default();
#endif
// Read drive database from file.
bool read_drive_database(const char * path);
// Init default db entry and optionally read drive databases from standard places.
bool init_drive_database(bool use_default_db);
// Get vendor attribute options from default db entry.
const ata_vendor_attr_defs & get_default_attr_defs();
#endif