ckb-next  beta-v0.2.8 at branch testing
ckb-next driver for corsair devices
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
profile.h File Reference
#include "includes.h"
#include "device.h"
+ Include dependency graph for profile.h:
+ This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define hwloadprofile(kb, apply)   (kb)->vtable->hwload(kb, 0, 0, apply, 0)
 

Functions

void allocprofile (usbdevice *kb)
 
int loadprofile (usbdevice *kb)
 
void freeprofile (usbdevice *kb)
 
void cmd_erase (usbdevice *kb, usbmode *mode, int dummy1, int dummy2, const char *dummy3)
 
void cmd_eraseprofile (usbdevice *kb, usbmode *dummy1, int dummy2, int dummy3, const char *dummy4)
 
void cmd_name (usbdevice *kb, usbmode *mode, int dummy1, int dummy2, const char *name)
 
void cmd_profilename (usbdevice *kb, usbmode *dummy1, int dummy2, int dummy3, const char *name)
 
char * getmodename (usbmode *mode)
 
char * getprofilename (usbprofile *profile)
 
char * gethwmodename (hwprofile *profile, int index)
 
char * gethwprofilename (hwprofile *profile)
 
int setid (usbid *id, const char *guid)
 
char * getid (usbid *id)
 
void hwtonative (usbprofile *profile, hwprofile *hw, int modecount)
 
void nativetohw (usbprofile *profile, hwprofile *hw, int modecount)
 
void cmd_id (usbdevice *kb, usbmode *mode, int dummy1, int dummy2, const char *id)
 
void cmd_profileid (usbdevice *kb, usbmode *mode, int dummy1, int dummy2, const char *id)
 
int cmd_hwload_kb (usbdevice *kb, usbmode *dummy1, int dummy2, int apply, const char *dummy3)
 
int cmd_hwload_mouse (usbdevice *kb, usbmode *dummy1, int dummy2, int apply, const char *dummy3)
 
int cmd_hwsave_kb (usbdevice *kb, usbmode *dummy1, int dummy2, int dummy3, const char *dummy4)
 
int cmd_hwsave_mouse (usbdevice *kb, usbmode *dummy1, int dummy2, int dummy3, const char *dummy4)
 

Macro Definition Documentation

#define hwloadprofile (   kb,
  apply 
)    (kb)->vtable->hwload(kb, 0, 0, apply, 0)

Definition at line 52 of file profile.h.

Referenced by _start_dev(), and loadprofile().

Function Documentation

void allocprofile ( usbdevice kb)

Definition at line 182 of file profile.c.

References usbprofile::currentmode, dpiset::forceupdate, lighting::forceupdate, initmode(), usbprofile::lastdpi, usbprofile::lastlight, usbprofile::mode, MODE_COUNT, and usbdevice::profile.

Referenced by cmd_eraseprofile().

182  {
183  if(kb->profile)
184  return;
185  usbprofile* profile = kb->profile = calloc(1, sizeof(usbprofile));
186  for(int i = 0; i < MODE_COUNT; i++)
187  initmode(profile->mode + i);
188  profile->currentmode = profile->mode;
189  profile->lastlight.forceupdate = profile->lastdpi.forceupdate = 1;
190 }
lighting lastlight
Definition: structures.h:107
#define MODE_COUNT
Definition: structures.h:100
usbprofile * profile
Definition: structures.h:221
usbmode * currentmode
Definition: structures.h:105
usbmode mode[6]
Definition: structures.h:103
dpiset lastdpi
Definition: structures.h:108
uchar forceupdate
Definition: structures.h:77
static void initmode(usbmode *mode)
Definition: profile.c:175
uchar forceupdate
Definition: structures.h:69

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void cmd_erase ( usbdevice kb,
usbmode mode,
int  dummy1,
int  dummy2,
const char *  dummy3 
)

Definition at line 203 of file profile.c.

References freemode(), imutex, and initmode().

203  {
204  pthread_mutex_lock(imutex(kb));
205  freemode(mode);
206  initmode(mode);
207  pthread_mutex_unlock(imutex(kb));
208 }
static void freemode(usbmode *mode)
Definition: profile.c:198
#define imutex(kb)
Definition: device.h:22
static void initmode(usbmode *mode)
Definition: profile.c:175

