> > Their design for high precision readings is just flawless! > > > > I need some time to get ideas so as to start with buffer support. > > > > But what kind of buffer support should be used ? > > sysfs trigger using scan_elements ? > > > > There are no interrupt supported by the sensor! And I don't know > > how hrtimer would work. > > Is it possible to poll for new data? I.e. is there an explicit > way of telling you are looking at a complete set of different data > from what you got on the previous reading? Yes, we have such facility: 5.3.5.1 New data status The measured data are stored into the output data registers at the end of each TPHG conversion phase along with status flags and index of measurement. register addr bit pos description meas_status_0 0x1D new_data_0<7> New data flag And why do you ask ? > It is unusual, but we do have a few other drivers where this is > necessary and some interesting dances to ensure they lock as closely > as possible with the actual sampling frequencies. The various problems for buffer support that I can see are: o The press, temp have 20(8+8+4) bits resolution but humidity has 16 bits. And then gas is 10 bits resolution(8 MSB + 2 LSB). o Non-linear addressing: decimal BME680_REG_TEMP_MSB 0x22 34 BME680_REG_PRESS_MSB 0x1F 31 BM6880_REG_HUMIDITY_MSB 0x25 37 BME680_REG_GAS_MSB 0x2A 42 Otherwise we could do large bulk read and push to buffer. o Every time setting FORCED MODE to trigger measurement but then looking at the following from BSEC makes me wonder: /* When the measurement is completed and data is ready for reading, the sensor must be in BME680_SLEEP_MODE. * Read operation mode to check whether measurement is completely done and wait until the sensor is no more * in BME680_FORCED_MODE. */ while (bme680_g.power_mode == BME680_FORCED_MODE) { /* sleep for 5 ms */ sleep(5); bme680_status = bme680_get_sensor_mode(&bme680_g); } Clearly, you wouldn't want this in interrupt handler, so we will overwrite mode irrespective of current mode and avoid those checks. o And lastly compensation functions, we wouldn't pass raw values and instead processed instead. Isn't ? So, now I see all these reading, setting config, checking bits, processing and finally pushing in an interrupt handler. Is this what shall be done ? I'm asking too many questions because I don't want to waste my time doing wrong and getting a NACK in the end. Also, I have another huge project currently to focus by Linux Foundation. But I'm happy to review and test patches anytime. > > Another question arises, say for eg., we use sysfs trigger and buffer > > capture comes in action: > > > > * Would I enable FORCED mode everytime in the trigger interrupt handler ? > > * Also check for config setting(such as oversampling) and set > > them accordingly in the interrupt handler ? > > > > If no, then other suggestion ? > > If yes, isn't that bad to do all that in "bottom half" ? > > The bottom half in this case is an interrupt thread so you can do what > ever you like in it. Hmm. OK I have a different vision for top/bottom half. > > I thought of preenable, but it works only 'once' prior to enabling but > > we need to set mode every time! > > Sounds like that might be necessary. I haven't read the datasheet > for a while and as you say it isn't always that informative! Yes, it is for the current revision. > > > It's nice to see this driver progressing. Keep up the good work! > > > > Thanks! Would need your help with its development. > > > > Indeed good to see this continue to move forwards. Well, as soon I saw BSEC, I realised I've done nothing and people would prefer BSEC. But on the other hand, I was contacted by one Croatian developer who is backporting my driver to the their kernel since they are stuck with 4.14 and the product is already in assembly stage. David also has a similar issue. -- Himanshu Jha Undergraduate Student Department of Electronics & Communication Guru Tegh Bahadur Institute of Technology