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

📄 rsmisc.c

📁 内核linux2.4.20,可跟rtlinux3.2打补丁 组成实时linux系统,编译内核
💻 C
📖 第 1 页 / 共 2 页
字号:
		MOVE_UNALIGNED16_TO_16 (buffer, &temp16);		buffer += 2;	}	else {		/*		 * Small Item		 * Set the descriptor field		 */		temp8 = 0x70;		temp8 |= 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 = POINTER_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    Acpi_rs_start_dependent_functions_resource * * PARAMETERS:  Byte_stream_buffer      - Pointer to the resource input byte *                                        stream *              Bytes_consumed          - u32 pointer that is filled with *                                        the number of bytes consumed from *                                        the Byte_stream_buffer *              Output_buffer           - Pointer to the user's return buffer *              Structure_size          - u32 pointer that is filled with *                                        the number of bytes in the filled *                                        in structure * * 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_dependent_functions_resource (	u8                      *byte_stream_buffer,	u32                     *bytes_consumed,	u8                      **output_buffer,	u32                     *structure_size){	u8                      *buffer = byte_stream_buffer;	acpi_resource          *output_struct = (acpi_resource *) *output_buffer;	u8                      temp8 = 0;	u32                     struct_size = SIZEOF_RESOURCE (acpi_resource_start_dpf);	FUNCTION_TRACE ("Rs_start_dependent_functions_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_ERROR);		}		/*		 * 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_ERROR);		}	}	else {		output_struct->data.start_dpf.compatibility_priority =				ACCEPTABLE_CONFIGURATION;		output_struct->data.start_dpf.performance_robustness =				ACCEPTABLE_CONFIGURATION;	}	/*	 * Set the Length parameter	 */	output_struct->length = struct_size;	/*	 * Return the final size of the structure	 */	*structure_size = struct_size;	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    Acpi_rs_end_dependent_functions_resource * * PARAMETERS:  Byte_stream_buffer      - Pointer to the resource input byte *                                        stream *              Bytes_consumed          - u32 pointer that is filled with *                                        the number of bytes consumed from *                                        the Byte_stream_buffer *              Output_buffer           - Pointer to the user's return buffer *              Structure_size          - u32 pointer that is filled with *                                        the number of bytes in the filled *                                        in structure * * 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_dependent_functions_resource (	u8                      *byte_stream_buffer,	u32                     *bytes_consumed,	u8                      **output_buffer,	u32                     *structure_size){	acpi_resource           *output_struct = (acpi_resource *) *output_buffer;	u32                     struct_size = ACPI_RESOURCE_LENGTH;	FUNCTION_TRACE ("Rs_end_dependent_functions_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 = struct_size;	/*	 * Return the final size of the structure	 */	*structure_size = struct_size;	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    Acpi_rs_start_dependent_functions_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_dependent_functions_stream (	acpi_resource           *linked_list,	u8                      **output_buffer,	u32                     *bytes_consumed){	u8                      *buffer = *output_buffer;	u8                      temp8 = 0;	FUNCTION_TRACE ("Rs_start_dependent_functions_stream");	/*	 * The descriptor field is set based upon whether a byte is needed	 * to contain Priority data.	 */	if (ACCEPTABLE_CONFIGURATION ==			linked_list->data.start_dpf.compatibility_priority &&		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 = POINTER_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    Acpi_rs_end_dependent_functions_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_end_dependent_functions_stream (	acpi_resource           *linked_list,	u8                      **output_buffer,	u32                     *bytes_consumed	){	u8                      *buffer = *output_buffer;	FUNCTION_TRACE ("Rs_end_dependent_functions_stream");	/*	 * The descriptor field is static	 */	*buffer = 0x38;	buffer += 1;	/*	 * Return the number of bytes consumed in this operation	 */	*bytes_consumed = POINTER_DIFF (buffer, *output_buffer);	return_ACPI_STATUS (AE_OK);}

⌨️ 快捷键说明

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