+ Here is the call graph for this function:

void cmd_eraseprofile ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  dummy3,
const char *  dummy4 
)

Definition at line 221 of file profile.c.

References _freeprofile(), allocprofile(), and imutex.

221  {
222  pthread_mutex_lock(imutex(kb));
223  _freeprofile(kb);
224  allocprofile(kb);
225  pthread_mutex_unlock(imutex(kb));
226 }
static void _freeprofile(usbdevice *kb)
Definition: profile.c:210
void allocprofile(usbdevice *kb)
Definition: profile.c:182
#define imutex(kb)
Definition: device.h:22

+ Here is the call graph for this function:

int cmd_hwload_kb ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  apply,
const char *  dummy3 
)

Definition at line 16 of file profile_keyboard.c.

References DELAY_LONG, usbdevice::hw, hwloadmode(), HWMODE_K70, HWMODE_K95, hwtonative(), hwprofile::id, IS_K95, MSG_SIZE, hwprofile::name, PR_NAME_LEN, usbdevice::profile, and usbrecv.

16  {
17  DELAY_LONG(kb);
18  hwprofile* hw = calloc(1, sizeof(hwprofile));
19  // Ask for profile and mode IDs
20  uchar data_pkt[2][MSG_SIZE] = {
21  { 0x0e, 0x15, 0x01, 0 },
22  { 0x0e, 0x16, 0x01, 0 }
23  };
24  uchar in_pkt[MSG_SIZE];
25  int modes = (IS_K95(kb) ? HWMODE_K95 : HWMODE_K70);
26  for(int i = 0; i <= modes; i++){
27  data_pkt[0][3] = i;
28  if(!usbrecv(kb, data_pkt[0], in_pkt)){
29  free(hw);
30  return -1;
31  }
32  memcpy(hw->id + i, in_pkt + 4, sizeof(usbid));
33  }
34  // Ask for profile name
35  if(!usbrecv(kb, data_pkt[1], in_pkt)){
36  free(hw);
37  return -1;
38  }
39  memcpy(hw->name[0], in_pkt + 4, PR_NAME_LEN * 2);
40  // Load modes
41  for(int i = 0; i < modes; i++){
42  if(hwloadmode(kb, hw, i)){
43  free(hw);
44  return -1;
45  }
46  }
47  // Make the profile active (if requested)
48  if(apply)
49  hwtonative(kb->profile, hw, modes);
50  // Free the existing profile (if any)
51  free(kb->hw);
52  kb->hw = hw;
53  DELAY_LONG(kb);
54  return 0;
55 }
#define HWMODE_K70
Definition: structures.h:115
#define MSG_SIZE
Definition: structures.h:176
usbprofile * profile
Definition: structures.h:221
#define DELAY_LONG(kb)
The longest delay takes place where something went wrong (eg when resetting the device) ...
Definition: usb.h:155
#define PR_NAME_LEN
Definition: structures.h:99
usbid id[3+1]
Definition: structures.h:123
unsigned char uchar
Definition: includes.h:24
void hwtonative(usbprofile *profile, hwprofile *hw, int modecount)
Definition: profile.c:235
static int hwloadmode(usbdevice *kb, hwprofile *hw, int mode)
#define HWMODE_K95
Definition: structures.h:116
hwprofile * hw
Definition: structures.h:223
ushort name[3+1][16]
Definition: structures.h:125
#define usbrecv(kb, out_msg, in_msg)
usbrecv macro is used to wrap _usbrecv() with debugging information (file and lineno) ...
Definition: usb.h:256
#define IS_K95(kb)
Definition: usb.h:71

+ Here is the call graph for this function:

int cmd_hwload_mouse ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  apply,
const char *  dummy3 
)

Definition at line 6 of file profile_mouse.c.

References DELAY_LONG, hwprofile::dpi, usbdevice::hw, hwtonative(), hwprofile::id, hwprofile::light, loaddpi(), loadrgb_mouse(), MSG_SIZE, hwprofile::name, PR_NAME_LEN, usbdevice::profile, and usbrecv.

