cregit-Linux how code gets into the kernel

Release 4.14 drivers/isdn/hardware/eicon/dsp_defs.h

/*
 *
 Copyright (c) Eicon Networks, 2002.
 *
 This source file is supplied for the use with
 Eicon Networks range of DIVA Server Adapters.
 *
 Eicon File Revision :    2.1
 *
 This program is free software; you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published by
 the Free Software Foundation; either version 2, or (at your option)
 any later version.
 *
 This program is distributed in the hope that it will be useful,
 but WITHOUT ANY WARRANTY OF ANY KIND WHATSOEVER INCLUDING ANY
 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., 675 Mass Ave, Cambridge, MA 02139, USA.
 *
 */
#ifndef DSP_DEFS_H_

#define DSP_DEFS_H_
#include "dspdids.h"
/*---------------------------------------------------------------------------*/

#define dsp_download_reserve_space(fp, length)
/*****************************************************************************/
/*
 * OS file access abstraction layer
 *
 * I/O functions returns -1 on error, 0 on EOF
 */
struct _OsFileHandle_;

typedef long (*OsFileIo)(struct _OsFileHandle_ *handle,
			 void *buffer,
			 long size);

typedef long (*OsFileSeek)(struct _OsFileHandle_ *handle,
			   long position,
			   int mode);

typedef long (*OsCardLoad)(struct _OsFileHandle_    *handle,
			   long length,
			   void **addr);

typedef struct _OsFileHandle_

{ void       *sysFileDesc;
	
unsigned long sysFileSize;
	
OsFileIo      sysFileRead;
	
OsFileSeek    sysFileSeek;
	
void       *sysLoadDesc;
	
OsCardLoad    sysCardLoad;

} OsFileHandle;
extern OsFileHandle *OsOpenFile(char *path_name);
extern void          OsCloseFile(OsFileHandle *fp);
/*****************************************************************************/

#define DSP_TELINDUS_FILE "dspdload.bin"
/* special DSP file for BRI cards for Qsig and CornetN because of missing memory */

#define DSP_QSIG_TELINDUS_FILE "dspdqsig.bin"

#define DSP_MDM_TELINDUS_FILE "dspdvmdm.bin"

#define DSP_FAX_TELINDUS_FILE "dspdvfax.bin"

#define DSP_DIRECTORY_ENTRIES 64

#define DSP_MEMORY_TYPE_EXTERNAL_DM         0

#define DSP_MEMORY_TYPE_EXTERNAL_PM         1

#define DSP_MEMORY_TYPE_INTERNAL_DM         2

#define DSP_MEMORY_TYPE_INTERNAL_PM         3

#define DSP_DOWNLOAD_FLAG_BOOTABLE          0x0001

#define DSP_DOWNLOAD_FLAG_2181              0x0002

#define DSP_DOWNLOAD_FLAG_TIMECRITICAL      0x0004

#define DSP_DOWNLOAD_FLAG_COMPAND           0x0008

#define DSP_MEMORY_BLOCK_COUNT              16

#define DSP_SEGMENT_PM_FLAG                 0x0001

#define DSP_SEGMENT_SHARED_FLAG             0x0002

#define DSP_SEGMENT_EXTERNAL_DM             DSP_MEMORY_TYPE_EXTERNAL_DM

#define DSP_SEGMENT_EXTERNAL_PM             DSP_MEMORY_TYPE_EXTERNAL_PM

#define DSP_SEGMENT_INTERNAL_DM             DSP_MEMORY_TYPE_INTERNAL_DM

#define DSP_SEGMENT_INTERNAL_PM             DSP_MEMORY_TYPE_INTERNAL_PM

#define DSP_SEGMENT_FIRST_RELOCATABLE       4

#define DSP_DATA_BLOCK_PM_FLAG              0x0001

#define DSP_DATA_BLOCK_DWORD_FLAG           0x0002

#define DSP_DATA_BLOCK_RESOLVE_FLAG         0x0004

#define DSP_RELOC_NONE                      0x00

#define DSP_RELOC_SEGMENT_MASK              0x3f

#define DSP_RELOC_TYPE_MASK                 0xc0

#define DSP_RELOC_TYPE_0                    0x00  
/* relocation of address in DM word / high part of PM word */

#define DSP_RELOC_TYPE_1                    0x40  
/* relocation of address in low part of PM data word */

#define DSP_RELOC_TYPE_2                    0x80  
/* relocation of address in standard command */

