| Eliot Blennerhassett | 719f82d | 2010-04-21 18:17:39 +0200 | [diff] [blame] | 1 | /****************************************************************************** | 
 | 2 |  | 
 | 3 |     AudioScience HPI driver | 
 | 4 |     Copyright (C) 1997-2010  AudioScience Inc. <support@audioscience.com> | 
 | 5 |  | 
 | 6 |     This program is free software; you can redistribute it and/or modify | 
 | 7 |     it under the terms of version 2 of the GNU General Public License as | 
 | 8 |     published by the Free Software Foundation; | 
 | 9 |  | 
 | 10 |     This program is distributed in the hope that it will be useful, | 
 | 11 |     but WITHOUT ANY WARRANTY; without even the implied warranty of | 
 | 12 |     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
 | 13 |     GNU General Public License for more details. | 
 | 14 |  | 
 | 15 |     You should have received a copy of the GNU General Public License | 
 | 16 |     along with this program; if not, write to the Free Software | 
 | 17 |     Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA | 
 | 18 |  | 
 | 19 |  Hardware Programming Interface (HPI) Utility functions. | 
 | 20 |  | 
 | 21 |  (C) Copyright AudioScience Inc. 2007 | 
 | 22 | *******************************************************************************/ | 
 | 23 |  | 
 | 24 | #include "hpi_internal.h" | 
 | 25 | #include "hpimsginit.h" | 
 | 26 |  | 
 | 27 | /* The actual message size for each object type */ | 
 | 28 | static u16 msg_size[HPI_OBJ_MAXINDEX + 1] = HPI_MESSAGE_SIZE_BY_OBJECT; | 
 | 29 | /* The actual response size for each object type */ | 
 | 30 | static u16 res_size[HPI_OBJ_MAXINDEX + 1] = HPI_RESPONSE_SIZE_BY_OBJECT; | 
 | 31 | /* Flag to enable alternate message type for SSX2 bypass. */ | 
 | 32 | static u16 gwSSX2_bypass; | 
 | 33 |  | 
 | 34 | /** \internal | 
 | 35 |   * Used by ASIO driver to disable SSX2 for a single process | 
 | 36 |   * \param phSubSys Pointer to HPI subsystem handle. | 
 | 37 |   * \param wBypass New bypass setting 0 = off, nonzero = on | 
 | 38 |   * \return Previous bypass setting. | 
 | 39 |   */ | 
 | 40 | u16 hpi_subsys_ssx2_bypass(const struct hpi_hsubsys *ph_subsys, u16 bypass) | 
 | 41 | { | 
 | 42 | 	u16 old_value = gwSSX2_bypass; | 
 | 43 |  | 
 | 44 | 	gwSSX2_bypass = bypass; | 
 | 45 |  | 
 | 46 | 	return old_value; | 
 | 47 | } | 
 | 48 |  | 
 | 49 | /** \internal | 
 | 50 |   * initialize the HPI message structure | 
 | 51 |   */ | 
 | 52 | static void hpi_init_message(struct hpi_message *phm, u16 object, | 
 | 53 | 	u16 function) | 
 | 54 | { | 
 | 55 | 	memset(phm, 0, sizeof(*phm)); | 
 | 56 | 	if ((object > 0) && (object <= HPI_OBJ_MAXINDEX)) | 
 | 57 | 		phm->size = msg_size[object]; | 
 | 58 | 	else | 
 | 59 | 		phm->size = sizeof(*phm); | 
 | 60 |  | 
 | 61 | 	if (gwSSX2_bypass) | 
 | 62 | 		phm->type = HPI_TYPE_SSX2BYPASS_MESSAGE; | 
 | 63 | 	else | 
 | 64 | 		phm->type = HPI_TYPE_MESSAGE; | 
 | 65 | 	phm->object = object; | 
 | 66 | 	phm->function = function; | 
 | 67 | 	phm->version = 0; | 
 | 68 | 	/* Expect adapter index to be set by caller */ | 
 | 69 | } | 
 | 70 |  | 
 | 71 | /** \internal | 
 | 72 |   * initialize the HPI response structure | 
 | 73 |   */ | 
 | 74 | void hpi_init_response(struct hpi_response *phr, u16 object, u16 function, | 
 | 75 | 	u16 error) | 
 | 76 | { | 
 | 77 | 	memset(phr, 0, sizeof(*phr)); | 
 | 78 | 	phr->type = HPI_TYPE_RESPONSE; | 
 | 79 | 	if ((object > 0) && (object <= HPI_OBJ_MAXINDEX)) | 
 | 80 | 		phr->size = res_size[object]; | 
 | 81 | 	else | 
 | 82 | 		phr->size = sizeof(*phr); | 
 | 83 | 	phr->object = object; | 
 | 84 | 	phr->function = function; | 
 | 85 | 	phr->error = error; | 
 | 86 | 	phr->specific_error = 0; | 
 | 87 | 	phr->version = 0; | 
 | 88 | } | 
 | 89 |  | 
 | 90 | void hpi_init_message_response(struct hpi_message *phm, | 
 | 91 | 	struct hpi_response *phr, u16 object, u16 function) | 
 | 92 | { | 
 | 93 | 	hpi_init_message(phm, object, function); | 
 | 94 | 	/* default error return if the response is | 
 | 95 | 	   not filled in by the callee */ | 
 | 96 | 	hpi_init_response(phr, object, function, | 
 | 97 | 		HPI_ERROR_PROCESSING_MESSAGE); | 
 | 98 | } | 
 | 99 |  | 
 | 100 | static void hpi_init_messageV1(struct hpi_message_header *phm, u16 size, | 
 | 101 | 	u16 object, u16 function) | 
 | 102 | { | 
 | 103 | 	memset(phm, 0, sizeof(*phm)); | 
 | 104 | 	if ((object > 0) && (object <= HPI_OBJ_MAXINDEX)) { | 
 | 105 | 		phm->size = size; | 
 | 106 | 		phm->type = HPI_TYPE_MESSAGE; | 
 | 107 | 		phm->object = object; | 
 | 108 | 		phm->function = function; | 
 | 109 | 		phm->version = 1; | 
 | 110 | 		/* Expect adapter index to be set by caller */ | 
 | 111 | 	} | 
 | 112 | } | 
 | 113 |  | 
 | 114 | void hpi_init_responseV1(struct hpi_response_header *phr, u16 size, | 
 | 115 | 	u16 object, u16 function) | 
 | 116 | { | 
 | 117 | 	memset(phr, 0, sizeof(*phr)); | 
 | 118 | 	phr->size = size; | 
 | 119 | 	phr->version = 1; | 
 | 120 | 	phr->type = HPI_TYPE_RESPONSE; | 
 | 121 | 	phr->error = HPI_ERROR_PROCESSING_MESSAGE; | 
 | 122 | } | 
 | 123 |  | 
 | 124 | void hpi_init_message_responseV1(struct hpi_message_header *phm, u16 msg_size, | 
 | 125 | 	struct hpi_response_header *phr, u16 res_size, u16 object, | 
 | 126 | 	u16 function) | 
 | 127 | { | 
 | 128 | 	hpi_init_messageV1(phm, msg_size, object, function); | 
 | 129 | 	hpi_init_responseV1(phr, res_size, object, function); | 
 | 130 | } |