6  {
7  DELAY_LONG(kb);
8  hwprofile* hw = calloc(1, sizeof(hwprofile));
9  // Ask for profile and mode IDs
10  uchar data_pkt[2][MSG_SIZE] = {
11  { 0x0e, 0x15, 0x01, 0 },
12  { 0x0e, 0x16, 0x01, 0 }
13  };
14  uchar in_pkt[MSG_SIZE];
15  for(int i = 0; i <= 1; i++){
16  data_pkt[0][3] = i;
17  if(!usbrecv(kb, data_pkt[0], in_pkt)){
18  free(hw);
19  return -1;
20  }
21  memcpy(hw->id + i, in_pkt + 4, sizeof(usbid));
22  }
23  // Ask for profile and mode names
24  for(int i = 0; i <= 1; i++){
25  data_pkt[1][3] = i;
26  if(!usbrecv(kb, data_pkt[1],in_pkt)){
27  free(hw);
28  return -1;
29  }
30  memcpy(hw->name[i], in_pkt + 4, PR_NAME_LEN * 2);
31  }
32 
33  // Load the RGB and DPI settings
34  if(loadrgb_mouse(kb, hw->light, 0)
35  || loaddpi(kb, hw->dpi, hw->light)){
36  free(hw);
37  return -1;
38  }
39 
40  // Make the profile active (if requested)
41  if(apply)
42  hwtonative(kb->profile, hw, 1);
43  // Free the existing profile (if any)
44  free(kb->hw);
45  kb->hw = hw;
46  DELAY_LONG(kb);
47  return 0;
48 }
#define MSG_SIZE
Definition: structures.h:176
usbprofile * profile
Definition: structures.h:221
int loadrgb_mouse(usbdevice *kb, lighting *light, int mode)
Definition: led_mouse.c:81
#define DELAY_LONG(kb)
The longest delay takes place where something went wrong (eg when resetting the device) ...
Definition: usb.h:155
#define PR_NAME_LEN
Definition: structures.h:99
usbid id[3+1]
Definition: structures.h:123
unsigned char uchar
Definition: includes.h:24
void hwtonative(usbprofile *profile, hwprofile *hw, int modecount)
Definition: profile.c:235
dpiset dpi[3]
Definition: structures.h:121
hwprofile * hw
Definition: structures.h:223
ushort name[3+1][16]
Definition: structures.h:125
#define usbrecv(kb, out_msg, in_msg)
usbrecv macro is used to wrap _usbrecv() with debugging information (file and lineno) ...
Definition: usb.h:256
lighting light[3]
Definition: structures.h:120
int loaddpi(usbdevice *kb, dpiset *dpi, lighting *light)
Definition: dpi.c:152

+ Here is the call graph for this function:

int cmd_hwsave_kb ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  dummy3,
const char *  dummy4 
)

Definition at line 57 of file profile_keyboard.c.

References DELAY_LONG, usbdevice::hw, HWMODE_K70, HWMODE_K95, hwprofile::id, IS_K95, hwprofile::light, MD_NAME_LEN, MSG_SIZE, hwprofile::name, nativetohw(), usbdevice::profile, savergb_kb(), and usbsend.