#define DSP_RELOC_TYPE_3                    0xc0  
/* relocation of address in call/jump on flag in */

#define DSP_COMBIFILE_FORMAT_IDENTIFICATION_SIZE 48

#define DSP_COMBIFILE_FORMAT_VERSION_BCD    0x0100

#define DSP_FILE_FORMAT_IDENTIFICATION_SIZE 48

#define DSP_FILE_FORMAT_VERSION_BCD         0x0100

typedef struct tag_dsp_combifile_header
{
	
char                  format_identification[DSP_COMBIFILE_FORMAT_IDENTIFICATION_SIZE];
	
word                  format_version_bcd;
	
word                  header_size;
	
word                  combifile_description_size;
	
word                  directory_entries;
	
word                  directory_size;
	
word                  download_count;
	
word                  usage_mask_size;

} t_dsp_combifile_header;

typedef struct tag_dsp_combifile_directory_entry
{
	
word                  card_type_number;
	
word                  file_set_number;

} t_dsp_combifile_directory_entry;

typedef struct tag_dsp_file_header
{
	
char                  format_identification[DSP_FILE_FORMAT_IDENTIFICATION_SIZE];
	
word                  format_version_bcd;
	
word                  download_id;
	
word                  download_flags;
	
word                  required_processing_power;
	
word                  interface_channel_count;
	
word                  header_size;
	
word                  download_description_size;
	
word                  memory_block_table_size;
	
word                  memory_block_count;
	
word                  segment_table_size;
	
word                  segment_count;
	
word                  symbol_table_size;
	
word                  symbol_count;
	
word                  total_data_size_dm;
	
word                  data_block_count_dm;
	
word                  total_data_size_pm;
	
word                  data_block_count_pm;

} t_dsp_file_header;

typedef struct tag_dsp_memory_block_desc
{
	
word                  alias_memory_block;
	
word                  memory_type;
	
word                  address;
	
word                  size;             /* DSP words */

} t_dsp_memory_block_desc;

typedef struct tag_dsp_segment_desc
{
	
word                  memory_block;
	
word                  attributes;
	
word                  base;
	
word                  size;
	
word                  alignment;        /* ==0 -> no other legal start address than base */

} t_dsp_segment_desc;

typedef struct tag_dsp_symbol_desc
{
	
word                  symbol_id;
	
word                  segment;
	
word                  offset;
	
word                  size;             /* DSP words */

} t_dsp_symbol_desc;

typedef struct tag_dsp_data_block_header
{
	
word                  attributes;
	
word                  segment;
	
word                  offset;
	
word                  size;             /* DSP words */

} t_dsp_data_block_header;

typedef struct tag_dsp_download_desc
{
	
word                  download_id;
	
word                  download_flags;
	
word                  required_processing_power;
	
word                  interface_channel_count;
	
word                  excess_header_size;
	
word                  memory_block_count;
	
word                  segment_count;
	
word                  symbol_count;
	
word                  data_block_count_dm;
	
word                  data_block_count_pm;
	
byte *p_excess_header_data;
	
char *p_download_description;
	
t_dsp_memory_block_desc *p_memory_block_table;
	
t_dsp_segment_desc *p_segment_table;
	
t_dsp_symbol_desc *p_symbol_table;
	
word *p_data_blocks_dm;
	
word *p_data_blocks_pm;

} t_dsp_desc;

typedef struct tag_dsp_portable_download_desc /* be sure to keep native alignment for MAESTRA's */
{
	
word                  download_id;
	
word                  download_flags;
	
word                  required_processing_power;
	
word                  interface_channel_count;
	
word                  excess_header_size;
	
word                  memory_block_count;
	
word                  segment_count;
	
word                  symbol_count;
	
word                  data_block_count_dm;
	
word                  data_block_count_pm;
	
dword                 p_excess_header_data;
	
dword                 p_download_description;
	
dword                 p_memory_block_table;
	
dword                 p_segment_table;
	
dword                 p_symbol_table;
	
dword                 p_data_blocks_dm;
	
dword                 p_data_blocks_pm;

} t_dsp_portable_desc;

#define DSP_DOWNLOAD_INDEX_KERNEL               0

#define DSP30TX_DOWNLOAD_INDEX_KERNEL           1

#define DSP30RX_DOWNLOAD_INDEX_KERNEL           2

#define DSP_MAX_DOWNLOAD_COUNT                  64

#define DSP_DOWNLOAD_MAX_SEGMENTS         16

