aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/media/dvb/dvb-core/dvb_frontend.c211
1 files changed, 108 insertions, 103 deletions
diff --git a/drivers/media/dvb/dvb-core/dvb_frontend.c b/drivers/media/dvb/dvb-core/dvb_frontend.c
index e24ebf51f07..4a05a2c61ab 100644
--- a/drivers/media/dvb/dvb-core/dvb_frontend.c
+++ b/drivers/media/dvb/dvb-core/dvb_frontend.c
@@ -858,34 +858,34 @@ static int dvb_frontend_check_parameters(struct dvb_frontend *fe,
858 858
859static int dvb_frontend_clear_cache(struct dvb_frontend *fe) 859static int dvb_frontend_clear_cache(struct dvb_frontend *fe)
860{ 860{
861 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
861 int i; 862 int i;
862 863
863 memset(&(fe->dtv_property_cache), 0, 864 memset(c, 0, sizeof(struct dtv_frontend_properties));
864 sizeof(struct dtv_frontend_properties)); 865
865 866 c->state = DTV_CLEAR;
866 fe->dtv_property_cache.state = DTV_CLEAR; 867 c->delivery_system = SYS_UNDEFINED;
867 fe->dtv_property_cache.delivery_system = SYS_UNDEFINED; 868 c->inversion = INVERSION_AUTO;
868 fe->dtv_property_cache.inversion = INVERSION_AUTO; 869 c->fec_inner = FEC_AUTO;
869 fe->dtv_property_cache.fec_inner = FEC_AUTO; 870 c->transmission_mode = TRANSMISSION_MODE_AUTO;
870 fe->dtv_property_cache.transmission_mode = TRANSMISSION_MODE_AUTO; 871 c->bandwidth_hz = BANDWIDTH_AUTO;
871 fe->dtv_property_cache.bandwidth_hz = BANDWIDTH_AUTO; 872 c->guard_interval = GUARD_INTERVAL_AUTO;
872 fe->dtv_property_cache.guard_interval = GUARD_INTERVAL_AUTO; 873 c->hierarchy = HIERARCHY_AUTO;
873 fe->dtv_property_cache.hierarchy = HIERARCHY_AUTO; 874 c->symbol_rate = QAM_AUTO;
874 fe->dtv_property_cache.symbol_rate = QAM_AUTO; 875 c->code_rate_HP = FEC_AUTO;
875 fe->dtv_property_cache.code_rate_HP = FEC_AUTO; 876 c->code_rate_LP = FEC_AUTO;
876 fe->dtv_property_cache.code_rate_LP = FEC_AUTO; 877
877 878 c->isdbt_partial_reception = -1;
878 fe->dtv_property_cache.isdbt_partial_reception = -1; 879 c->isdbt_sb_mode = -1;
879 fe->dtv_property_cache.isdbt_sb_mode = -1; 880 c->isdbt_sb_subchannel = -1;
880 fe->dtv_property_cache.isdbt_sb_subchannel = -1; 881 c->isdbt_sb_segment_idx = -1;
881 fe->dtv_property_cache.isdbt_sb_segment_idx = -1; 882 c->isdbt_sb_segment_count = -1;
882 fe->dtv_property_cache.isdbt_sb_segment_count = -1; 883 c->isdbt_layer_enabled = 0x7;
883 fe->dtv_property_cache.isdbt_layer_enabled = 0x7;
884 for (i = 0; i < 3; i++) { 884 for (i = 0; i < 3; i++) {
885 fe->dtv_property_cache.layer[i].fec = FEC_AUTO; 885 c->layer[i].fec = FEC_AUTO;
886 fe->dtv_property_cache.layer[i].modulation = QAM_AUTO; 886 c->layer[i].modulation = QAM_AUTO;
887 fe->dtv_property_cache.layer[i].interleaving = -1; 887 c->layer[i].interleaving = -1;
888 fe->dtv_property_cache.layer[i].segment_count = -1; 888 c->layer[i].segment_count = -1;
889 } 889 }
890 890
891 return 0; 891 return 0;
@@ -1194,121 +1194,122 @@ static int dtv_property_process_get(struct dvb_frontend *fe,
1194 struct dtv_property *tvp, 1194 struct dtv_property *tvp,
1195 struct file *file) 1195 struct file *file)
1196{ 1196{
1197 const struct dtv_frontend_properties *c = &fe->dtv_property_cache;
1197 int r; 1198 int r;
1198 1199
1199 switch(tvp->cmd) { 1200 switch(tvp->cmd) {
1200 case DTV_FREQUENCY: 1201 case DTV_FREQUENCY:
1201 tvp->u.data = fe->dtv_property_cache.frequency; 1202 tvp->u.data = c->frequency;
1202 break; 1203 break;
1203 case DTV_MODULATION: 1204 case DTV_MODULATION:
1204 tvp->u.data = fe->dtv_property_cache.modulation; 1205 tvp->u.data = c->modulation;
1205 break; 1206 break;
1206 case DTV_BANDWIDTH_HZ: 1207 case DTV_BANDWIDTH_HZ:
1207 tvp->u.data = fe->dtv_property_cache.bandwidth_hz; 1208 tvp->u.data = c->bandwidth_hz;
1208 break; 1209 break;
1209 case DTV_INVERSION: 1210 case DTV_INVERSION:
1210 tvp->u.data = fe->dtv_property_cache.inversion; 1211 tvp->u.data = c->inversion;
1211 break; 1212 break;
1212 case DTV_SYMBOL_RATE: 1213 case DTV_SYMBOL_RATE:
1213 tvp->u.data = fe->dtv_property_cache.symbol_rate; 1214 tvp->u.data = c->symbol_rate;
1214 break; 1215 break;
1215 case DTV_INNER_FEC: 1216 case DTV_INNER_FEC:
1216 tvp->u.data = fe->dtv_property_cache.fec_inner; 1217 tvp->u.data = c->fec_inner;
1217 break; 1218 break;
1218 case DTV_PILOT: 1219 case DTV_PILOT:
1219 tvp->u.data = fe->dtv_property_cache.pilot; 1220 tvp->u.data = c->pilot;
1220 break; 1221 break;
1221 case DTV_ROLLOFF: 1222 case DTV_ROLLOFF:
1222 tvp->u.data = fe->dtv_property_cache.rolloff; 1223 tvp->u.data = c->rolloff;
1223 break; 1224 break;
1224 case DTV_DELIVERY_SYSTEM: 1225 case DTV_DELIVERY_SYSTEM:
1225 tvp->u.data = fe->dtv_property_cache.delivery_system; 1226 tvp->u.data = c->delivery_system;
1226 break; 1227 break;
1227 case DTV_VOLTAGE: 1228 case DTV_VOLTAGE:
1228 tvp->u.data = fe->dtv_property_cache.voltage; 1229 tvp->u.data = c->voltage;
1229 break; 1230 break;
1230 case DTV_TONE: 1231 case DTV_TONE:
1231 tvp->u.data = fe->dtv_property_cache.sectone; 1232 tvp->u.data = c->sectone;
1232 break; 1233 break;
1233 case DTV_API_VERSION: 1234 case DTV_API_VERSION:
1234 tvp->u.data = (DVB_API_VERSION << 8) | DVB_API_VERSION_MINOR; 1235 tvp->u.data = (DVB_API_VERSION << 8) | DVB_API_VERSION_MINOR;
1235 break; 1236 break;
1236 case DTV_CODE_RATE_HP: 1237 case DTV_CODE_RATE_HP:
1237 tvp->u.data = fe->dtv_property_cache.code_rate_HP; 1238 tvp->u.data = c->code_rate_HP;
1238 break; 1239 break;
1239 case DTV_CODE_RATE_LP: 1240 case DTV_CODE_RATE_LP:
1240 tvp->u.data = fe->dtv_property_cache.code_rate_LP; 1241 tvp->u.data = c->code_rate_LP;
1241 break; 1242 break;
1242 case DTV_GUARD_INTERVAL: 1243 case DTV_GUARD_INTERVAL:
1243 tvp->u.data = fe->dtv_property_cache.guard_interval; 1244 tvp->u.data = c->guard_interval;
1244 break; 1245 break;
1245 case DTV_TRANSMISSION_MODE: 1246 case DTV_TRANSMISSION_MODE:
1246 tvp->u.data = fe->dtv_property_cache.transmission_mode; 1247 tvp->u.data = c->transmission_mode;
1247 break; 1248 break;
1248 case DTV_HIERARCHY: 1249 case DTV_HIERARCHY:
1249 tvp->u.data = fe->dtv_property_cache.hierarchy; 1250 tvp->u.data = c->hierarchy;
1250 break; 1251 break;
1251 1252
1252 /* ISDB-T Support here */ 1253 /* ISDB-T Support here */
1253 case DTV_ISDBT_PARTIAL_RECEPTION: 1254 case DTV_ISDBT_PARTIAL_RECEPTION:
1254 tvp->u.data = fe->dtv_property_cache.isdbt_partial_reception; 1255 tvp->u.data = c->isdbt_partial_reception;
1255 break; 1256 break;
1256 case DTV_ISDBT_SOUND_BROADCASTING: 1257 case DTV_ISDBT_SOUND_BROADCASTING:
1257 tvp->u.data = fe->dtv_property_cache.isdbt_sb_mode; 1258 tvp->u.data = c->isdbt_sb_mode;
1258 break; 1259 break;
1259 case DTV_ISDBT_SB_SUBCHANNEL_ID: 1260 case DTV_ISDBT_SB_SUBCHANNEL_ID:
1260 tvp->u.data = fe->dtv_property_cache.isdbt_sb_subchannel; 1261 tvp->u.data = c->isdbt_sb_subchannel;
1261 break; 1262 break;
1262 case DTV_ISDBT_SB_SEGMENT_IDX: 1263 case DTV_ISDBT_SB_SEGMENT_IDX:
1263 tvp->u.data = fe->dtv_property_cache.isdbt_sb_segment_idx; 1264 tvp->u.data = c->isdbt_sb_segment_idx;
1264 break; 1265 break;
1265 case DTV_ISDBT_SB_SEGMENT_COUNT: 1266 case DTV_ISDBT_SB_SEGMENT_COUNT:
1266 tvp->u.data = fe->dtv_property_cache.isdbt_sb_segment_count; 1267 tvp->u.data = c->isdbt_sb_segment_count;
1267 break; 1268 break;
1268 case DTV_ISDBT_LAYER_ENABLED: 1269 case DTV_ISDBT_LAYER_ENABLED:
1269 tvp->u.data = fe->dtv_property_cache.isdbt_layer_enabled; 1270 tvp->u.data = c->isdbt_layer_enabled;
1270 break; 1271 break;
1271 case DTV_ISDBT_LAYERA_FEC: 1272 case DTV_ISDBT_LAYERA_FEC:
1272 tvp->u.data = fe->dtv_property_cache.layer[0].fec; 1273 tvp->u.data = c->layer[0].fec;
1273 break; 1274 break;
1274 case DTV_ISDBT_LAYERA_MODULATION: 1275 case DTV_ISDBT_LAYERA_MODULATION:
1275 tvp->u.data = fe->dtv_property_cache.layer[0].modulation; 1276 tvp->u.data = c->layer[0].modulation;
1276 break; 1277 break;
1277 case DTV_ISDBT_LAYERA_SEGMENT_COUNT: 1278 case DTV_ISDBT_LAYERA_SEGMENT_COUNT:
1278 tvp->u.data = fe->dtv_property_cache.layer[0].segment_count; 1279 tvp->u.data = c->layer[0].segment_count;
1279 break; 1280 break;
1280 case DTV_ISDBT_LAYERA_TIME_INTERLEAVING: 1281 case DTV_ISDBT_LAYERA_TIME_INTERLEAVING:
1281 tvp->u.data = fe->dtv_property_cache.layer[0].interleaving; 1282 tvp->u.data = c->layer[0].interleaving;
1282 break; 1283 break;
1283 case DTV_ISDBT_LAYERB_FEC: 1284 case DTV_ISDBT_LAYERB_FEC:
1284 tvp->u.data = fe->dtv_property_cache.layer[1].fec; 1285 tvp->u.data = c->layer[1].fec;
1285 break; 1286 break;
1286 case DTV_ISDBT_LAYERB_MODULATION: 1287 case DTV_ISDBT_LAYERB_MODULATION:
1287 tvp->u.data = fe->dtv_property_cache.layer[1].modulation; 1288 tvp->u.data = c->layer[1].modulation;
1288 break; 1289 break;
1289 case DTV_ISDBT_LAYERB_SEGMENT_COUNT: 1290 case DTV_ISDBT_LAYERB_SEGMENT_COUNT:
1290 tvp->u.data = fe->dtv_property_cache.layer[1].segment_count; 1291 tvp->u.data = c->layer[1].segment_count;
1291 break; 1292 break;
1292 case DTV_ISDBT_LAYERB_TIME_INTERLEAVING: 1293 case DTV_ISDBT_LAYERB_TIME_INTERLEAVING:
1293 tvp->u.data = fe->dtv_property_cache.layer[1].interleaving; 1294 tvp->u.data = c->layer[1].interleaving;
1294 break; 1295 break;
1295 case DTV_ISDBT_LAYERC_FEC: 1296 case DTV_ISDBT_LAYERC_FEC:
1296 tvp->u.data = fe->dtv_property_cache.layer[2].fec; 1297 tvp->u.data = c->layer[2].fec;
1297 break; 1298 break;
1298 case DTV_ISDBT_LAYERC_MODULATION: 1299 case DTV_ISDBT_LAYERC_MODULATION:
1299 tvp->u.data = fe->dtv_property_cache.layer[2].modulation; 1300 tvp->u.data = c->layer[2].modulation;
1300 break; 1301 break;
1301 case DTV_ISDBT_LAYERC_SEGMENT_COUNT: 1302 case DTV_ISDBT_LAYERC_SEGMENT_COUNT:
1302 tvp->u.data = fe->dtv_property_cache.layer[2].segment_count; 1303 tvp->u.data = c->layer[2].segment_count;
1303 break; 1304 break;
1304 case DTV_ISDBT_LAYERC_TIME_INTERLEAVING: 1305 case DTV_ISDBT_LAYERC_TIME_INTERLEAVING:
1305 tvp->u.data = fe->dtv_property_cache.layer[2].interleaving; 1306 tvp->u.data = c->layer[2].interleaving;
1306 break; 1307 break;
1307 case DTV_ISDBS_TS_ID: 1308 case DTV_ISDBS_TS_ID:
1308 tvp->u.data = fe->dtv_property_cache.isdbs_ts_id; 1309 tvp->u.data = c->isdbs_ts_id;
1309 break; 1310 break;
1310 case DTV_DVBT2_PLP_ID: 1311 case DTV_DVBT2_PLP_ID:
1311 tvp->u.data = fe->dtv_property_cache.dvbt2_plp_id; 1312 tvp->u.data = c->dvbt2_plp_id;
1312 break; 1313 break;
1313 default: 1314 default:
1314 return -EINVAL; 1315 return -EINVAL;
@@ -1331,6 +1332,7 @@ static int dtv_property_process_set(struct dvb_frontend *fe,
1331 struct file *file) 1332 struct file *file)
1332{ 1333{
1333 int r = 0; 1334 int r = 0;
1335 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
1334 struct dvb_frontend_private *fepriv = fe->frontend_priv; 1336 struct dvb_frontend_private *fepriv = fe->frontend_priv;
1335 dtv_property_dump(tvp); 1337 dtv_property_dump(tvp);
1336 1338
@@ -1354,7 +1356,7 @@ static int dtv_property_process_set(struct dvb_frontend *fe,
1354 * tunerequest so we can pass validation in the FE_SET_FRONTEND 1356 * tunerequest so we can pass validation in the FE_SET_FRONTEND
1355 * ioctl. 1357 * ioctl.
1356 */ 1358 */
1357 fe->dtv_property_cache.state = tvp->cmd; 1359 c->state = tvp->cmd;
1358 dprintk("%s() Finalised property cache\n", __func__); 1360 dprintk("%s() Finalised property cache\n", __func__);
1359 dtv_property_cache_submit(fe); 1361 dtv_property_cache_submit(fe);
1360 1362
@@ -1362,118 +1364,118 @@ static int dtv_property_process_set(struct dvb_frontend *fe,
1362 &fepriv->parameters_in); 1364 &fepriv->parameters_in);
1363 break; 1365 break;
1364 case DTV_FREQUENCY: 1366 case DTV_FREQUENCY:
1365 fe->dtv_property_cache.frequency = tvp->u.data; 1367 c->frequency = tvp->u.data;
1366 break; 1368 break;
1367 case DTV_MODULATION: 1369 case DTV_MODULATION:
1368 fe->dtv_property_cache.modulation = tvp->u.data; 1370 c->modulation = tvp->u.data;
1369 break; 1371 break;
1370 case DTV_BANDWIDTH_HZ: 1372 case DTV_BANDWIDTH_HZ:
1371 fe->dtv_property_cache.bandwidth_hz = tvp->u.data; 1373 c->bandwidth_hz = tvp->u.data;
1372 break; 1374 break;
1373 case DTV_INVERSION: 1375 case DTV_INVERSION:
1374 fe->dtv_property_cache.inversion = tvp->u.data; 1376 c->inversion = tvp->u.data;
1375 break; 1377 break;
1376 case DTV_SYMBOL_RATE: 1378 case DTV_SYMBOL_RATE:
1377 fe->dtv_property_cache.symbol_rate = tvp->u.data; 1379 c->symbol_rate = tvp->u.data;
1378 break; 1380 break;
1379 case DTV_INNER_FEC: 1381 case DTV_INNER_FEC:
1380 fe->dtv_property_cache.fec_inner = tvp->u.data; 1382 c->fec_inner = tvp->u.data;
1381 break; 1383 break;
1382 case DTV_PILOT: 1384 case DTV_PILOT:
1383 fe->dtv_property_cache.pilot = tvp->u.data; 1385 c->pilot = tvp->u.data;
1384 break; 1386 break;
1385 case DTV_ROLLOFF: 1387 case DTV_ROLLOFF:
1386 fe->dtv_property_cache.rolloff = tvp->u.data; 1388 c->rolloff = tvp->u.data;
1387 break; 1389 break;
1388 case DTV_DELIVERY_SYSTEM: 1390 case DTV_DELIVERY_SYSTEM:
1389 fe->dtv_property_cache.delivery_system = tvp->u.data; 1391 c->delivery_system = tvp->u.data;
1390 break; 1392 break;
1391 case DTV_VOLTAGE: 1393 case DTV_VOLTAGE:
1392 fe->dtv_property_cache.voltage = tvp->u.data; 1394 c->voltage = tvp->u.data;
1393 r = dvb_frontend_ioctl_legacy(file, FE_SET_VOLTAGE, 1395 r = dvb_frontend_ioctl_legacy(file, FE_SET_VOLTAGE,
1394 (void *)fe->dtv_property_cache.voltage); 1396 (void *)c->voltage);
1395 break; 1397 break;
1396 case DTV_TONE: 1398 case DTV_TONE:
1397 fe->dtv_property_cache.sectone = tvp->u.data; 1399 c->sectone = tvp->u.data;
1398 r = dvb_frontend_ioctl_legacy(file, FE_SET_TONE, 1400 r = dvb_frontend_ioctl_legacy(file, FE_SET_TONE,
1399 (void *)fe->dtv_property_cache.sectone); 1401 (void *)c->sectone);
1400 break; 1402 break;
1401 case DTV_CODE_RATE_HP: 1403 case DTV_CODE_RATE_HP:
1402 fe->dtv_property_cache.code_rate_HP = tvp->u.data; 1404 c->code_rate_HP = tvp->u.data;
1403 break; 1405 break;
1404 case DTV_CODE_RATE_LP: 1406 case DTV_CODE_RATE_LP:
1405 fe->dtv_property_cache.code_rate_LP = tvp->u.data; 1407 c->code_rate_LP = tvp->u.data;
1406 break; 1408 break;
1407 case DTV_GUARD_INTERVAL: 1409 case DTV_GUARD_INTERVAL:
1408 fe->dtv_property_cache.guard_interval = tvp->u.data; 1410 c->guard_interval = tvp->u.data;
1409 break; 1411 break;
1410 case DTV_TRANSMISSION_MODE: 1412 case DTV_TRANSMISSION_MODE:
1411 fe->dtv_property_cache.transmission_mode = tvp->u.data; 1413 c->transmission_mode = tvp->u.data;
1412 break; 1414 break;
1413 case DTV_HIERARCHY: 1415 case DTV_HIERARCHY:
1414 fe->dtv_property_cache.hierarchy = tvp->u.data; 1416 c->hierarchy = tvp->u.data;
1415 break; 1417 break;
1416 1418
1417 /* ISDB-T Support here */ 1419 /* ISDB-T Support here */
1418 case DTV_ISDBT_PARTIAL_RECEPTION: 1420 case DTV_ISDBT_PARTIAL_RECEPTION:
1419 fe->dtv_property_cache.isdbt_partial_reception = tvp->u.data; 1421 c->isdbt_partial_reception = tvp->u.data;
1420 break; 1422 break;
1421 case DTV_ISDBT_SOUND_BROADCASTING: 1423 case DTV_ISDBT_SOUND_BROADCASTING:
1422 fe->dtv_property_cache.isdbt_sb_mode = tvp->u.data; 1424 c->isdbt_sb_mode = tvp->u.data;
1423 break; 1425 break;
1424 case DTV_ISDBT_SB_SUBCHANNEL_ID: 1426 case DTV_ISDBT_SB_SUBCHANNEL_ID:
1425 fe->dtv_property_cache.isdbt_sb_subchannel = tvp->u.data; 1427 c->isdbt_sb_subchannel = tvp->u.data;
1426 break; 1428 break;
1427 case DTV_ISDBT_SB_SEGMENT_IDX: 1429 case DTV_ISDBT_SB_SEGMENT_IDX:
1428 fe->dtv_property_cache.isdbt_sb_segment_idx = tvp->u.data; 1430 c->isdbt_sb_segment_idx = tvp->u.data;
1429 break; 1431 break;
1430 case DTV_ISDBT_SB_SEGMENT_COUNT: 1432 case DTV_ISDBT_SB_SEGMENT_COUNT:
1431 fe->dtv_property_cache.isdbt_sb_segment_count = tvp->u.data; 1433 c->isdbt_sb_segment_count = tvp->u.data;
1432 break; 1434 break;
1433 case DTV_ISDBT_LAYER_ENABLED: 1435 case DTV_ISDBT_LAYER_ENABLED:
1434 fe->dtv_property_cache.isdbt_layer_enabled = tvp->u.data; 1436 c->isdbt_layer_enabled = tvp->u.data;
1435 break; 1437 break;
1436 case DTV_ISDBT_LAYERA_FEC: 1438 case DTV_ISDBT_LAYERA_FEC:
1437 fe->dtv_property_cache.layer[0].fec = tvp->u.data; 1439 c->layer[0].fec = tvp->u.data;
1438 break; 1440 break;
1439 case DTV_ISDBT_LAYERA_MODULATION: 1441 case DTV_ISDBT_LAYERA_MODULATION:
1440 fe->dtv_property_cache.layer[0].modulation = tvp->u.data; 1442 c->layer[0].modulation = tvp->u.data;
1441 break; 1443 break;
1442 case DTV_ISDBT_LAYERA_SEGMENT_COUNT: 1444 case DTV_ISDBT_LAYERA_SEGMENT_COUNT:
1443 fe->dtv_property_cache.layer[0].segment_count = tvp->u.data; 1445 c->layer[0].segment_count = tvp->u.data;
1444 break; 1446 break;
1445 case DTV_ISDBT_LAYERA_TIME_INTERLEAVING: 1447 case DTV_ISDBT_LAYERA_TIME_INTERLEAVING:
1446 fe->dtv_property_cache.layer[0].interleaving = tvp->u.data; 1448 c->layer[0].interleaving = tvp->u.data;
1447 break; 1449 break;
1448 case DTV_ISDBT_LAYERB_FEC: 1450 case DTV_ISDBT_LAYERB_FEC:
1449 fe->dtv_property_cache.layer[1].fec = tvp->u.data; 1451 c->layer[1].fec = tvp->u.data;
1450 break; 1452 break;
1451 case DTV_ISDBT_LAYERB_MODULATION: 1453 case DTV_ISDBT_LAYERB_MODULATION:
1452 fe->dtv_property_cache.layer[1].modulation = tvp->u.data; 1454 c->layer[1].modulation = tvp->u.data;
1453 break; 1455 break;
1454 case DTV_ISDBT_LAYERB_SEGMENT_COUNT: 1456 case DTV_ISDBT_LAYERB_SEGMENT_COUNT:
1455 fe->dtv_property_cache.layer[1].segment_count = tvp->u.data; 1457 c->layer[1].segment_count = tvp->u.data;
1456 break; 1458 break;
1457 case DTV_ISDBT_LAYERB_TIME_INTERLEAVING: 1459 case DTV_ISDBT_LAYERB_TIME_INTERLEAVING:
1458 fe->dtv_property_cache.layer[1].interleaving = tvp->u.data; 1460 c->layer[1].interleaving = tvp->u.data;
1459 break; 1461 break;
1460 case DTV_ISDBT_LAYERC_FEC: 1462 case DTV_ISDBT_LAYERC_FEC:
1461 fe->dtv_property_cache.layer[2].fec = tvp->u.data; 1463 c->layer[2].fec = tvp->u.data;
1462 break; 1464 break;
1463 case DTV_ISDBT_LAYERC_MODULATION: 1465 case DTV_ISDBT_LAYERC_MODULATION:
1464 fe->dtv_property_cache.layer[2].modulation = tvp->u.data; 1466 c->layer[2].modulation = tvp->u.data;
1465 break; 1467 break;
1466 case DTV_ISDBT_LAYERC_SEGMENT_COUNT: 1468 case DTV_ISDBT_LAYERC_SEGMENT_COUNT:
1467 fe->dtv_property_cache.layer[2].segment_count = tvp->u.data; 1469 c->layer[2].segment_count = tvp->u.data;
1468 break; 1470 break;
1469 case DTV_ISDBT_LAYERC_TIME_INTERLEAVING: 1471 case DTV_ISDBT_LAYERC_TIME_INTERLEAVING:
1470 fe->dtv_property_cache.layer[2].interleaving = tvp->u.data; 1472 c->layer[2].interleaving = tvp->u.data;
1471 break; 1473 break;
1472 case DTV_ISDBS_TS_ID: 1474 case DTV_ISDBS_TS_ID:
1473 fe->dtv_property_cache.isdbs_ts_id = tvp->u.data; 1475 c->isdbs_ts_id = tvp->u.data;
1474 break; 1476 break;
1475 case DTV_DVBT2_PLP_ID: 1477 case DTV_DVBT2_PLP_ID:
1476 fe->dtv_property_cache.dvbt2_plp_id = tvp->u.data; 1478 c->dvbt2_plp_id = tvp->u.data;
1477 break; 1479 break;
1478 default: 1480 default:
1479 return -EINVAL; 1481 return -EINVAL;
@@ -1487,6 +1489,7 @@ static int dvb_frontend_ioctl(struct file *file,
1487{ 1489{
1488 struct dvb_device *dvbdev = file->private_data; 1490 struct dvb_device *dvbdev = file->private_data;
1489 struct dvb_frontend *fe = dvbdev->priv; 1491 struct dvb_frontend *fe = dvbdev->priv;
1492 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
1490 struct dvb_frontend_private *fepriv = fe->frontend_priv; 1493 struct dvb_frontend_private *fepriv = fe->frontend_priv;
1491 int err = -EOPNOTSUPP; 1494 int err = -EOPNOTSUPP;
1492 1495
@@ -1506,7 +1509,7 @@ static int dvb_frontend_ioctl(struct file *file,
1506 if ((cmd == FE_SET_PROPERTY) || (cmd == FE_GET_PROPERTY)) 1509 if ((cmd == FE_SET_PROPERTY) || (cmd == FE_GET_PROPERTY))
1507 err = dvb_frontend_ioctl_properties(file, cmd, parg); 1510 err = dvb_frontend_ioctl_properties(file, cmd, parg);
1508 else { 1511 else {
1509 fe->dtv_property_cache.state = DTV_UNDEFINED; 1512 c->state = DTV_UNDEFINED;
1510 err = dvb_frontend_ioctl_legacy(file, cmd, parg); 1513 err = dvb_frontend_ioctl_legacy(file, cmd, parg);
1511 } 1514 }
1512 1515
@@ -1519,6 +1522,7 @@ static int dvb_frontend_ioctl_properties(struct file *file,
1519{ 1522{
1520 struct dvb_device *dvbdev = file->private_data; 1523 struct dvb_device *dvbdev = file->private_data;
1521 struct dvb_frontend *fe = dvbdev->priv; 1524 struct dvb_frontend *fe = dvbdev->priv;
1525 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
1522 int err = 0; 1526 int err = 0;
1523 1527
1524 struct dtv_properties *tvps = NULL; 1528 struct dtv_properties *tvps = NULL;
@@ -1556,7 +1560,7 @@ static int dvb_frontend_ioctl_properties(struct file *file,
1556 (tvp + i)->result = err; 1560 (tvp + i)->result = err;
1557 } 1561 }
1558 1562
1559 if(fe->dtv_property_cache.state == DTV_TUNE) 1563 if (c->state == DTV_TUNE)
1560 dprintk("%s() Property cache is full, tuning\n", __func__); 1564 dprintk("%s() Property cache is full, tuning\n", __func__);
1561 1565
1562 } else 1566 } else
@@ -1787,9 +1791,10 @@ static int dvb_frontend_ioctl_legacy(struct file *file,
1787 break; 1791 break;
1788 1792
1789 case FE_SET_FRONTEND: { 1793 case FE_SET_FRONTEND: {
1794 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
1790 struct dvb_frontend_tune_settings fetunesettings; 1795 struct dvb_frontend_tune_settings fetunesettings;
1791 1796
1792 if(fe->dtv_property_cache.state == DTV_TUNE) { 1797 if (c->state == DTV_TUNE) {
1793 if (dvb_frontend_check_parameters(fe, &fepriv->parameters_in) < 0) { 1798 if (dvb_frontend_check_parameters(fe, &fepriv->parameters_in) < 0) {
1794 err = -EINVAL; 1799 err = -EINVAL;
1795 break; 1800 break;