Lines Matching refs:handle

133 static acpi_status acpi_bus_offline(acpi_handle handle, u32 lvl, void *data,  in acpi_bus_offline()  argument
136 struct acpi_device *device = acpi_fetch_acpi_dev(handle); in acpi_bus_offline()
178 static acpi_status acpi_bus_online(acpi_handle handle, u32 lvl, void *data, in acpi_bus_online() argument
181 struct acpi_device *device = acpi_fetch_acpi_dev(handle); in acpi_bus_online()
202 acpi_handle handle = device->handle; in acpi_scan_try_to_offline() local
215 status = acpi_walk_namespace(ACPI_TYPE_ANY, handle, ACPI_UINT32_MAX, in acpi_scan_try_to_offline()
220 acpi_walk_namespace(ACPI_TYPE_ANY, handle, ACPI_UINT32_MAX, in acpi_scan_try_to_offline()
224 acpi_bus_offline(handle, 0, (void *)false, (void **)&errdev); in acpi_scan_try_to_offline()
227 acpi_walk_namespace(ACPI_TYPE_ANY, handle, ACPI_UINT32_MAX, in acpi_scan_try_to_offline()
231 acpi_bus_offline(handle, 0, (void *)true, in acpi_scan_try_to_offline()
236 acpi_bus_online(handle, 0, NULL, NULL); in acpi_scan_try_to_offline()
237 acpi_walk_namespace(ACPI_TYPE_ANY, handle, in acpi_scan_try_to_offline()
321 acpi_handle handle = device->handle; in acpi_scan_hot_remove() local
335 acpi_handle_debug(handle, "Ejecting\n"); in acpi_scan_hot_remove()
339 acpi_evaluate_lck(handle, 0); in acpi_scan_hot_remove()
343 status = acpi_evaluate_ej0(handle); in acpi_scan_hot_remove()
353 status = acpi_evaluate_integer(handle, "_STA", NULL, &sta); in acpi_scan_hot_remove()
355 acpi_handle_warn(handle, in acpi_scan_hot_remove()
358 acpi_handle_warn(handle, in acpi_scan_hot_remove()
375 ret = acpi_bus_scan(adev->handle); in acpi_scan_rescan_bus()
431 acpi_evaluate_ost(adev->handle, ACPI_NOTIFY_EJECT_REQUEST, in acpi_generic_hotplug_event()
451 if (adev->handle == INVALID_ACPI_HANDLE) in acpi_device_hotplug()
489 acpi_evaluate_ost(adev->handle, src, ost_code, NULL); in acpi_device_hotplug()
602 static void acpi_scan_drop_device(acpi_handle handle, void *context) in acpi_scan_drop_device() argument
624 adev->handle = INVALID_ACPI_HANDLE; in acpi_scan_drop_device()
629 static struct acpi_device *handle_to_device(acpi_handle handle, in handle_to_device() argument
635 status = acpi_get_data_full(handle, acpi_scan_drop_device, in handle_to_device()
638 acpi_handle_debug(handle, "No context!\n"); in handle_to_device()
651 struct acpi_device *acpi_fetch_acpi_dev(acpi_handle handle) in acpi_fetch_acpi_dev() argument
653 return handle_to_device(handle, NULL); in acpi_fetch_acpi_dev()
673 struct acpi_device *acpi_get_acpi_dev(acpi_handle handle) in acpi_get_acpi_dev() argument
675 return handle_to_device(handle, get_acpi_device); in acpi_get_acpi_dev()
708 acpi_handle handle = adev->handle; in acpi_tie_acpi_dev() local
711 if (!handle) in acpi_tie_acpi_dev()
714 status = acpi_attach_data(handle, acpi_scan_drop_device, adev); in acpi_tie_acpi_dev()
716 acpi_handle_err(handle, "Unable to attach device data\n"); in acpi_tie_acpi_dev()
727 if (!acpi_get_physical_device_location(adev->handle, &pld)) in acpi_store_pld_crc()
808 acpi_detach_data(device->handle, acpi_scan_drop_device); in acpi_device_add()
865 static struct acpi_device *acpi_find_parent_acpi_dev(acpi_handle handle) in acpi_find_parent_acpi_dev() argument
874 if (!handle) in acpi_find_parent_acpi_dev()
880 status = acpi_get_parent(handle, &handle); in acpi_find_parent_acpi_dev()
887 adev = acpi_fetch_acpi_dev(handle); in acpi_find_parent_acpi_dev()
893 acpi_bus_get_ejd(acpi_handle handle, acpi_handle *ejd) in acpi_bus_get_ejd() argument
900 status = acpi_get_handle(handle, "_EJD", &tmp); in acpi_bus_get_ejd()
904 status = acpi_evaluate_object(handle, "_EJD", NULL, &buffer); in acpi_bus_get_ejd()
917 acpi_handle handle = dev->handle; in acpi_bus_extract_wakeup_device_power_package() local
928 status = acpi_evaluate_object(handle, "_PRW", NULL, &buffer); in acpi_bus_extract_wakeup_device_power_package()
930 acpi_handle_info(handle, "_PRW evaluation failed: %s\n", in acpi_bus_extract_wakeup_device_power_package()
952 element->package.elements[0].reference.handle; in acpi_bus_extract_wakeup_device_power_package()
978 acpi_handle_warn(handle, "Retrieving current states " in acpi_bus_extract_wakeup_device_power_package()
984 acpi_handle_warn(handle, "Overriding _PRW sleep state " in acpi_bus_extract_wakeup_device_power_package()
1024 status = acpi_setup_gpe_for_wake(device->handle, wakeup->gpe_device, in acpi_wakeup_gpe_init()
1034 if (!acpi_has_method(device->handle, "_PRW")) in acpi_bus_get_wakeup_device_flags()
1067 status = acpi_evaluate_object(device->handle, pathname, NULL, &buffer); in acpi_bus_init_power_state()
1081 if (acpi_has_method(device->handle, pathname)) in acpi_bus_init_power_state()
1098 if (!acpi_has_method(device->handle, "_PS0") && in acpi_bus_get_power_flags()
1099 !acpi_has_method(device->handle, "_PR0")) in acpi_bus_get_power_flags()
1107 if (acpi_has_method(device->handle, "_PSC")) in acpi_bus_get_power_flags()
1110 if (acpi_has_method(device->handle, "_IRC")) in acpi_bus_get_power_flags()
1113 if (acpi_has_method(device->handle, "_DSW")) in acpi_bus_get_power_flags()
1116 acpi_evaluate_integer(device->handle, "_DSC", NULL, &dsc); in acpi_bus_get_power_flags()
1154 if (acpi_has_method(device->handle, "_STA")) in acpi_bus_get_flags()
1158 if (acpi_has_method(device->handle, "_RMV")) in acpi_bus_get_flags()
1162 if (acpi_has_method(device->handle, "_EJD") || in acpi_bus_get_flags()
1163 acpi_has_method(device->handle, "_EJ0")) in acpi_bus_get_flags()
1195 acpi_get_name(device->handle, ACPI_SINGLE_NAME, &buffer); in acpi_device_get_busid()
1214 bool acpi_ata_match(acpi_handle handle) in acpi_ata_match() argument
1216 return acpi_has_method(handle, "_GTF") || in acpi_ata_match()
1217 acpi_has_method(handle, "_GTM") || in acpi_ata_match()
1218 acpi_has_method(handle, "_STM") || in acpi_ata_match()
1219 acpi_has_method(handle, "_SDD"); in acpi_ata_match()
1228 bool acpi_bay_match(acpi_handle handle) in acpi_bay_match() argument
1232 if (!acpi_has_method(handle, "_EJ0")) in acpi_bay_match()
1234 if (acpi_ata_match(handle)) in acpi_bay_match()
1236 if (ACPI_FAILURE(acpi_get_parent(handle, &phandle))) in acpi_bay_match()
1255 acpi_handle handle = adev->handle; in is_ejectable_bay() local
1257 if (acpi_has_method(handle, "_EJ0") && acpi_device_is_battery(adev)) in is_ejectable_bay()
1260 return acpi_bay_match(handle); in is_ejectable_bay()
1266 bool acpi_dock_match(acpi_handle handle) in acpi_dock_match() argument
1268 return acpi_has_method(handle, "_DCK"); in acpi_dock_match()
1272 acpi_backlight_cap_match(acpi_handle handle, u32 level, void *context, in acpi_backlight_cap_match() argument
1277 if (acpi_has_method(handle, "_BCM") && in acpi_backlight_cap_match()
1278 acpi_has_method(handle, "_BCL")) { in acpi_backlight_cap_match()
1279 acpi_handle_debug(handle, "Found generic backlight support\n"); in acpi_backlight_cap_match()
1295 long acpi_is_video_device(acpi_handle handle) in acpi_is_video_device() argument
1300 if (acpi_has_method(handle, "_DOD") || acpi_has_method(handle, "_DOS")) in acpi_is_video_device()
1304 if (acpi_has_method(handle, "_ROM")) in acpi_is_video_device()
1308 if (acpi_has_method(handle, "_VPO") && in acpi_is_video_device()
1309 acpi_has_method(handle, "_GPD") && in acpi_is_video_device()
1310 acpi_has_method(handle, "_SPD")) in acpi_is_video_device()
1315 acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, in acpi_is_video_device()
1358 static bool acpi_ibm_smbus_match(acpi_handle handle) in acpi_ibm_smbus_match() argument
1367 if (ACPI_FAILURE(acpi_get_name(handle, ACPI_SINGLE_NAME, &path)) || in acpi_ibm_smbus_match()
1372 if (acpi_has_method(handle, "SBI") && in acpi_ibm_smbus_match()
1373 acpi_has_method(handle, "SBR") && in acpi_ibm_smbus_match()
1374 acpi_has_method(handle, "SBW")) in acpi_ibm_smbus_match()
1380 static bool acpi_object_is_system_bus(acpi_handle handle) in acpi_object_is_system_bus() argument
1385 tmp == handle) in acpi_object_is_system_bus()
1388 tmp == handle) in acpi_object_is_system_bus()
1394 static void acpi_set_pnp_ids(acpi_handle handle, struct acpi_device_pnp *pnp, in acpi_set_pnp_ids() argument
1403 if (handle == ACPI_ROOT_OBJECT) { in acpi_set_pnp_ids()
1408 acpi_get_object_info(handle, &info); in acpi_set_pnp_ids()
1439 if (acpi_is_video_device(handle)) { in acpi_set_pnp_ids()
1444 if (acpi_bay_match(handle)) in acpi_set_pnp_ids()
1446 else if (acpi_dock_match(handle)) in acpi_set_pnp_ids()
1448 else if (acpi_ibm_smbus_match(handle)) in acpi_set_pnp_ids()
1451 acpi_object_is_system_bus(handle)) { in acpi_set_pnp_ids()
1560 if (adev && acpi_has_method(adev->handle, METHOD_NAME__DMA)) in acpi_dma_get_range()
1569 if (!acpi_has_method(adev->handle, METHOD_NAME__CRS)) { in acpi_dma_get_range()
1570 acpi_handle_warn(adev->handle, "_DMA is valid only if _CRS is present\n"); in acpi_dma_get_range()
1698 status = acpi_evaluate_integer(adev->handle, "_CCA", in acpi_init_coherency()
1710 acpi_handle_debug(adev->handle, in acpi_init_coherency()
1806 void acpi_init_device_object(struct acpi_device *device, acpi_handle handle, in acpi_init_device_object() argument
1809 struct acpi_device *parent = acpi_find_parent_acpi_dev(handle); in acpi_init_device_object()
1813 device->handle = handle; in acpi_init_device_object()
1821 acpi_set_pnp_ids(handle, &device->pnp, type); in acpi_init_device_object()
1839 if (dep->consumer == adev->handle) { in acpi_scan_dep_init()
1862 acpi_handle handle, int type, bool dep_init) in acpi_add_single_object() argument
1872 acpi_init_device_object(device, handle, type, acpi_device_release); in acpi_add_single_object()
1912 acpi_handle_debug(handle, "Added as %s, parent %s\n", in acpi_add_single_object()
1931 static bool acpi_device_should_be_hidden(acpi_handle handle) in acpi_device_should_be_hidden() argument
1937 if (!(spcr_uart_addr && acpi_has_method(handle, METHOD_NAME__CRS))) in acpi_device_should_be_hidden()
1944 status = acpi_walk_resources(handle, METHOD_NAME__CRS, in acpi_device_should_be_hidden()
1949 acpi_handle_info(handle, "The UART device @%pa in SPCR table will be hidden\n", in acpi_device_should_be_hidden()
2009 int acpi_scan_add_dep(acpi_handle handle, struct acpi_handle_list *dep_devices) in acpi_scan_add_dep() argument
2022 acpi_handle_debug(handle, "Error reading _DEP device info\n"); in acpi_scan_add_dep()
2040 dep->consumer = handle; in acpi_scan_add_dep()
2056 if (acpi_dock_match(adev->handle) || is_ejectable_bay(adev)) { in acpi_scan_init_hotplug()
2071 u32 __weak arch_acpi_add_auto_dep(acpi_handle handle) { return 0; } in arch_acpi_add_auto_dep() argument
2073 static u32 acpi_scan_check_dep(acpi_handle handle) in acpi_scan_check_dep() argument
2085 count += arch_acpi_add_auto_dep(handle); in acpi_scan_check_dep()
2093 if (!acpi_has_method(handle, "_DEP") || !acpi_has_method(handle, "_HID")) in acpi_scan_check_dep()
2096 if (!acpi_evaluate_reference(handle, "_DEP", NULL, &dep_devices)) { in acpi_scan_check_dep()
2097 acpi_handle_debug(handle, "Failed to evaluate _DEP.\n"); in acpi_scan_check_dep()
2101 count += acpi_scan_add_dep(handle, &dep_devices); in acpi_scan_check_dep()
2105 static acpi_status acpi_scan_check_crs_csi2_cb(acpi_handle handle, u32 a, void *b, void **c) in acpi_scan_check_crs_csi2_cb() argument
2107 acpi_mipi_check_crs_csi2(handle); in acpi_scan_check_crs_csi2_cb()
2111 static acpi_status acpi_bus_check_add(acpi_handle handle, bool first_pass, in acpi_bus_check_add() argument
2114 struct acpi_device *device = acpi_fetch_acpi_dev(handle); in acpi_bus_check_add()
2121 if (ACPI_FAILURE(acpi_get_type(handle, &acpi_type))) in acpi_bus_check_add()
2126 if (acpi_device_should_be_hidden(handle)) in acpi_bus_check_add()
2130 acpi_mipi_check_crs_csi2(handle); in acpi_bus_check_add()
2133 if (acpi_scan_check_dep(handle) > 0) { in acpi_bus_check_add()
2141 acpi_walk_namespace(ACPI_TYPE_DEVICE, handle, in acpi_bus_check_add()
2163 acpi_add_power_resource(handle); in acpi_bus_check_add()
2173 acpi_add_single_object(&device, handle, type, !first_pass); in acpi_bus_check_add()
2186 static acpi_status acpi_bus_check_add_1(acpi_handle handle, u32 lvl_not_used, in acpi_bus_check_add_1() argument
2189 return acpi_bus_check_add(handle, true, (struct acpi_device **)ret_p); in acpi_bus_check_add_1()
2192 static acpi_status acpi_bus_check_add_2(acpi_handle handle, u32 lvl_not_used, in acpi_bus_check_add_2() argument
2195 return acpi_bus_check_add(handle, false, (struct acpi_device **)ret_p); in acpi_bus_check_add_2()
2274 if (ACPI_SUCCESS(acpi_bus_get_ejd(device->handle, &ejd))) in acpi_bus_attach()
2340 if (dep->consumer == adev->handle) in acpi_dev_get_next_consumer_dev_cb()
2433 static int acpi_walk_dep_device_list(acpi_handle handle, in acpi_walk_dep_device_list() argument
2442 if (dep->supplier == handle) { in acpi_walk_dep_device_list()
2461 acpi_walk_dep_device_list(supplier->handle, acpi_scan_clear_dep, NULL); in acpi_dev_clear_dependencies()
2498 acpi_walk_dep_device_list(supplier->handle, in acpi_dev_get_next_consumer_dev()
2510 static void acpi_scan_postponed_branch(acpi_handle handle) in acpi_scan_postponed_branch() argument
2514 if (ACPI_FAILURE(acpi_bus_check_add(handle, false, &adev))) in acpi_scan_postponed_branch()
2517 acpi_walk_namespace(ACPI_TYPE_ANY, handle, ACPI_UINT32_MAX, in acpi_scan_postponed_branch()
2536 acpi_handle handle = dep->consumer; in acpi_scan_postponed() local
2543 if (!acpi_fetch_acpi_dev(handle)) { in acpi_scan_postponed()
2552 acpi_scan_postponed_branch(handle); in acpi_scan_postponed()
2580 int acpi_bus_scan(acpi_handle handle) in acpi_bus_scan() argument
2586 if (ACPI_SUCCESS(acpi_bus_check_add(handle, true, &device))) in acpi_bus_scan()
2587 acpi_walk_namespace(ACPI_TYPE_ANY, handle, ACPI_UINT32_MAX, in acpi_bus_scan()