2.4. Digital TV Conditional Access kABI

struct dvb_ca_en50221

Structure describing a CA interface

Definition

struct dvb_ca_en50221 {
  struct module *owner;
  int (*read_attribute_mem)(struct dvb_ca_en50221 *ca, int slot, int address);
  int (*write_attribute_mem)(struct dvb_ca_en50221 *ca, int slot, int address, u8 value);
  int (*read_cam_control)(struct dvb_ca_en50221 *ca, int slot, u8 address);
  int (*write_cam_control)(struct dvb_ca_en50221 *ca, int slot, u8 address, u8 value);
  int (*read_data)(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount);
  int (*write_data)(struct dvb_ca_en50221 *ca, int slot, u8 *ebuf, int ecount);
  int (*slot_reset)(struct dvb_ca_en50221 *ca, int slot);
  int (*slot_shutdown)(struct dvb_ca_en50221 *ca, int slot);
  int (*slot_ts_enable)(struct dvb_ca_en50221 *ca, int slot);
  int (*poll_slot_status)(struct dvb_ca_en50221 *ca, int slot, int open);
  void *data;
  void *private;
};

Members

owner
the module owning this structure
read_attribute_mem
function for reading attribute memory on the CAM
write_attribute_mem
function for writing attribute memory on the CAM
read_cam_control
function for reading the control interface on the CAM
write_cam_control
function for reading the control interface on the CAM
read_data
function for reading data (block mode)
write_data
function for writing data (block mode)
slot_reset
function to reset the CAM slot
slot_shutdown
function to shutdown a CAM slot
slot_ts_enable
function to enable the Transport Stream on a CAM slot
poll_slot_status
function to poll slot status. Only necessary if DVB_CA_FLAG_EN50221_IRQ_CAMCHANGE is not set.
data
private data, used by caller.
private
Opaque data used by the dvb_ca core. Do not modify!

NOTE

the read_*, write_* and poll_slot_status functions will be called for different slots concurrently and need to use locks where and if appropriate. There will be no concurrent access to one slot.

void dvb_ca_en50221_camchange_irq(struct dvb_ca_en50221 *pubca, int slot, int change_type)

A CAMCHANGE IRQ has occurred.

Parameters

struct dvb_ca_en50221 *pubca
CA instance.
int slot
Slot concerned.
int change_type
One of the DVB_CA_CAMCHANGE_* values
void dvb_ca_en50221_camready_irq(struct dvb_ca_en50221 *pubca, int slot)

A CAMREADY IRQ has occurred.

Parameters

struct dvb_ca_en50221 *pubca
CA instance.
int slot
Slot concerned.
void dvb_ca_en50221_frda_irq(struct dvb_ca_en50221 *ca, int slot)

An FR or a DA IRQ has occurred.

Parameters

struct dvb_ca_en50221 *ca
CA instance.
int slot
Slot concerned.
int dvb_ca_en50221_init(struct dvb_adapter *dvb_adapter, struct dvb_ca_en50221 *ca, int flags, int slot_count)

Initialise a new DVB CA device.

Parameters

struct dvb_adapter *dvb_adapter
DVB adapter to attach the new CA device to.
struct dvb_ca_en50221 *ca
The dvb_ca instance.
int flags
Flags describing the CA device (DVB_CA_EN50221_FLAG_*).
int slot_count
Number of slots supported.

Description

return 0 on success, nonzero on failure

void dvb_ca_en50221_release(struct dvb_ca_en50221 *ca)

Release a DVB CA device.

Parameters

struct dvb_ca_en50221 *ca
The associated dvb_ca instance.