diff options
author | Mauro Carvalho Chehab <mchehab@redhat.com> | 2013-03-07 14:34:06 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2013-03-21 06:43:54 -0400 |
commit | a51fea4fdbf1c8151f55029c82f850cbd335ff29 (patch) | |
tree | 401a02e43626a3a26b5c3ca0c500bf6e59d5607a /drivers/media/common | |
parent | 76e41a655ae68b3e0468a3ef497a57415a77b54b (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.c | 46 |
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); |