On Mon, Jan 1, 2018 at 12:43 PM, Ognjen Galić <smclt30p@xxxxxxxxx> wrote: > On Mon, Jan 01, 2018 at 12:24:39PM +0200, Andy Shevchenko wrote: >> On Sun, Dec 31, 2017 at 4:17 PM, Ognjen Galic <smclt30p@xxxxxxxxx> wrote: >> > thinkpad_acpi registers two new attributes for each battery: >> > >> > 1) Charge start threshold >> > /sys/class/power_supply/BATN/charge_start_threshold >> > >> > Valid values are [0, 99]. A value of 0 turns off the >> > start threshold wear control. >> > >> > 2) Charge stop threshold >> > /sys/class/power_supply/BATN/charge_stop_threshold >> > >> > Valid values are [1, 100]. A value of 100 turns off >> > the stop threshold wear control. This must be >> > configured first. >> > >> >> > This patch depends on the following patches: >> > >> > "battery: Add the battery hooking API" >> >> Since this is series, no need to put above into changelog. >> >> AFAICS it's not going to be backported either. >> >> >> > +/** >> > + * This evaluates a ACPI method call specific to the battery >> > + * ACPI extension. The specifics are that an error is marked >> > + * in the 32rd bit of the response, so we just check that here. >> > + * >> > + * Returns 0 on success >> > + */ >> > +static int tpacpi_battery_acpi_eval(char *method, int *ret, int param) >> > +{ >> >> One problem and one trick you may do. >> >> A problem: you return ACPI status as int. We have special type for >> that. So, be consistent with it. >> Looking to acpi_evalf() which is private to the module, I think you >> need to get rid of ACPI return codes here. > > What do you mean by "get rid of ACPI return codes"? > Are you suggesting this? > > static void tpacpi_battery_ac.... I think that Andy was talking about returning things like AE_ERROR, which are of type acpi_status, as int. You should return either the Linux error codes (in which case int is the type to use) or ACPI error codes (in which the function should be defined to return acpi_status). Do not mix them. > How would I check if the ACPI call failed if I made the function return > void? > > I use a function return value to check if the ACPI call failed, > and a return integer pointer to which I write the return data to. > >> >> A trick: since you are using only least significant byte of the >> response, you can declare it as u8 *value (yeah, ret is not best name >> here I think). > > Neat trick. Little-endian only though. Don't do that unless your code is guaranteed to always (now and in the future) run on little-endian. Thanks, Rafael