libosmocore 0.3.6
Osmocom core library
GSMTAP

Data Structures

struct  gsmtap_inst
 one gsmtap instance More...

Files

file  gsmtap_util.h
file  gsmtap_util.c

Functions

uint8_t chantype_rsl2gsmtap (uint8_t rsl_chantype, uint8_t link_id)
 convert RSL channel number to GSMTAP channel type
struct msgbgsmtap_makemsg (uint16_t arfcn, uint8_t ts, uint8_t chan_type, uint8_t ss, uint32_t fn, int8_t signal_dbm, uint8_t snr, const uint8_t *data, unsigned int len)
 create L1/L2 data and put it into GSMTAP
static int gsmtap_inst_fd (struct gsmtap_inst *gti)
 obtain the file descriptor associated with a gsmtap instance
int gsmtap_source_init_fd (const char *host, uint16_t port)
 Create a new (sending) GSMTAP source socket.
int gsmtap_source_add_sink_fd (int gsmtap_fd)
 Add a local sink to an existing GSMTAP source and return fd.
struct gsmtap_instgsmtap_source_init (const char *host, uint16_t port, int ofd_wq_mode)
 Open GSMTAP source socket, connect and register osmo_fd.
int gsmtap_source_add_sink (struct gsmtap_inst *gti)
 Add a local sink to an existing GSMTAP source instance.
int gsmtap_sendmsg (struct gsmtap_inst *gti, struct msgb *msg)
 Send a Message buffers through a GSMTAP source.
int gsmtap_send (struct gsmtap_inst *gti, uint16_t arfcn, uint8_t ts, uint8_t chan_type, uint8_t ss, uint32_t fn, int8_t signal_dbm, uint8_t snr, const uint8_t *data, unsigned int len)
 receive a message from L1/L2 and put it in GSMTAP
static int gsmtap_wq_w_cb (struct osmo_fd *ofd, struct msgb *msg)
static int gsmtap_sink_fd_cb (struct osmo_fd *fd, unsigned int flags)

Variables

struct osmo_wqueue gsmtap_inst::wq
 the wait queue
struct osmo_fd gsmtap_inst::sink_ofd
 file descriptor
struct gsmtap_inst __attribute__

Function Documentation

uint8_t chantype_rsl2gsmtap ( uint8_t  rsl_chantype,
uint8_t  link_id 
)

convert RSL channel number to GSMTAP channel type

Parameters:
[in]rsl_cantypeRSL channel type
[in]link_idRSL link identifier
Returns:
GSMTAP channel type
struct msgb * gsmtap_makemsg ( uint16_t  arfcn,
uint8_t  ts,
uint8_t  chan_type,
uint8_t  ss,
uint32_t  fn,
int8_t  signal_dbm,
uint8_t  snr,
const uint8_t *  data,
unsigned int  len 
) [read]

create L1/L2 data and put it into GSMTAP

Parameters:
[in]arfcnGSM ARFCN (Channel Number)
[in]tsGSM time slot
[in]chan_typeChannel Type
[in]ssSub-slot
[in]fnGSM Frame Number
[in]signal_dbmSignal Strength (dBm)
[in]snrSignal/Noise Ratio (SNR)
[in]dataPointer to data buffer
[in]lenLength of data

This function will allocate a new msgb and fill it with a GSMTAP header containing the information

References msgb_alloc(), and msgb_put().

Referenced by gsmtap_send().

int gsmtap_sendmsg ( struct gsmtap_inst gti,
struct msgb msg 
)

Send a Message buffers through a GSMTAP source.

Parameters:
[in]gtiGSMTAP instance
[in]msgbmessage buffer

References msgb::data, gsmtap_inst_fd(), msgb::len, msgb_free(), gsmtap_inst::ofd_wq_mode, osmo_wqueue_enqueue(), and gsmtap_inst::wq.

Referenced by gsmtap_send().

struct gsmtap_inst * gsmtap_source_init ( const char *  host,
uint16_t  port,
int  ofd_wq_mode 
) [read]

Open GSMTAP source socket, connect and register osmo_fd.

Parameters:
[in]hosthost name or IP address in string format
[in]portUDP port number in host byte order
[in]osmo_wq_modeRegister osmo_wqueue (1) or not (0)

Open GSMTAP source (sending) socket, connect it to host/port, allocate 'struct gsmtap_inst' and optionally osmo_fd/osmo_wqueue registration. This means it is like gsmtap_init2 but integrated with libosmocore Select loop abstraction

References osmo_wqueue::bfd, osmo_fd::fd, gsmtap_source_init_fd(), gsmtap_inst::ofd_wq_mode, osmo_fd_register(), osmo_wqueue_init(), gsmtap_inst::sink_ofd, gsmtap_inst::wq, and osmo_wqueue::write_cb.

int gsmtap_source_init_fd ( const char *  host,
uint16_t  port 
)

Create a new (sending) GSMTAP source socket.

Parameters:
[in]hosthost name or IP address in string format
[in]portUDP port number in host byte order

Opens a GSMTAP source (sending) socket, conncet it to host/port and return resulting fd. If host is NULL, the destination address will be localhost. If port is 0, the default GSMTAP_UDP_PORT will be used.

References osmo_sock_init().

Referenced by gsmtap_source_init().