#define DSP_UDATA_REQUEST_RECONFIGURE     0
/*
  parameters:
  <word> reconfigure delay (in 8kHz samples)
  <word> reconfigure code
  <byte> reconfigure hdlc preamble flags
*/

#define DSP_RECONFIGURE_TX_FLAG           0x8000

#define DSP_RECONFIGURE_SHORT_TRAIN_FLAG  0x4000

#define DSP_RECONFIGURE_ECHO_PROTECT_FLAG 0x2000

#define DSP_RECONFIGURE_HDLC_FLAG         0x1000

#define DSP_RECONFIGURE_SYNC_FLAG         0x0800

#define DSP_RECONFIGURE_PROTOCOL_MASK     0x00ff

#define DSP_RECONFIGURE_IDLE              0

#define DSP_RECONFIGURE_V25               1

#define DSP_RECONFIGURE_V21_CH2           2

#define DSP_RECONFIGURE_V27_2400          3

#define DSP_RECONFIGURE_V27_4800          4

#define DSP_RECONFIGURE_V29_7200          5

#define DSP_RECONFIGURE_V29_9600          6

#define DSP_RECONFIGURE_V33_12000         7

#define DSP_RECONFIGURE_V33_14400         8

#define DSP_RECONFIGURE_V17_7200          9

#define DSP_RECONFIGURE_V17_9600          10

#define DSP_RECONFIGURE_V17_12000         11

#define DSP_RECONFIGURE_V17_14400         12
/*
  data indications if transparent framer
  <byte> data 0
  <byte> data 1
  ...
  data indications if HDLC framer
  <byte> data 0
  <byte> data 1
  ...
  <byte> CRC 0
  <byte> CRC 1
  <byte> preamble flags
*/

#define DSP_UDATA_INDICATION_SYNC         0
/*
  returns:
  <word> time of sync (sampled from counter at 8kHz)
*/

#define DSP_UDATA_INDICATION_DCD_OFF      1
/*
  returns:
  <word> time of DCD off (sampled from counter at 8kHz)
*/

#define DSP_UDATA_INDICATION_DCD_ON       2
/*
  returns:
  <word> time of DCD on (sampled from counter at 8kHz)
  <byte> connected norm
  <word> connected options
  <dword> connected speed (bit/s)
*/

#define DSP_UDATA_INDICATION_CTS_OFF      3
/*
  returns:
  <word> time of CTS off (sampled from counter at 8kHz)
*/

#define DSP_UDATA_INDICATION_CTS_ON       4
/*
  returns:
  <word> time of CTS on (sampled from counter at 8kHz)
  <byte> connected norm
  <word> connected options
  <dword> connected speed (bit/s)
*/

#define DSP_CONNECTED_NORM_UNSPECIFIED      0

#define DSP_CONNECTED_NORM_V21              1

#define DSP_CONNECTED_NORM_V23              2

#define DSP_CONNECTED_NORM_V22              3

#define DSP_CONNECTED_NORM_V22_BIS          4

#define DSP_CONNECTED_NORM_V32_BIS          5

#define DSP_CONNECTED_NORM_V34              6

#define DSP_CONNECTED_NORM_V8               7

#define DSP_CONNECTED_NORM_BELL_212A        8

#define DSP_CONNECTED_NORM_BELL_103         9

#define DSP_CONNECTED_NORM_V29_LEASED_LINE  10

#define DSP_CONNECTED_NORM_V33_LEASED_LINE  11

#define DSP_CONNECTED_NORM_TFAST            12

#define DSP_CONNECTED_NORM_V21_CH2          13

#define DSP_CONNECTED_NORM_V27_TER          14

#define DSP_CONNECTED_NORM_V29              15

#define DSP_CONNECTED_NORM_V33              16

#define DSP_CONNECTED_NORM_V17              17

#define DSP_CONNECTED_OPTION_TRELLIS        0x0001
/*---------------------------------------------------------------------------*/
extern char *dsp_read_file(OsFileHandle *fp,
			   word card_type_number,
			   word *p_dsp_download_count,
			   t_dsp_desc *p_dsp_download_table,
			   t_dsp_portable_desc *p_dsp_portable_download_table);
/*---------------------------------------------------------------------------*/
#endif /* DSP_DEFS_H_ */

Overall Contributors

PersonTokensPropCommitsCommitProp
Armin Schindler82099.03%150.00%
Joe Perches80.97%150.00%
Total828100.00%2100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
Created with cregit.