Lines Matching refs:smbus_cmi
86 struct acpi_smbus_cmi *smbus_cmi = adap->algo_data; in acpi_smbus_cmi_access() local
164 method = smbus_cmi->methods->mt_sbr; in acpi_smbus_cmi_access()
168 method = smbus_cmi->methods->mt_sbw; in acpi_smbus_cmi_access()
180 status = acpi_evaluate_object(smbus_cmi->handle, method, &input, in acpi_smbus_cmi_access()
183 acpi_handle_err(smbus_cmi->handle, in acpi_smbus_cmi_access()
192 acpi_handle_err(smbus_cmi->handle, "Invalid argument type\n"); in acpi_smbus_cmi_access()
197 acpi_handle_err(smbus_cmi->handle, "Invalid argument type\n"); in acpi_smbus_cmi_access()
203 acpi_handle_debug(smbus_cmi->handle, "%s return status: %i\n", method, in acpi_smbus_cmi_access()
229 acpi_handle_err(smbus_cmi->handle, "Invalid argument type\n"); in acpi_smbus_cmi_access()
241 acpi_handle_err(smbus_cmi->handle, in acpi_smbus_cmi_access()
253 acpi_handle_err(smbus_cmi->handle, in acpi_smbus_cmi_access()
273 struct acpi_smbus_cmi *smbus_cmi = adapter->algo_data; in acpi_smbus_cmi_func() local
276 ret = smbus_cmi->cap_read | smbus_cmi->cap_write ? in acpi_smbus_cmi_func()
279 ret |= smbus_cmi->cap_read ? in acpi_smbus_cmi_func()
285 ret |= smbus_cmi->cap_write ? in acpi_smbus_cmi_func()
300 static int acpi_smbus_cmi_add_cap(struct acpi_smbus_cmi *smbus_cmi, in acpi_smbus_cmi_add_cap() argument
304 struct acpi_handle *handle = smbus_cmi->handle; in acpi_smbus_cmi_add_cap()
308 if (!strcmp(name, smbus_cmi->methods->mt_info)) { in acpi_smbus_cmi_add_cap()
309 status = acpi_evaluate_object(smbus_cmi->handle, in acpi_smbus_cmi_add_cap()
310 smbus_cmi->methods->mt_info, in acpi_smbus_cmi_add_cap()
314 smbus_cmi->methods->mt_info, status); in acpi_smbus_cmi_add_cap()
336 smbus_cmi->cap_info = 1; in acpi_smbus_cmi_add_cap()
337 } else if (!strcmp(name, smbus_cmi->methods->mt_sbr)) in acpi_smbus_cmi_add_cap()
338 smbus_cmi->cap_read = 1; in acpi_smbus_cmi_add_cap()
339 else if (!strcmp(name, smbus_cmi->methods->mt_sbw)) in acpi_smbus_cmi_add_cap()
340 smbus_cmi->cap_write = 1; in acpi_smbus_cmi_add_cap()
352 struct acpi_smbus_cmi *smbus_cmi = context; in acpi_smbus_cmi_query_methods() local
358 acpi_smbus_cmi_add_cap(smbus_cmi, node_name); in acpi_smbus_cmi_query_methods()
365 struct acpi_smbus_cmi *smbus_cmi; in acpi_smbus_cmi_add() local
369 smbus_cmi = kzalloc(sizeof(struct acpi_smbus_cmi), GFP_KERNEL); in acpi_smbus_cmi_add()
370 if (!smbus_cmi) in acpi_smbus_cmi_add()
373 smbus_cmi->handle = device->handle; in acpi_smbus_cmi_add()
376 device->driver_data = smbus_cmi; in acpi_smbus_cmi_add()
377 smbus_cmi->cap_info = 0; in acpi_smbus_cmi_add()
378 smbus_cmi->cap_read = 0; in acpi_smbus_cmi_add()
379 smbus_cmi->cap_write = 0; in acpi_smbus_cmi_add()
383 smbus_cmi->methods = in acpi_smbus_cmi_add()
386 acpi_walk_namespace(ACPI_TYPE_METHOD, smbus_cmi->handle, 1, in acpi_smbus_cmi_add()
387 acpi_smbus_cmi_query_methods, NULL, smbus_cmi, NULL); in acpi_smbus_cmi_add()
389 if (smbus_cmi->cap_info == 0) { in acpi_smbus_cmi_add()
394 snprintf(smbus_cmi->adapter.name, sizeof(smbus_cmi->adapter.name), in acpi_smbus_cmi_add()
397 smbus_cmi->adapter.owner = THIS_MODULE; in acpi_smbus_cmi_add()
398 smbus_cmi->adapter.algo = &acpi_smbus_cmi_algorithm; in acpi_smbus_cmi_add()
399 smbus_cmi->adapter.algo_data = smbus_cmi; in acpi_smbus_cmi_add()
400 smbus_cmi->adapter.class = I2C_CLASS_HWMON | I2C_CLASS_SPD; in acpi_smbus_cmi_add()
401 smbus_cmi->adapter.dev.parent = &device->dev; in acpi_smbus_cmi_add()
403 ret = i2c_add_adapter(&smbus_cmi->adapter); in acpi_smbus_cmi_add()
412 kfree(smbus_cmi); in acpi_smbus_cmi_add()
419 struct acpi_smbus_cmi *smbus_cmi = acpi_driver_data(device); in acpi_smbus_cmi_remove() local
421 i2c_del_adapter(&smbus_cmi->adapter); in acpi_smbus_cmi_remove()
422 kfree(smbus_cmi); in acpi_smbus_cmi_remove()