|  | /* SPDX-License-Identifier: GPL-2.0-or-later */ | 
|  | /* | 
|  | * CIMaX SP2/HF CI driver | 
|  | * | 
|  | * Copyright (C) 2014 Olli Salonen <olli.salonen@iki.fi> | 
|  | */ | 
|  |  | 
|  | #ifndef SP2_H | 
|  | #define SP2_H | 
|  |  | 
|  | #include <media/dvb_ca_en50221.h> | 
|  |  | 
|  | /* | 
|  | * I2C address | 
|  | * 0x40 (port 0) | 
|  | * 0x41 (port 1) | 
|  | */ | 
|  | struct sp2_config { | 
|  | /* dvb_adapter to attach the ci to */ | 
|  | struct dvb_adapter *dvb_adap; | 
|  |  | 
|  | /* function ci_control handles the device specific ci ops */ | 
|  | void *ci_control; | 
|  |  | 
|  | /* priv is passed back to function ci_control */ | 
|  | void *priv; | 
|  | }; | 
|  |  | 
|  | extern int sp2_ci_read_attribute_mem(struct dvb_ca_en50221 *en50221, | 
|  | int slot, int addr); | 
|  | extern int sp2_ci_write_attribute_mem(struct dvb_ca_en50221 *en50221, | 
|  | int slot, int addr, u8 data); | 
|  | extern int sp2_ci_read_cam_control(struct dvb_ca_en50221 *en50221, | 
|  | int slot, u8 addr); | 
|  | extern int sp2_ci_write_cam_control(struct dvb_ca_en50221 *en50221, | 
|  | int slot, u8 addr, u8 data); | 
|  | extern int sp2_ci_slot_reset(struct dvb_ca_en50221 *en50221, int slot); | 
|  | extern int sp2_ci_slot_shutdown(struct dvb_ca_en50221 *en50221, int slot); | 
|  | extern int sp2_ci_slot_ts_enable(struct dvb_ca_en50221 *en50221, int slot); | 
|  | extern int sp2_ci_poll_slot_status(struct dvb_ca_en50221 *en50221, | 
|  | int slot, int open); | 
|  |  | 
|  | #endif |