⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rsmisc.c

📁 h内核
💻 C
📖 第 1 页 / 共 2 页
字号:
	 */	if(linked_list->data.vendor_specific.length > 7) {		/*		 * Large Item, Set the descriptor field and length bytes		 */		*buffer = 0x84;		buffer += 1;		temp16 = (u16) linked_list->data.vendor_specific.length;		ACPI_MOVE_16_TO_16 (buffer, &temp16);		buffer += 2;	}	else {		/*		 * Small Item, Set the descriptor field		 */		temp8 = 0x70;		temp8 |= (u8) linked_list->data.vendor_specific.length;		*buffer = temp8;		buffer += 1;	}	/*	 * Loop through all of the Vendor Specific fields	 */	for (index = 0; index < linked_list->data.vendor_specific.length; index++) {		temp8 = linked_list->data.vendor_specific.reserved[index];		*buffer = temp8;		buffer += 1;	}	/*	 * Return the number of bytes consumed in this operation	 */	*bytes_consumed = ACPI_PTR_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    acpi_rs_start_depend_fns_resource * * PARAMETERS:  byte_stream_buffer      - Pointer to the resource input byte *                                        stream *              bytes_consumed          - Pointer to where the number of bytes *                                        consumed the byte_stream_buffer is *                                        returned *              output_buffer           - Pointer to the return data buffer *              structure_size          - Pointer to where the number of bytes *                                        in the return data struct is returned * * RETURN:      Status * * DESCRIPTION: Take the resource byte stream and fill out the appropriate *              structure pointed to by the output_buffer. Return the *              number of bytes consumed from the byte stream. * ******************************************************************************/acpi_statusacpi_rs_start_depend_fns_resource (	u8                              *byte_stream_buffer,	acpi_size                       *bytes_consumed,	u8                              **output_buffer,	acpi_size                       *structure_size){	u8                              *buffer = byte_stream_buffer;	struct acpi_resource            *output_struct = (void *) *output_buffer;	u8                              temp8 = 0;	acpi_size                       struct_size = ACPI_SIZEOF_RESOURCE (struct acpi_resource_start_dpf);	ACPI_FUNCTION_TRACE ("rs_start_depend_fns_resource");	/*	 * The number of bytes consumed are contained in the descriptor (Bits:0-1)	 */	temp8 = *buffer;	*bytes_consumed = (temp8 & 0x01) + 1;	output_struct->id = ACPI_RSTYPE_START_DPF;	/*	 * Point to Byte 1 if it is used	 */	if (2 == *bytes_consumed) {		buffer += 1;		temp8 = *buffer;		/*		 * Check Compatibility priority		 */		output_struct->data.start_dpf.compatibility_priority = temp8 & 0x03;		if (3 == output_struct->data.start_dpf.compatibility_priority) {			return_ACPI_STATUS (AE_AML_BAD_RESOURCE_VALUE);		}		/*		 * Check Performance/Robustness preference		 */		output_struct->data.start_dpf.performance_robustness = (temp8 >> 2) & 0x03;		if (3 == output_struct->data.start_dpf.performance_robustness) {			return_ACPI_STATUS (AE_AML_BAD_RESOURCE_VALUE);		}	}	else {		output_struct->data.start_dpf.compatibility_priority =				ACPI_ACCEPTABLE_CONFIGURATION;		output_struct->data.start_dpf.performance_robustness =				ACPI_ACCEPTABLE_CONFIGURATION;	}	/*	 * Set the Length parameter	 */	output_struct->length = (u32) struct_size;	/*	 * Return the final size of the structure	 */	*structure_size = struct_size;	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    acpi_rs_end_depend_fns_resource * * PARAMETERS:  byte_stream_buffer      - Pointer to the resource input byte *                                        stream *              bytes_consumed          - Pointer to where the number of bytes *                                        consumed the byte_stream_buffer is *                                        returned *              output_buffer           - Pointer to the return data buffer *              structure_size          - Pointer to where the number of bytes *                                        in the return data struct is returned * * RETURN:      Status * * DESCRIPTION: Take the resource byte stream and fill out the appropriate *              structure pointed to by the output_buffer. Return the *              number of bytes consumed from the byte stream. * ******************************************************************************/acpi_statusacpi_rs_end_depend_fns_resource (	u8                              *byte_stream_buffer,	acpi_size                       *bytes_consumed,	u8                              **output_buffer,	acpi_size                       *structure_size){	struct acpi_resource            *output_struct = (void *) *output_buffer;	acpi_size                       struct_size = ACPI_RESOURCE_LENGTH;	ACPI_FUNCTION_TRACE ("rs_end_depend_fns_resource");	/*	 * The number of bytes consumed is static	 */	*bytes_consumed = 1;	/*	 *  Fill out the structure	 */	output_struct->id = ACPI_RSTYPE_END_DPF;	/*	 * Set the Length parameter	 */	output_struct->length = (u32) struct_size;	/*	 * Return the final size of the structure	 */	*structure_size = struct_size;	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    acpi_rs_start_depend_fns_stream * * PARAMETERS:  linked_list             - Pointer to the resource linked list *              output_buffer           - Pointer to the user's return buffer *              bytes_consumed          - u32 pointer that is filled with *                                        the number of bytes of the *                                        output_buffer used * * RETURN:      Status * * DESCRIPTION: Take the linked list resource structure and fills in the *              the appropriate bytes in a byte stream * ******************************************************************************/acpi_statusacpi_rs_start_depend_fns_stream (	struct acpi_resource            *linked_list,	u8                              **output_buffer,	acpi_size                       *bytes_consumed){	u8                              *buffer = *output_buffer;	u8                              temp8 = 0;	ACPI_FUNCTION_TRACE ("rs_start_depend_fns_stream");	/*	 * The descriptor field is set based upon whether a byte is needed	 * to contain Priority data.	 */	if (ACPI_ACCEPTABLE_CONFIGURATION ==			linked_list->data.start_dpf.compatibility_priority &&		ACPI_ACCEPTABLE_CONFIGURATION ==			linked_list->data.start_dpf.performance_robustness) {		*buffer = 0x30;	}	else {		*buffer = 0x31;		buffer += 1;		/*		 * Set the Priority Byte Definition		 */		temp8 = 0;		temp8 = (u8) ((linked_list->data.start_dpf.performance_robustness &				   0x03) << 2);		temp8 |= (linked_list->data.start_dpf.compatibility_priority &				   0x03);		*buffer = temp8;	}	buffer += 1;	/*	 * Return the number of bytes consumed in this operation	 */	*bytes_consumed = ACPI_PTR_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    acpi_rs_end_depend_fns_stream * * PARAMETERS:  linked_list             - Pointer to the resource linked list *              output_buffer           - Pointer to the user's return buffer *              bytes_consumed          - Pointer to where the number of bytes *                                        used in the output_buffer is returned * * RETURN:      Status * * DESCRIPTION: Take the linked list resource structure and fills in the *              the appropriate bytes in a byte stream * ******************************************************************************/acpi_statusacpi_rs_end_depend_fns_stream (	struct acpi_resource            *linked_list,	u8                              **output_buffer,	acpi_size                       *bytes_consumed){	u8                              *buffer = *output_buffer;	ACPI_FUNCTION_TRACE ("rs_end_depend_fns_stream");	/*	 * The descriptor field is static	 */	*buffer = 0x38;	buffer += 1;	/*	 * Return the number of bytes consumed in this operation	 */	*bytes_consumed = ACPI_PTR_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -