Logo Search packages:      
Sourcecode: alsa-driver version File versions  Download package

hpidspcd.h

Go to the documentation of this file.
/***********************************************************************/
/*!

    AudioScience HPI driver
    Copyright (C) 1997-2003  AudioScience Inc. <support@audioscience.com>

    This program is free software; you can redistribute it and/or modify
    it under the terms of version 2 of the GNU General Public License as
    published by the Free Software Foundation;

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

\file
Functions for reading DSP code to load into DSP
USE_ZLIB is forced to be undefined.

If it is not defined, code is read from linked arrays.
HPI_INCLUDE_**** must be defined
and the appropriate hzz?????.c or hex?????.c linked in

If USE_ZLIB is defined, hpizlib.c must also be linked
*/
/***********************************************************************/
#ifndef _HPIDSPLD_H_
#define _HPIDSPLD_H_

/*#include <stdio.h> */
#include "hpi.h"

#ifndef DISABLE_PRAGMA_PACK1
#pragma pack(push, 1)
#endif

/** Descriptor for dspcode from firmware loader */
00042 struct dsp_code {
      /**  Firmware descriptor */
00044       const struct firmware *psFirmware;
      struct pci_dev *psDev;
      /** Expected number of words in the whole dsp code,INCL header */
00047       long int dwBlockLength;
      /** Number of words read so far */
00049       long int dwWordCount;
      /** Version read from dsp code file */
00051       u32 dwVersion;
      /** CRC read from dsp code file */
00053       u32 dwCrc;
};

#ifndef DISABLE_PRAGMA_PACK1
#pragma pack(pop)
#endif

/** Prepare *psDspCode to refer to the requuested adapter.
 Searches the file, or selects the appropriate linked array

\return 0 for success, or error code if requested code is not available
*/
short HpiDspCode_Open(
      u32 nAdapter,           /*!< Adapter family */
      /*!< Pointer to DSP code control structure */
      struct dsp_code *psDspCode,
      /*!< Pointer to dword to receive OS specific error code */
      u32 *pdwOsErrorCode
);

/*! Close the DSP code file */
void HpiDspCode_Close(
      struct dsp_code *psDspCode
);

/*! Rewind to the beginning of the DSP code file (for verify) */
void HpiDspCode_Rewind(
      struct dsp_code *psDspCode
);

/*! Read one word from the dsp code file
      \return 0 for success, or error code if eof, or block length exceeded
*/
short HpiDspCode_ReadWord(
      struct dsp_code *psDspCode,
      /*!< Where to store the read word */
      u32 *pdwWord
);

/** Get a block of dsp code into an internal buffer, and provide a pointer to
that buffer. (If dsp code is already an array in memory, it is referenced,
not copied.)

\return Error if requested number of words are not available
*/
short HpiDspCode_ReadBlock(
      size_t nWordsRequested,
      struct dsp_code *psDspCode,
      /* Pointer to store (Pointer to code buffer) */
      u32 **ppdwBlock
);

#endif

Generated by  Doxygen 1.6.0   Back to index