57  {
58  DELAY_LONG(kb);
59  hwprofile* hw = kb->hw;
60  if(!hw)
61  hw = kb->hw = calloc(1, sizeof(hwprofile));
62  int modes = (IS_K95(kb) ? HWMODE_K95 : HWMODE_K70);
63  nativetohw(kb->profile, hw, modes);
64  // Save the profile and mode names
65  uchar data_pkt[2][MSG_SIZE] = {
66  { 0x07, 0x16, 0x01, 0 },
67  { 0x07, 0x15, 0x01, 0 },
68  };
69  // Save the mode names
70  for(int i = 0; i <= modes; i++){
71  data_pkt[0][3] = i;
72  memcpy(data_pkt[0] + 4, hw->name[i], MD_NAME_LEN * 2);
73  if(!usbsend(kb, data_pkt[0], 1))
74  return -1;
75  }
76  // Save the IDs
77  for(int i = 0; i <= modes; i++){
78  data_pkt[1][3] = i;
79  memcpy(data_pkt[1] + 4, hw->id + i, sizeof(usbid));
80  if(!usbsend(kb, data_pkt[1], 1))
81  return -1;
82  }
83  // Save the RGB data
84  for(int i = 0; i < modes; i++){
85  if(savergb_kb(kb, hw->light + i, i))
86  return -1;
87  }
88  DELAY_LONG(kb);
89  return 0;
90 }
#define HWMODE_K70
Definition: structures.h:115
#define MSG_SIZE
Definition: structures.h:176
usbprofile * profile
Definition: structures.h:221
#define DELAY_LONG(kb)
The longest delay takes place where something went wrong (eg when resetting the device) ...
Definition: usb.h:155
#define MD_NAME_LEN
Definition: structures.h:82
usbid id[3+1]
Definition: structures.h:123
unsigned char uchar
Definition: includes.h:24
void nativetohw(usbprofile *profile, hwprofile *hw, int modecount)
Definition: profile.c:252
#define HWMODE_K95
Definition: structures.h:116
hwprofile * hw
Definition: structures.h:223
ushort name[3+1][16]
Definition: structures.h:125
int savergb_kb(usbdevice *kb, lighting *light, int mode)
Definition: led_keyboard.c:139
#define IS_K95(kb)
Definition: usb.h:71
#define usbsend(kb, messages, count)
usbsend macro is used to wrap _usbsend() with debugging information (file and lineno) ...
Definition: usb.h:239
lighting light[3]
Definition: structures.h:120

+ Here is the call graph for this function:

int cmd_hwsave_mouse ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  dummy3,
const char *  dummy4 
)

Definition at line 50 of file profile_mouse.c.

References DELAY_LONG, hwprofile::dpi, usbdevice::hw, hwprofile::id, hwprofile::light, MD_NAME_LEN, MSG_SIZE, hwprofile::name, nativetohw(), usbdevice::profile, savedpi(), savergb_mouse(), and usbsend.

50  {
51  DELAY_LONG(kb);
52  hwprofile* hw = kb->hw;
53  if(!hw)
54  hw = kb->hw = calloc(1, sizeof(hwprofile));
55  nativetohw(kb->profile, hw, 1);
56  // Save the profile and mode names
57  uchar data_pkt[2][MSG_SIZE] = {
58  { 0x07, 0x16, 0x01, 0 },
59  { 0x07, 0x15, 0x01, 0 },
60  };
61  for(int i = 0; i <= 1; i++){
62  data_pkt[0][3] = i;
63  memcpy(data_pkt[0] + 4, hw->name[i], MD_NAME_LEN * 2);
64  if(!usbsend(kb, data_pkt[0], 1))
65  return -1;
66  }
67  // Save the IDs
68  for(int i = 0; i <= 1; i++){
69  data_pkt[1][3] = i;
70  memcpy(data_pkt[1] + 4, hw->id + i, sizeof(usbid));
71  if(!usbsend(kb, data_pkt[1], 1))
72  return -1;
73  }
74  // Save the RGB data for the non-DPI zones
75  if(savergb_mouse(kb, hw->light, 0))
76  return -1;
77  // Save the DPI data (also saves RGB for those states)
78  if(savedpi(kb, hw->dpi, hw->light))
79  return -1;
80  DELAY_LONG(kb);
81  return 0;
82 }
int savergb_mouse(usbdevice *kb, lighting *light, int mode)
Definition: led_mouse.c:62
#define MSG_SIZE
Definition: structures.h:176
usbprofile * profile
Definition: structures.h:221
#define DELAY_LONG(kb)
The longest delay takes place where something went wrong (eg when resetting the device) ...
Definition: usb.h:155
int savedpi(usbdevice *kb, dpiset *dpi, lighting *light)
Definition: dpi.c:124
#define MD_NAME_LEN
Definition: structures.h:82
usbid id[3+1]
Definition: structures.h:123
unsigned char uchar
Definition: includes.h:24
dpiset dpi[3]
Definition: structures.h:121
void nativetohw(usbprofile *profile, hwprofile *hw, int modecount)
Definition: profile.c:252
hwprofile * hw
Definition: structures.h:223
ushort name[3+1][16]
Definition: structures.h:125
#define usbsend(kb, messages, count)
usbsend macro is used to wrap _usbsend() with debugging information (file and lineno) ...
Definition: usb.h:239
lighting light[3]
Definition: structures.h:120

