v27ter_rx.h File Reference

Go to the source code of this file.

Classes

struct  v27ter_rx_state_t

Defines

#define _V27TER_RX_H_
#define V27TER_EQUALIZER_PRE_LEN   16
#define V27TER_EQUALIZER_POST_LEN   14
#define V27TER_RX_4800_FILTER_STEPS   27
#define V27TER_RX_2400_FILTER_STEPS   27
#define V27TER_RX_FILTER_STEPS   V27TER_RX_2400_FILTER_STEPS

Functions

v27ter_rx_state_tv27ter_rx_init (v27ter_rx_state_t *s, int bit_rate, put_bit_func_t put_bit, void *user_data)
 Initialise a V.27ter modem receive context.
int v27ter_rx_restart (v27ter_rx_state_t *s, int bit_rate, int old_train)
 Reinitialise an existing V.27ter modem receive context.
int v27ter_rx_free (v27ter_rx_state_t *s)
 Free a V.27ter modem receive context.
void v27ter_rx_set_put_bit (v27ter_rx_state_t *s, put_bit_func_t put_bit, void *user_data)
 Change the put_bit function associated with a V.27ter modem receive context.
void v27ter_rx_set_modem_status_handler (v27ter_rx_state_t *s, modem_rx_status_func_t handler, void *user_data)
 Change the modem status report function associated with a V.27ter modem receive context.
int v27ter_rx (v27ter_rx_state_t *s, const int16_t amp[], int len)
 Process a block of received V.27ter modem audio samples.
int v27ter_rx_equalizer_state (v27ter_rx_state_t *s, complexf_t **coeffs)
 Get a snapshot of the current equalizer coefficients.
float v27ter_rx_carrier_frequency (v27ter_rx_state_t *s)
float v27ter_rx_symbol_timing_correction (v27ter_rx_state_t *s)
float v27ter_rx_signal_power (v27ter_rx_state_t *s)
void v27ter_rx_signal_cutoff (v27ter_rx_state_t *s, float cutoff)
void v27ter_rx_set_qam_report_handler (v27ter_rx_state_t *s, qam_report_handler_t handler, void *user_data)


Detailed Description


Function Documentation

int v27ter_rx ( v27ter_rx_state_t s,
const int16_t  amp[],
int  len 
)

float v27ter_rx_carrier_frequency ( v27ter_rx_state_t s  ) 

Get the current received carrier frequency.

Parameters:
s The modem context.
Returns:
The frequency, in Hertz.

References v27ter_rx_state_t::carrier_phase_rate, and dds_frequencyf().

int v27ter_rx_equalizer_state ( v27ter_rx_state_t s,
complexf_t **  coeffs 
)

Get a snapshot of the current equalizer coefficients.

Get a snapshot of the current equalizer coefficients.

Parameters:
coeffs The vector of complex coefficients.
Returns:
The number of coefficients in the vector.

References v27ter_rx_state_t::eq_coeff.

int v27ter_rx_free ( v27ter_rx_state_t s  ) 

Free a V.27ter modem receive context.

Free a V.27ter modem receive context.

Parameters:
s The modem context.
Returns:
0 for OK

v27ter_rx_state_t* v27ter_rx_init ( v27ter_rx_state_t s,
int  bit_rate,
put_bit_func_t  put_bit,
void *  user_data 
)

Initialise a V.27ter modem receive context.

Initialise a V.27ter modem receive context.

Parameters:
s The modem context.
bit_rate The bit rate of the modem. Valid values are 2400 and 4800.
put_bit The callback routine used to put the received data.
user_data An opaque pointer passed to the put_bit routine.
Returns:
A pointer to the modem context, or NULL if there was a problem.

References v27ter_rx_state_t::logging, v27ter_rx_state_t::put_bit, v27ter_rx_state_t::put_bit_user_data, v27ter_rx_restart(), and v27ter_rx_signal_cutoff().

int v27ter_rx_restart ( v27ter_rx_state_t s,
int  bit_rate,
int  old_train 
)

void v27ter_rx_set_modem_status_handler ( v27ter_rx_state_t s,
modem_rx_status_func_t  handler,
void *  user_data 
)

Change the modem status report function associated with a V.27ter modem receive context.

Change the modem status report function associated with a V.27ter modem receive context.

Parameters:
s The modem context.
handler The callback routine used to report modem status changes.
user_data An opaque pointer.

References v27ter_rx_state_t::status_handler, and v27ter_rx_state_t::status_user_data.

void v27ter_rx_set_put_bit ( v27ter_rx_state_t s,
put_bit_func_t  put_bit,
void *  user_data 
)

Change the put_bit function associated with a V.27ter modem receive context.

Change the put_bit function associated with a V.27ter modem receive context.

Parameters:
s The modem context.
put_bit The callback routine used to handle received bits.
user_data An opaque pointer.

References v27ter_rx_state_t::put_bit, and v27ter_rx_state_t::put_bit_user_data.

void v27ter_rx_set_qam_report_handler ( v27ter_rx_state_t s,
qam_report_handler_t  handler,
void *  user_data 
)

Set a handler routine to process QAM status reports

Parameters:
s The modem context.
handler The handler routine.
user_data An opaque pointer passed to the handler routine.

References v27ter_rx_state_t::qam_report, and v27ter_rx_state_t::qam_user_data.

void v27ter_rx_signal_cutoff ( v27ter_rx_state_t s,
float  cutoff 
)

Set the power level at which the carrier detection will cut in

Parameters:
s The modem context.
cutoff The signal cutoff power, in dBm0.

References v27ter_rx_state_t::carrier_off_power, v27ter_rx_state_t::carrier_on_power, and power_meter_level_dbm0().

Referenced by v27ter_rx_init().

float v27ter_rx_signal_power ( v27ter_rx_state_t s  ) 

Get a current received signal power.

Parameters:
s The modem context.
Returns:
The signal power, in dBm0.

References v27ter_rx_state_t::power, and power_meter_current_dbm0().

float v27ter_rx_symbol_timing_correction ( v27ter_rx_state_t s  ) 

Get the current symbol timing correction since startup.

Parameters:
s The modem context.
Returns:
The correction.

References v27ter_rx_state_t::bit_rate, and v27ter_rx_state_t::total_baud_timing_correction.


Generated on Tue Oct 7 20:25:52 2008 for spandsp by  doxygen 1.5.6