diff src/cs/layer1/gtt_include/ctm/diag_deinterleaver.h @ 0:4e78acac3d88

src/{condat,cs,gpf,nucleus}: import from Selenite
author Mychaela Falconia <falcon@freecalypso.org>
date Fri, 16 Oct 2020 06:23:26 +0000
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/cs/layer1/gtt_include/ctm/diag_deinterleaver.h	Fri Oct 16 06:23:26 2020 +0000
@@ -0,0 +1,155 @@
+/*
+
+*******************************************************************************
+
+*
+
+*      COPYRIGHT (C) 2000 BY ERICSSON EUROLAB DEUTSCHLAND GmbH
+
+*      90411 NUERNBERG, GERMANY, Tel Int + 49 911 5217 100
+
+*
+
+*      The program(s) may be used and/or copied only with the
+
+*      written permission from Ericsson or in accordance
+
+*      with the terms and conditions stipulated in the agreement or
+
+*      contract under which the program(s) have been supplied.
+
+*
+
+*******************************************************************************
+
+*
+
+*      File             : diag_interleaver.h
+
+*      Purpose          : diagonal (chain) deinterleaver routine
+
+*
+
+*******************************************************************************
+
+*/
+
+#ifndef diag_deinterleaver_h
+
+#define diag_deinterleaver_h "$Id: $"
+
+#include "l1_confg.h"
+
+/*
+
+*******************************************************************************
+
+*                         INCLUDE FILES
+
+*******************************************************************************
+
+*/
+
+
+
+#include "init_interleaver.h"
+
+
+
+/*
+
+*******************************************************************************
+
+*                         DECLARATION OF PROTOTYPES
+
+*******************************************************************************
+
+*/
+
+
+
+/* ---------------------------------------------------------------------- */
+
+/* diag_deinterleaver:                                                    */
+
+/* Corresponding deinterleaver to diag_interleaver.                       */
+
+/* An arbitrary number of bits can be interleaved, depending of the       */
+
+/* length of the vector "in". The vector "out", which must have the same  */
+
+/* length than "in", contains the interleaved samples.                    */
+
+/* All states (memory etc.) of the interleaver are stored in the variable */
+
+/* *intl_state. Therefore, a pointer to this variable must be handled to  */
+
+/* this function. This variable initially has to be initialized by the    */
+
+/* function init_interleaver, which offers also the possibility to        */
+
+/* specify the dimensions of the deinterleaver matrix.                    */
+
+/* ---------------------------------------------------------------------- */
+
+
+
+void diag_deinterleaver(WORD16 *out,
+
+                        WORD16 *in,
+
+                        WORD16 num_valid_bits,
+
+                        interleaver_state_t *intl_state);
+
+
+
+/* ---------------------------------------------------------------------- */
+
+/* shift_deinterleaver:                                                   */
+
+/* Shift of the deinterleaver buffer by <shift> samples.                  */
+
+/* shift>0  -> shift to the right                                         */
+
+/* shift<0  -> shift to the left                                          */
+
+/* The elements from <insert_bits> are inserted into the resulting space. */
+
+/* The vector <insert_bits> must have at least abs(shift) elements.       */
+
+/* ---------------------------------------------------------------------- */
+
+
+
+void shift_deinterleaver(WORD16 shift,
+
+                         WORD16 *insert_bits,
+
+                         interleaver_state_t *ptr_state);
+
+
+#if(NEW_WKA_PATCH==1)
+  void just_shift(WORD16 shift, WORD16* in_bits, interleaver_state_t *intl_state);
+#endif
+
+#if (TTY_SYNC_MCU == 1)
+  void flush_and_shift_deinterleaver(WORD16 shift,WORD16 *insert_bits,interleaver_state_t *ptr_state);
+#endif
+
+#if(TTY_SYNC_MCU_2==1)
+  WORD16 flush_diag_deint(WORD16 *out, WORD16 *in, interleaver_state_t *intl_state);
+  void zero_pad_deint(interleaver_state_t *intl_state);
+#endif
+
+#if(OPTIMISED==1)
+void new_diag_deinterleaver(WORD16 *out,
+                        WORD16 jump,
+                        WORD16 *flush_vector,
+                        WORD16 *in,
+                        WORD16 num_valid_bits,
+                        interleaver_state_t *intl_state);
+#endif
+
+#endif
+