+ Here is the call graph for this function:

void cmd_id ( usbdevice kb,
usbmode mode,
int  dummy1,
int  dummy2,
const char *  id 
)

Definition at line 160 of file profile.c.

References usbmode::id, usbid::modified, and setid().

160  {
161  // ID is either a GUID or an 8-digit hex number
162  int newmodified;
163  if(!setid(&mode->id, id) && sscanf(id, "%08x", &newmodified) == 1)
164  memcpy(mode->id.modified, &newmodified, sizeof(newmodified));
165 }
int setid(usbid *id, const char *guid)
Definition: profile.c:64
char modified[4]
Definition: structures.h:10
usbid id
Definition: structures.h:88

+ Here is the call graph for this function:

void cmd_name ( usbdevice kb,
usbmode mode,
int  dummy1,
int  dummy2,
const char *  name 
)

Definition at line 117 of file profile.c.

References MD_NAME_LEN, usbmode::name, u16enc(), and urldecode2().

117  {
118  char decoded[strlen(name) + 1];
119  urldecode2(decoded, name);
120  size_t srclen = strlen(decoded), dstlen = MD_NAME_LEN;
121  u16enc(decoded, mode->name, &srclen, &dstlen);
122 }
void u16enc(char *in, ushort *out, size_t *srclen, size_t *dstlen)
Definition: profile.c:97
ushort name[16]
Definition: structures.h:89
#define MD_NAME_LEN
Definition: structures.h:82
void urldecode2(char *dst, const char *src)
Definition: profile.c:8

+ Here is the call graph for this function:

void cmd_profileid ( usbdevice kb,
usbmode mode,
int  dummy1,
int  dummy2,
const char *  id 
)

Definition at line 167 of file profile.c.

References usbprofile::id, usbid::modified, usbdevice::profile, and setid().

167  {
168  usbprofile* profile = kb->profile;
169  int newmodified;
170  if(!setid(&profile->id, id) && sscanf(id, "%08x", &newmodified) == 1)
171  memcpy(profile->id.modified, &newmodified, sizeof(newmodified));
172 
173 }
usbprofile * profile
Definition: structures.h:221
int setid(usbid *id, const char *guid)
Definition: profile.c:64
char modified[4]
Definition: structures.h:10
usbid id
Definition: structures.h:111

+ Here is the call graph for this function:

void cmd_profilename ( usbdevice kb,
usbmode dummy1,
int  dummy2,
int  dummy3,
const char *  name 
)

Definition at line 124 of file profile.c.

References usbprofile::name, PR_NAME_LEN, usbdevice::profile, u16enc(), and urldecode2().

124  {
125  usbprofile* profile = kb->profile;
126  char decoded[strlen(name) + 1];
127  urldecode2(decoded, name);
128  size_t srclen = strlen(decoded), dstlen = PR_NAME_LEN;
129  u16enc(decoded, profile->name, &srclen, &dstlen);
130 }
usbprofile * profile
Definition: structures.h:221
void u16enc(char *in, ushort *out, size_t *srclen, size_t *dstlen)
Definition: profile.c:97
#define PR_NAME_LEN
Definition: structures.h:99
ushort name[16]
Definition: structures.h:110
void urldecode2(char *dst, const char *src)
Definition: profile.c:8

+ Here is the call graph for this function:

void freeprofile ( usbdevice kb)

Definition at line 228 of file profile.c.

References _freeprofile(), and usbdevice::hw.

228  {
229  _freeprofile(kb);
230  // Also free HW profile
231  free(kb->hw);
232  kb->hw = 0;
233 }
static void _freeprofile(usbdevice *kb)
Definition: profile.c:210
hwprofile * hw
Definition: structures.h:223

+ Here is the call graph for this function:

char* gethwmodename ( hwprofile profile,
int  index 
)

