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

📄 rsmisc.c

📁 linux-2.6.15.6
💻 C
📖 第 1 页 / 共 2 页
字号:
	/* Dereference the length to find if this is a large or small item. */	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 found 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 + -