aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/common
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@redhat.com>2013-03-07 14:34:06 -0500
committerMauro Carvalho Chehab <mchehab@redhat.com>2013-03-21 06:43:54 -0400
commita51fea4fdbf1c8151f55029c82f850cbd335ff29 (patch)
tree401a02e43626a3a26b5c3ca0c500bf6e59d5607a /drivers/media/common
parent76e41a655ae68b3e0468a3ef497a57415a77b54b (diff)
[media] siano: add support for ISDB-T full-seg
Fix the DVBv5 API handling for ISDB-T and add support for 13 segments. Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/common')
-rw-r--r--drivers/media/common/siano/smsdvb.c46
1 files changed, 17 insertions, 29 deletions
diff --git a/drivers/media/common/siano/smsdvb.c b/drivers/media/common/siano/smsdvb.c
index f4fd6703c49e..4900aa9e8b7a 100644
--- a/drivers/media/common/siano/smsdvb.c
+++ b/drivers/media/common/siano/smsdvb.c
@@ -652,6 +652,9 @@ static int smsdvb_isdbt_set_frontend(struct dvb_frontend *fe)
652 struct dtv_frontend_properties *c = &fe->dtv_property_cache; 652 struct dtv_frontend_properties *c = &fe->dtv_property_cache;
653 struct smsdvb_client_t *client = 653 struct smsdvb_client_t *client =
654 container_of(fe, struct smsdvb_client_t, frontend); 654 container_of(fe, struct smsdvb_client_t, frontend);
655 int board_id = smscore_get_board_id(client->coredev);
656 struct sms_board *board = sms_get_board(board_id);
657 enum sms_device_type_st type = board->type;
655 658
656 struct { 659 struct {
657 struct SmsMsgHdr_ST Msg; 660 struct SmsMsgHdr_ST Msg;
@@ -669,40 +672,25 @@ static int smsdvb_isdbt_set_frontend(struct dvb_frontend *fe)
669 if (c->isdbt_sb_segment_idx == -1) 672 if (c->isdbt_sb_segment_idx == -1)
670 c->isdbt_sb_segment_idx = 0; 673 c->isdbt_sb_segment_idx = 0;
671 674
672 switch (c->isdbt_sb_segment_count) { 675 if (!c->isdbt_layer_enabled)
673 case 3: 676 c->isdbt_layer_enabled = 7;
674 Msg.Data[1] = BW_ISDBT_3SEG;
675 break;
676 case 1:
677 Msg.Data[1] = BW_ISDBT_1SEG;
678 break;
679 case 0: /* AUTO */
680 switch (c->bandwidth_hz / 1000000) {
681 case 8:
682 case 7:
683 c->isdbt_sb_segment_count = 3;
684 Msg.Data[1] = BW_ISDBT_3SEG;
685 break;
686 case 6:
687 c->isdbt_sb_segment_count = 1;
688 Msg.Data[1] = BW_ISDBT_1SEG;
689 break;
690 default: /* Assumes 6 MHZ bw */
691 c->isdbt_sb_segment_count = 1;
692 c->bandwidth_hz = 6000;
693 Msg.Data[1] = BW_ISDBT_1SEG;
694 break;
695 }
696 break;
697 default:
698 sms_info("Segment count %d not supported", c->isdbt_sb_segment_count);
699 return -EINVAL;
700 }
701 677
702 Msg.Data[0] = c->frequency; 678 Msg.Data[0] = c->frequency;
679 Msg.Data[1] = BW_ISDBT_1SEG;
703 Msg.Data[2] = 12000000; 680 Msg.Data[2] = 12000000;
704 Msg.Data[3] = c->isdbt_sb_segment_idx; 681 Msg.Data[3] = c->isdbt_sb_segment_idx;
705 682
683 if (c->isdbt_partial_reception) {
684 if ((type == SMS_PELE || type == SMS_RIO) &&
685 c->isdbt_sb_segment_count > 3)
686 Msg.Data[1] = BW_ISDBT_13SEG;
687 else if (c->isdbt_sb_segment_count > 1)
688 Msg.Data[1] = BW_ISDBT_3SEG;
689 } else if (type == SMS_PELE || type == SMS_RIO)
690 Msg.Data[1] = BW_ISDBT_13SEG;
691
692 c->bandwidth_hz = 6000000;
693
706 sms_info("%s: freq %d segwidth %d segindex %d\n", __func__, 694 sms_info("%s: freq %d segwidth %d segindex %d\n", __func__,
707 c->frequency, c->isdbt_sb_segment_count, 695 c->frequency, c->isdbt_sb_segment_count,
708 c->isdbt_sb_segment_idx); 696 c->isdbt_sb_segment_idx);