Definition at line 152 of file profile.c.

References MD_NAME_LEN, hwprofile::name, and printname().

Referenced by _cmd_get().

152  {
153  return printname(profile->name[index + 1], MD_NAME_LEN);
154 }
#define MD_NAME_LEN
Definition: structures.h:82
ushort name[3+1][16]
Definition: structures.h:125
char * printname(ushort *name, int length)
Definition: profile.c:132

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

char* gethwprofilename ( hwprofile profile)

Definition at line 156 of file profile.c.

References MD_NAME_LEN, hwprofile::name, and printname().

Referenced by _cmd_get().

156  {
157  return printname(profile->name[0], MD_NAME_LEN);
158 }
#define MD_NAME_LEN
Definition: structures.h:82
ushort name[3+1][16]
Definition: structures.h:125
char * printname(ushort *name, int length)
Definition: profile.c:132

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

char* getid ( usbid id)

Definition at line 79 of file profile.c.

References usbid::guid.

Referenced by _cmd_get().

79  {
80  int32_t data1;
81  int16_t data2, data3, data4a;
82  char data4b[6];
83  memcpy(&data1, id->guid + 0x0, 4);
84  memcpy(&data2, id->guid + 0x4, 2);
85  memcpy(&data3, id->guid + 0x6, 2);
86  memcpy(&data4a, id->guid + 0x8, 2);
87  memcpy(data4b, id->guid + 0xA, 6);
88  char* guid = malloc(39);
89  snprintf(guid, 39, "{%08X-%04hX-%04hX-%04hX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
90  data1, data2, data3, data4a, data4b[0], data4b[1], data4b[2], data4b[3], data4b[4], data4b[5]);
91  return guid;
92 }
char guid[16]
Definition: structures.h:9

+ Here is the caller graph for this function:

char* getmodename ( usbmode mode)

Definition at line 144 of file profile.c.

References MD_NAME_LEN, usbmode::name, and printname().

Referenced by _cmd_get().

144  {
145  return printname(mode->name, MD_NAME_LEN);
146 }
ushort name[16]
Definition: structures.h:89
#define MD_NAME_LEN
Definition: structures.h:82
char * printname(ushort *name, int length)
Definition: profile.c:132

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

char* getprofilename ( usbprofile profile)

Definition at line 148 of file profile.c.

References usbprofile::name, PR_NAME_LEN, and printname().

Referenced by _cmd_get().

148  {
149  return printname(profile->name, PR_NAME_LEN);
150 }
#define PR_NAME_LEN
Definition: structures.h:99
ushort name[16]
Definition: structures.h:110
char * printname(ushort *name, int length)
Definition: profile.c:132

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void hwtonative ( usbprofile profile,
hwprofile hw,
int  modecount 
)

Definition at line 235 of file profile.c.

References usbmode::dpi, hwprofile::dpi, dpiset::forceupdate, lighting::forceupdate, usbmode::id, usbprofile::id, hwprofile::id, usbprofile::lastdpi, usbprofile::lastlight, usbmode::light, hwprofile::light, MD_NAME_LEN, usbprofile::mode, usbmode::name, usbprofile::name, hwprofile::name, and PR_NAME_LEN.

Referenced by cmd_hwload_kb(), and cmd_hwload_mouse().

