By using DTV_SET_PROPERTY I can run though a list of possible systems to determine what is supported and what isnt. I havent looked too far but I think it uses delsys to determine this information. Which I can already get from DTV_ENUM_DELSYS. This functionality could be expanded to delmod and delfec. But there is no way to pol modulations or fec using DTV_SET_PROPERTY. I understand there is FE_CAN_*** for modulations and fecs but its far from complete and not very expandable. If we only went on FE_CAN_ for fec we'd be missing about half the supported fec's. Ultimately Id like a solution that would have modulations per system, and fec per modulation as they are quite often different. The delsys/delmod/delfec is a simpler cleaner interface that is adding new functionality and wouldnt be required for drivers or userland to implement if they dont want to as the patch stands (if we implemented DTV_SET_PROPERTY checks against delmod/delfec then it would be required in drivers) So Id love to hear more comments on this subject, it would really be nice to clean some of the inadequacies up, imo userland should have the ability to pol the driver for supported systems/modulation/fec vs just trying everything and seeing what works and what doesnt. Thanks, Chris On Mon, Jul 22, 2013 at 5:21 AM, Mauro Carvalho Chehab <m.chehab@xxxxxxxxxxx> wrote: > Hi Chris, > > Em Fri, 19 Jul 2013 14:27:09 -0600 > Chris Lee <updatelee@xxxxxxxxx> escreveu: > >> In frontend.h we have a struct called dvb_frontend_ops, in there we >> have an element called delsys to show the delivery systems supported >> by the tuner, Id like to propose we add onto that with delmod and >> delfec. >> >> Its not a perfect solution as sometimes a specific modulation or fec >> is only availible on specific systems. But its better then what we >> have now. The struct fe_caps isnt really suited for this, its missing >> many systems, modulations, and fec's. Its just not expandable enough >> to get all the supported sys/mod/fec a tuner supports in there. >> >> Expanding this would allow user land applications to poll the tuner to >> determine more detailed information on the tuners capabilities. >> >> Here is the patch I propose, along with the au8522 driver modified to >> utilize the new elements. Id like to hear comments on it. Does anyone >> see a better way of doing this ? > > We had a discussion some time ago about it. Basically, a device that > it is said to support, let's say, DVB-T, should support all possible > modulations and FECs that are part of the system. > > So, in thesis, there shouldn't be any need to add a list of modulations > and FECs. > > Also, frontends that support multiple delivery systems would need > to enumerate the modulations and FECs after the selection of a given > delivery system (as, typically, they only support a subset of them > for each delsys). > > Ok, practice is different, as there are reverse-engineered drivers > that may not support everything that the hardware supports. Also, > a few hardware may have additional restrictions. > > Yet, on those cases, the userspace may detect if a given modulation > type or FEC is supported, by trying to set it and check if the > operation didn't fail, and if the cache got properly updated. > > So, at the end, it was decided to not add anything like that. > > Yet, it is good to see other opinions. > > It should be said that one of the hard parts of an approach like > that, is that someone would need to dig into each driver and add > the proper support for per-delsys modulation and FECs. > > Alternatively, the core could initialize it to the default value > for each standard, and call some driver-specific function that > would reset the modulation/FECs that aren't supported by some > specific drivers. > > Regards, > Mauro > >> >> Chris Lee <updatelee@xxxxxxxxx> >> >> diff --git a/drivers/media/dvb-core/dvb_frontend.c >> b/drivers/media/dvb-core/dvb_frontend.c >> index 1f925e8..f5df08e 100644 >> --- a/drivers/media/dvb-core/dvb_frontend.c >> +++ b/drivers/media/dvb-core/dvb_frontend.c >> @@ -1036,6 +1036,8 @@ static struct dtv_cmds_h dtv_cmds[DTV_MAX_COMMAND + 1] = { >> _DTV_CMD(DTV_API_VERSION, 0, 0), >> >> _DTV_CMD(DTV_ENUM_DELSYS, 0, 0), >> + _DTV_CMD(DTV_ENUM_DELMOD, 0, 0), >> + _DTV_CMD(DTV_ENUM_DELFEC, 0, 0), >> >> _DTV_CMD(DTV_ATSCMH_PARADE_ID, 1, 0), >> _DTV_CMD(DTV_ATSCMH_RS_FRAME_ENSEMBLE, 1, 0), >> @@ -1285,6 +1287,22 @@ static int dtv_property_process_get(struct >> dvb_frontend *fe, >> } >> tvp->u.buffer.len = ncaps; >> break; >> + case DTV_ENUM_DELMOD: >> + ncaps = 0; >> + while (fe->ops.delmod[ncaps] && ncaps < MAX_DELMOD) { >> + tvp->u.buffer.data[ncaps] = fe->ops.delmod[ncaps]; >> + ncaps++; >> + } >> + tvp->u.buffer.len = ncaps; >> + break; >> + case DTV_ENUM_DELFEC: >> + ncaps = 0; >> + while (fe->ops.delfec[ncaps] && ncaps < MAX_DELFEC) { >> + tvp->u.buffer.data[ncaps] = fe->ops.delfec[ncaps]; >> + ncaps++; >> + } >> + tvp->u.buffer.len = ncaps; >> + break; >> case DTV_FREQUENCY: >> tvp->u.data = c->frequency; >> break; >> diff --git a/drivers/media/dvb-core/dvb_frontend.h >> b/drivers/media/dvb-core/dvb_frontend.h >> index 371b6ca..4e96640 100644 >> --- a/drivers/media/dvb-core/dvb_frontend.h >> +++ b/drivers/media/dvb-core/dvb_frontend.h >> @@ -47,6 +47,8 @@ >> * should be smaller or equal to 32 >> */ >> #define MAX_DELSYS 8 >> +#define MAX_DELMOD 8 >> +#define MAX_DELFEC 32 >> >> struct dvb_frontend_tune_settings { >> int min_delay_ms; >> @@ -263,6 +265,8 @@ struct dvb_frontend_ops { >> struct dvb_frontend_info info; >> >> u8 delsys[MAX_DELSYS]; >> + u8 delmod[MAX_DELMOD]; >> + u8 delfec[MAX_DELFEC]; >> >> void (*release)(struct dvb_frontend* fe); >> void (*release_sec)(struct dvb_frontend* fe); >> diff --git a/include/uapi/linux/dvb/frontend.h >> b/include/uapi/linux/dvb/frontend.h >> index c56d77c..be63d37 100644 >> --- a/include/uapi/linux/dvb/frontend.h >> +++ b/include/uapi/linux/dvb/frontend.h >> @@ -375,7 +375,10 @@ struct dvb_frontend_event { >> #define DTV_STAT_ERROR_BLOCK_COUNT 68 >> #define DTV_STAT_TOTAL_BLOCK_COUNT 69 >> >> -#define DTV_MAX_COMMAND DTV_STAT_TOTAL_BLOCK_COUNT >> +#define DTV_ENUM_DELMOD 70 >> +#define DTV_ENUM_DELFEC 71 >> + >> +#define DTV_MAX_COMMAND DTV_ENUM_DELFEC >> >> typedef enum fe_pilot { >> PILOT_ON, >> diff --git a/drivers/media/dvb-frontends/au8522_dig.c >> b/drivers/media/dvb-frontends/au8522_dig.c >> index 6ee9028..1044c9d 100644 >> --- a/drivers/media/dvb-frontends/au8522_dig.c >> +++ b/drivers/media/dvb-frontends/au8522_dig.c >> @@ -822,7 +822,9 @@ error: >> EXPORT_SYMBOL(au8522_attach); >> >> static struct dvb_frontend_ops au8522_ops = { >> - .delsys = { SYS_ATSC, SYS_DVBC_ANNEX_B }, >> + .delsys = { SYS_DVBC_ANNEX_B, SYS_ATSC }, >> + .delmod = { QAM_256, QAM_64, VSB_8 }, >> + .delfec = { FEC_NONE }, >> .info = { >> .name = "Auvitek AU8522 QAM/8VSB Frontend", >> .frequency_min = 54000000, >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-media" in >> the body of a message to majordomo@xxxxxxxxxxxxxxx >> More majordomo info at http://vger.kernel.org/majordomo-info.html > > > -- > > Cheers, > Mauro -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html