0001
0002
0003
0004
0005
0006
0007
0008
0009
0010 #define EXPORT_ACPI_INTERFACES
0011
0012 #include <acpi/acpi.h>
0013 #include "accommon.h"
0014 #include "acnamesp.h"
0015
0016 #define _COMPONENT ACPI_HARDWARE
0017 ACPI_MODULE_NAME("hwxface")
0018
0019
0020
0021
0022
0023
0024
0025
0026
0027
0028
0029
0030
0031
0032 acpi_status acpi_reset(void)
0033 {
0034 struct acpi_generic_address *reset_reg;
0035 acpi_status status;
0036
0037 ACPI_FUNCTION_TRACE(acpi_reset);
0038
0039 reset_reg = &acpi_gbl_FADT.reset_register;
0040
0041
0042
0043 if (!(acpi_gbl_FADT.flags & ACPI_FADT_RESET_REGISTER) ||
0044 !reset_reg->address) {
0045 return_ACPI_STATUS(AE_NOT_EXIST);
0046 }
0047
0048 if (reset_reg->space_id == ACPI_ADR_SPACE_SYSTEM_IO) {
0049
0050
0051
0052
0053
0054
0055
0056
0057
0058
0059
0060 status = acpi_os_write_port((acpi_io_address)reset_reg->address,
0061 acpi_gbl_FADT.reset_value,
0062 ACPI_RESET_REGISTER_WIDTH);
0063 } else {
0064
0065
0066 status = acpi_hw_write(acpi_gbl_FADT.reset_value, reset_reg);
0067 }
0068
0069 return_ACPI_STATUS(status);
0070 }
0071
0072 ACPI_EXPORT_SYMBOL(acpi_reset)
0073
0074
0075
0076
0077
0078
0079
0080
0081
0082
0083
0084
0085
0086
0087
0088
0089
0090
0091
0092 acpi_status acpi_read(u64 *return_value, struct acpi_generic_address *reg)
0093 {
0094 acpi_status status;
0095
0096 ACPI_FUNCTION_NAME(acpi_read);
0097
0098 status = acpi_hw_read(return_value, reg);
0099 return (status);
0100 }
0101
0102 ACPI_EXPORT_SYMBOL(acpi_read)
0103
0104
0105
0106
0107
0108
0109
0110
0111
0112
0113
0114
0115
0116 acpi_status acpi_write(u64 value, struct acpi_generic_address *reg)
0117 {
0118 acpi_status status;
0119
0120 ACPI_FUNCTION_NAME(acpi_write);
0121
0122 status = acpi_hw_write(value, reg);
0123 return (status);
0124 }
0125
0126 ACPI_EXPORT_SYMBOL(acpi_write)
0127
0128 #if (!ACPI_REDUCED_HARDWARE)
0129
0130
0131
0132
0133
0134
0135
0136
0137
0138
0139
0140
0141
0142
0143
0144
0145
0146
0147
0148
0149
0150
0151
0152
0153 acpi_status acpi_read_bit_register(u32 register_id, u32 *return_value)
0154 {
0155 struct acpi_bit_register_info *bit_reg_info;
0156 u32 register_value;
0157 u32 value;
0158 acpi_status status;
0159
0160 ACPI_FUNCTION_TRACE_U32(acpi_read_bit_register, register_id);
0161
0162
0163
0164 bit_reg_info = acpi_hw_get_bit_register_info(register_id);
0165 if (!bit_reg_info) {
0166 return_ACPI_STATUS(AE_BAD_PARAMETER);
0167 }
0168
0169
0170
0171 status = acpi_hw_register_read(bit_reg_info->parent_register,
0172 ®ister_value);
0173 if (ACPI_FAILURE(status)) {
0174 return_ACPI_STATUS(status);
0175 }
0176
0177
0178
0179 value = ((register_value & bit_reg_info->access_bit_mask)
0180 >> bit_reg_info->bit_position);
0181
0182 ACPI_DEBUG_PRINT((ACPI_DB_IO,
0183 "BitReg %X, ParentReg %X, Actual %8.8X, ReturnValue %8.8X\n",
0184 register_id, bit_reg_info->parent_register,
0185 register_value, value));
0186
0187 *return_value = value;
0188 return_ACPI_STATUS(AE_OK);
0189 }
0190
0191 ACPI_EXPORT_SYMBOL(acpi_read_bit_register)
0192
0193
0194
0195
0196
0197
0198
0199
0200
0201
0202
0203
0204
0205
0206
0207
0208
0209
0210
0211
0212
0213
0214 acpi_status acpi_write_bit_register(u32 register_id, u32 value)
0215 {
0216 struct acpi_bit_register_info *bit_reg_info;
0217 acpi_cpu_flags lock_flags;
0218 u32 register_value;
0219 acpi_status status = AE_OK;
0220
0221 ACPI_FUNCTION_TRACE_U32(acpi_write_bit_register, register_id);
0222
0223
0224
0225 bit_reg_info = acpi_hw_get_bit_register_info(register_id);
0226 if (!bit_reg_info) {
0227 return_ACPI_STATUS(AE_BAD_PARAMETER);
0228 }
0229
0230 lock_flags = acpi_os_acquire_raw_lock(acpi_gbl_hardware_lock);
0231
0232
0233
0234
0235
0236 if (bit_reg_info->parent_register != ACPI_REGISTER_PM1_STATUS) {
0237
0238
0239
0240
0241
0242
0243 status = acpi_hw_register_read(bit_reg_info->parent_register,
0244 ®ister_value);
0245 if (ACPI_FAILURE(status)) {
0246 goto unlock_and_exit;
0247 }
0248
0249
0250
0251
0252
0253 ACPI_REGISTER_INSERT_VALUE(register_value,
0254 bit_reg_info->bit_position,
0255 bit_reg_info->access_bit_mask,
0256 value);
0257
0258 status = acpi_hw_register_write(bit_reg_info->parent_register,
0259 register_value);
0260 } else {
0261
0262
0263
0264
0265
0266
0267
0268
0269 register_value = ACPI_REGISTER_PREPARE_BITS(value,
0270 bit_reg_info->
0271 bit_position,
0272 bit_reg_info->
0273 access_bit_mask);
0274
0275
0276
0277 if (register_value) {
0278 status =
0279 acpi_hw_register_write(ACPI_REGISTER_PM1_STATUS,
0280 register_value);
0281 }
0282 }
0283
0284 ACPI_DEBUG_PRINT((ACPI_DB_IO,
0285 "BitReg %X, ParentReg %X, Value %8.8X, Actual %8.8X\n",
0286 register_id, bit_reg_info->parent_register, value,
0287 register_value));
0288
0289 unlock_and_exit:
0290
0291 acpi_os_release_raw_lock(acpi_gbl_hardware_lock, lock_flags);
0292 return_ACPI_STATUS(status);
0293 }
0294
0295 ACPI_EXPORT_SYMBOL(acpi_write_bit_register)
0296 #endif
0297
0298
0299
0300
0301
0302
0303
0304
0305
0306
0307
0308
0309
0310
0311
0312
0313
0314
0315
0316
0317
0318
0319
0320
0321
0322
0323
0324
0325
0326
0327
0328
0329
0330
0331
0332
0333
0334 acpi_status
0335 acpi_get_sleep_type_data(u8 sleep_state, u8 *sleep_type_a, u8 *sleep_type_b)
0336 {
0337 acpi_status status;
0338 struct acpi_evaluate_info *info;
0339 union acpi_operand_object **elements;
0340
0341 ACPI_FUNCTION_TRACE(acpi_get_sleep_type_data);
0342
0343
0344
0345 if ((sleep_state > ACPI_S_STATES_MAX) || !sleep_type_a || !sleep_type_b) {
0346 return_ACPI_STATUS(AE_BAD_PARAMETER);
0347 }
0348
0349
0350
0351 info = ACPI_ALLOCATE_ZEROED(sizeof(struct acpi_evaluate_info));
0352 if (!info) {
0353 return_ACPI_STATUS(AE_NO_MEMORY);
0354 }
0355
0356
0357
0358
0359
0360 info->relative_pathname = acpi_gbl_sleep_state_names[sleep_state];
0361
0362 status = acpi_ns_evaluate(info);
0363 if (ACPI_FAILURE(status)) {
0364 if (status == AE_NOT_FOUND) {
0365
0366
0367
0368 goto final_cleanup;
0369 }
0370
0371 goto warning_cleanup;
0372 }
0373
0374
0375
0376 if (!info->return_object) {
0377 ACPI_ERROR((AE_INFO, "No Sleep State object returned from [%s]",
0378 info->relative_pathname));
0379 status = AE_AML_NO_RETURN_VALUE;
0380 goto warning_cleanup;
0381 }
0382
0383
0384
0385 if (info->return_object->common.type != ACPI_TYPE_PACKAGE) {
0386 ACPI_ERROR((AE_INFO,
0387 "Sleep State return object is not a Package"));
0388 status = AE_AML_OPERAND_TYPE;
0389 goto return_value_cleanup;
0390 }
0391
0392
0393
0394
0395
0396
0397 elements = info->return_object->package.elements;
0398 switch (info->return_object->package.count) {
0399 case 0:
0400
0401 status = AE_AML_PACKAGE_LIMIT;
0402 break;
0403
0404 case 1:
0405
0406 if (elements[0]->common.type != ACPI_TYPE_INTEGER) {
0407 status = AE_AML_OPERAND_TYPE;
0408 break;
0409 }
0410
0411
0412
0413 *sleep_type_a = (u8)elements[0]->integer.value;
0414 *sleep_type_b = (u8)(elements[0]->integer.value >> 8);
0415 break;
0416
0417 case 2:
0418 default:
0419
0420 if ((elements[0]->common.type != ACPI_TYPE_INTEGER) ||
0421 (elements[1]->common.type != ACPI_TYPE_INTEGER)) {
0422 status = AE_AML_OPERAND_TYPE;
0423 break;
0424 }
0425
0426
0427
0428 *sleep_type_a = (u8)elements[0]->integer.value;
0429 *sleep_type_b = (u8)elements[1]->integer.value;
0430 break;
0431 }
0432
0433 return_value_cleanup:
0434 acpi_ut_remove_reference(info->return_object);
0435
0436 warning_cleanup:
0437 if (ACPI_FAILURE(status)) {
0438 ACPI_EXCEPTION((AE_INFO, status,
0439 "While evaluating Sleep State [%s]",
0440 info->relative_pathname));
0441 }
0442
0443 final_cleanup:
0444 ACPI_FREE(info);
0445 return_ACPI_STATUS(status);
0446 }
0447
0448 ACPI_EXPORT_SYMBOL(acpi_get_sleep_type_data)