libspandsp 0.0.4

v42.c File Reference

#include <stdio.h>
#include <stdlib.h>
#include <inttypes.h>
#include <string.h>
#include <errno.h>
#include "spandsp/telephony.h"
#include "spandsp/logging.h"
#include "spandsp/async.h"
#include "spandsp/hdlc.h"
#include "spandsp/schedule.h"
#include "spandsp/queue.h"
#include "spandsp/v42.h"

Defines

#define FALSE   0
#define TRUE   (!FALSE)
#define LAPM_FRAMETYPE_MASK   0x03
#define LAPM_FRAMETYPE_I   0x00
#define LAPM_FRAMETYPE_I_ALT   0x02
#define LAPM_FRAMETYPE_S   0x01
#define LAPM_FRAMETYPE_U   0x03
#define T_WAIT_MIN   2000
#define T_WAIT_MAX   10000
#define T_400   750000
#define T_401   1000000
#define T_402   1000000
#define T_403   10000000
#define N_400   3
#define N_401   128
#define LAPM_DLCI_DTE_TO_DTE   0
#define LAPM_DLCI_LAYER2_MANAGEMENT   63

Functions

void lapm_reset (lapm_state_t *s)
void lapm_restart (lapm_state_t *s)
const char * lapm_status_to_str (int status)
int lapm_tx (lapm_state_t *s, const void *buf, int len)
int lapm_release (lapm_state_t *s)
int lapm_loopback (lapm_state_t *s, int enable)
int lapm_break (lapm_state_t *s, int enable)
int lapm_tx_iframe (lapm_state_t *s, const void *buf, int len, int cr)
void lapm_dump (lapm_state_t *s, const uint8_t *frame, int len, int showraw, int txrx)
void lapm_receive (void *user_data, const uint8_t *frame, int len, int ok)
void v42_rx_bit (void *user_data, int bit)
int v42_tx_bit (void *user_data)
void v42_set_status_callback (v42_state_t *s, v42_status_func_t callback, void *user_data)
void v42_restart (v42_state_t *s)
v42_state_tv42_init (v42_state_t *s, int caller, int detect, v42_frame_handler_t frame_handler, void *user_data)
int v42_release (v42_state_t *s)

Detailed Description


Function Documentation

int lapm_break ( lapm_state_t s,
int  enable 
)

Send a break over a LAP.M connection

void lapm_dump ( lapm_state_t s,
const uint8_t *  frame,
int  len,
int  showraw,
int  txrx 
)

Dump LAP.M frames in a raw and/or decoded forms

Parameters:
frameThe frame itself
lenThe length of the frame, in octets
showrawTRUE if the raw octets should be dumped
txrxTRUE if tx, FALSE if rx. Used to highlight the packet's direction.

References lapm_state_t::logging, span_log(), and span_log_buf().

Referenced by lapm_receive().

int lapm_loopback ( lapm_state_t s,
int  enable 
)

Enable or disable loopback of a LAP.M connection

int lapm_release ( lapm_state_t s)

Initiate an orderly release of a LAP.M connection

int lapm_tx ( lapm_state_t s,
const void *  buf,
int  len 
)

Transmit a LAP.M frame

References queue_write().

v42_state_t* v42_init ( v42_state_t s,
int  caller,
int  detect,
v42_frame_handler_t  frame_handler,
void *  user_data 
)

Initialise a V.42 context.

Parameters:
sThe V.42 context.
callerTRUE if caller mode, else answerer mode.
frame_handlerA callback function to handle received frames of data.
user_dataAn opaque pointer passed to the frame handler routine.
Returns:
???

References v42_state_t::caller, v42_state_t::detect, v42_state_t::lapm, v42_state_t::logging, queue_init(), lapm_state_t::t401_timer, lapm_state_t::t402_timer, lapm_state_t::t403_timer, and v42_restart().

int v42_release ( v42_state_t s)

Release a V.42 context.

Parameters:
sThe V.42 context.
Returns:
0 if OK
void v42_restart ( v42_state_t s)
void v42_rx_bit ( void *  user_data,
int  bit 
)

Process a newly received bit for a V.42 context.

References hdlc_rx_put_bit(), and v42_state_t::lapm.

void v42_set_status_callback ( v42_state_t s,
v42_status_func_t  callback,
void *  user_data 
)

Assign or remove a callback routine used to deal with V.42 status changes.

References v42_state_t::lapm.

int v42_tx_bit ( void *  user_data)

Get the next transmit bit for a V.42 context.

References hdlc_tx_get_bit(), and v42_state_t::lapm.