235  {
236  // Copy the profile name and ID
237  memcpy(profile->name, hw->name[0], PR_NAME_LEN * 2);
238  memcpy(&profile->id, hw->id, sizeof(usbid));
239  // Copy the mode settings
240  for(int i = 0; i < modecount; i++){
241  usbmode* mode = profile->mode + i;
242  memcpy(mode->name, hw->name[i + 1], MD_NAME_LEN * 2);
243  memcpy(&mode->id, hw->id + i + 1, sizeof(usbid));
244  memcpy(&mode->light, hw->light + i, sizeof(lighting));
245  memcpy(&mode->dpi, hw->dpi + i, sizeof(dpiset));
246  // Set a force update on the light/DPI since they've been overwritten
247  mode->light.forceupdate = mode->dpi.forceupdate = 1;
248  }
249  profile->lastlight.forceupdate = profile->lastdpi.forceupdate = 1;
250 }
lighting lastlight
Definition: structures.h:107
usbmode mode[6]
Definition: structures.h:103
ushort name[16]
Definition: structures.h:89
#define MD_NAME_LEN
Definition: structures.h:82
usbid id
Definition: structures.h:111
#define PR_NAME_LEN
Definition: structures.h:99
dpiset lastdpi
Definition: structures.h:108
lighting light
Definition: structures.h:84
usbid id[3+1]
Definition: structures.h:123
dpiset dpi
Definition: structures.h:86
ushort name[16]
Definition: structures.h:110
uchar forceupdate
Definition: structures.h:77
dpiset dpi[3]
Definition: structures.h:121
ushort name[3+1][16]
Definition: structures.h:125
lighting light[3]
Definition: structures.h:120
uchar forceupdate
Definition: structures.h:69
usbid id
Definition: structures.h:88

+ Here is the caller graph for this function:

int loadprofile ( usbdevice kb)

Definition at line 192 of file profile.c.

References hwloadprofile.

192  {
193  if(hwloadprofile(kb, 1))
194  return -1;
195  return 0;
196 }
#define hwloadprofile(kb, apply)
Definition: profile.h:52
void nativetohw ( usbprofile profile,
hwprofile hw,
int  modecount 
)

Definition at line 252 of file profile.c.

References usbmode::dpi, hwprofile::dpi, usbmode::id, usbprofile::id, hwprofile::id, usbmode::light, hwprofile::light, MD_NAME_LEN, usbprofile::mode, usbmode::name, usbprofile::name, hwprofile::name, and PR_NAME_LEN.

Referenced by cmd_hwsave_kb(), and cmd_hwsave_mouse().

252  {
253  // Copy name and ID
254  memcpy(hw->name[0], profile->name, PR_NAME_LEN * 2);
255  memcpy(hw->id, &profile->id, sizeof(usbid));
256  // Copy the mode settings
257  for(int i = 0; i < modecount; i++){
258  usbmode* mode = profile->mode + i;
259  memcpy(hw->name[i + 1], mode->name, MD_NAME_LEN * 2);
260  memcpy(hw->id + i + 1, &mode->id, sizeof(usbid));
261  memcpy(hw->light + i, &mode->light, sizeof(lighting));
262  memcpy(hw->dpi + i, &mode->dpi, sizeof(dpiset));
263  }
264 }
usbmode mode[6]
Definition: structures.h:103
ushort name[16]
Definition: structures.h:89
#define MD_NAME_LEN
Definition: structures.h:82
usbid id
Definition: structures.h:111
#define PR_NAME_LEN
Definition: structures.h:99
lighting light
Definition: structures.h:84
usbid id[3+1]
Definition: structures.h:123
dpiset dpi
Definition: structures.h:86
ushort name[16]
Definition: structures.h:110
dpiset dpi[3]
Definition: structures.h:121
ushort name[3+1][16]
Definition: structures.h:125
lighting light[3]
Definition: structures.h:120
usbid id
Definition: structures.h:88

+ Here is the caller graph for this function:

int setid ( usbid id,
const char *  guid 
)

Definition at line 64 of file profile.c.

References usbid::guid.

Referenced by cmd_id(), and cmd_profileid().

64  {
65  int32_t data1;
66  int16_t data2, data3, data4a;
67  char data4b[6];
68  if(sscanf(guid, "{%08X-%04hX-%04hX-%04hX-%02hhX%02hhX%02hhX%02hhX%02hhX%02hhX}",
69  &data1, &data2, &data3, &data4a, data4b, data4b + 1, data4b + 2, data4b + 3, data4b + 4, data4b + 5) != 10)
70  return 0;
71  memcpy(id->guid + 0x0, &data1, 4);
72  memcpy(id->guid + 0x4, &data2, 2);
73  memcpy(id->guid + 0x6, &data3, 2);
74  memcpy(id->guid + 0x8, &data4a, 2);
75  memcpy(id->guid + 0xA, data4b, 6);
76  return 1;
77 }
char guid[16]
Definition: structures.h:9

+ Here is the caller graph for this function: