FXLS8471Q - FIFO Fill mode example code

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 
已解决

FXLS8471Q - FIFO Fill mode example code

跳至解决方案
2,074 次查看
andrewneil
Contributor III

here:

https://community.nxp.com/t5/Sensors-Knowledge-Base/FXLS8471Q-FIFO-Fill-mode-example-code/ta-p/11080... 

by @TomasVaverka 

In the first code block, I think the comment against CTRL_REG4 is wrong (or, at least, misleading):

 

 

void FXLS8471Q_Init (void)
{
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x00); // Standby mode
  FXLS8471Q_WriteRegister(F_SETUP_REG, 0xA0); // FIFO Fill mode, 32 samples
  FXLS8471Q_WriteRegister(CTRL_REG4,   0x40); // Enable FIFO interrupt, push-pull, active low
  FXLS8471Q_WriteRegister(CTRL_REG5,   0x40); // Route the FIFO interrupt to INT1 - PTA5   
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x19); // ODR = 100Hz, Active mode
}

 

 

According to the datasheet, CTRL_REG4 contains only interrupt enable bits - not push-pull or active-low controls.

The push-pull and active-low controls are in CTRL_REG3  (the defaults are push-pull & active-low).

 

 

 

0 项奖励
1 解答
2,056 次查看
TomasVaverka
NXP TechSupport
NXP TechSupport

Hello Andrew,

Thank you again for your feedback, you are right, both the output mode (push-pull vs. open-drain) and polarity (active low vs. high) are configurable using bits pp_od and ipol in the CTRL_REG3 register.

I have updated the FXLS8471Q_Init function to make this clear.

void FXLS8471Q_Init (void)
{
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x00); // Standby mode
  FXLS8471Q_WriteRegister(F_SETUP_REG, 0xA0); // FIFO Fill mode, 32 samples
  FXLS8471Q_WriteRegister(CTRL_REG3,   0x00); // Push-pull, active low interrupt
  FXLS8471Q_WriteRegister(CTRL_REG4,   0x40); // Enable FIFO interrupt
  FXLS8471Q_WriteRegister(CTRL_REG5,   0x40); // Route the FIFO interrupt to INT1 - PTA5   
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x19); // ODR = 100Hz, Active mode
}

 

BR, Tomas

在原帖中查看解决方案

2 回复数
2,057 次查看
TomasVaverka
NXP TechSupport
NXP TechSupport

Hello Andrew,

Thank you again for your feedback, you are right, both the output mode (push-pull vs. open-drain) and polarity (active low vs. high) are configurable using bits pp_od and ipol in the CTRL_REG3 register.

I have updated the FXLS8471Q_Init function to make this clear.

void FXLS8471Q_Init (void)
{
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x00); // Standby mode
  FXLS8471Q_WriteRegister(F_SETUP_REG, 0xA0); // FIFO Fill mode, 32 samples
  FXLS8471Q_WriteRegister(CTRL_REG3,   0x00); // Push-pull, active low interrupt
  FXLS8471Q_WriteRegister(CTRL_REG4,   0x40); // Enable FIFO interrupt
  FXLS8471Q_WriteRegister(CTRL_REG5,   0x40); // Route the FIFO interrupt to INT1 - PTA5   
  FXLS8471Q_WriteRegister(CTRL_REG1,   0x19); // ODR = 100Hz, Active mode
}

 

BR, Tomas

2,050 次查看
andrewneil
Contributor III

Thanks.

It would be useful to have some samples like this for the FXLS896xAF, please ...

0 项奖励
%3CLINGO-SUB%20id%3D%22lingo-sub-1817711%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3EFXLS8471Q%20-%20FIFO%20%E5%A1%AB%E5%85%85%E6%A8%A1%E5%BC%8F%E7%A4%BA%E4%BE%8B%E4%BB%A3%E7%A0%81%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1817711%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E8%BF%99%E9%87%8C%EF%BC%9A%3C%2FP%3E%3CP%3E%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2FSensors-Knowledge-Base%2FFXLS8471Q-FIFO-Fill-mode-example-code%2Fta-p%2F1108021%22%20target%3D%22_blank%22%3Ehttps%3A%2F%2Fcommunity.nxp.com%2Ft5%2FSensors-Knowledge-Base%2FFXLS8471Q-FIFO-Fill-mode-example-code%2Fta-p%2F1108021%3C%2FA%3E%20%3C%2FP%3E%3CP%3E%E4%BD%9C%E8%80%85%EF%BC%9A%3CA%20href%3D%22https%3A%2F%2Fcommunity.nxp.com%2Ft5%2Fuser%2Fviewprofilepage%2Fuser-id%2F12216%22%20target%3D%22_blank%22%3E%40TomasVaverka%3C%2FA%3E%3C%2FP%3E%3CP%3E%E5%9C%A8%E7%AC%AC%E4%B8%80%E4%B8%AA%E4%BB%A3%E7%A0%81%E5%9D%97%E4%B8%AD%EF%BC%8C%E6%88%91%E8%AE%A4%E4%B8%BA%E9%92%88%E5%AF%B9%20CTRL_REG4%20%E7%9A%84%E6%B3%A8%E9%87%8A%E6%98%AF%E9%94%99%E8%AF%AF%E7%9A%84%EF%BC%88%E6%88%96%E8%80%85%E8%87%B3%E5%B0%91%E6%98%AF%E8%AF%AF%E5%AF%BC%E6%80%A7%E7%9A%84%EF%BC%89%EF%BC%9A%3C%2FP%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3CPRE%20class%3D%22lia-code-sample%20language-c%22%3E%3CCODE%20translate%3D%22no%22%3Evoid%20FXLS8471Q_Init%20(void)%0A%7B%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG1%2C%20%20%200x00)%3B%20%2F%2F%20Standby%20mode%0A%20%20FXLS8471Q_WriteRegister(F_SETUP_REG%2C%200xA0)%3B%20%2F%2F%20FIFO%20Fill%20mode%2C%2032%20samples%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG4%2C%20%20%200x40)%3B%20%2F%2F%20Enable%20FIFO%20interrupt%2C%20push-pull%2C%20active%20low%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG5%2C%20%20%200x40)%3B%20%2F%2F%20Route%20the%20FIFO%20interrupt%20to%20INT1%20-%20PTA5%20%20%20%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG1%2C%20%20%200x19)%3B%20%2F%2F%20ODR%20%3D%20100Hz%2C%20Active%20mode%0A%7D%3C%2FCODE%3E%3C%2FPRE%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3CP%3E%E6%A0%B9%E6%8D%AE%E6%95%B0%E6%8D%AE%E6%89%8B%E5%86%8C%EF%BC%8C%3CSTRONG%3ECTRL%3C%2FSTRONG%3E_REG4%20%E4%BB%85%E5%8C%85%E5%90%AB%E4%B8%AD%E6%96%AD%E4%BD%BF%E8%83%BD%E4%BD%8D%EF%BC%8C%E4%B8%8D%E5%8C%85%E5%90%AB%E6%8E%A8%E6%8C%BD%E6%88%96%E4%BD%8E%E7%94%B5%E5%B9%B3%E6%8E%A7%E5%88%B6%E3%80%82%3C%2FP%3E%3CP%3E%E6%8E%A8%E6%8C%BD%E5%92%8C%E4%BD%8E%E7%94%B5%E5%B9%B3%E6%9C%89%E6%95%88%E6%8E%A7%E5%88%B6%E5%9C%A8%3CSTRONG%3ECTRL_REG3%3C%2FSTRONG%3E%E4%B8%AD%EF%BC%88%E9%BB%98%E8%AE%A4%E5%80%BC%E4%B8%BA%E6%8E%A8%E6%8C%BD%26amp%3B%20%E4%BD%8E%E7%94%B5%E5%B9%B3%E6%9C%89%E6%95%88%EF%BC%89%E3%80%82%3C%2FP%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3CBR%20%2F%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1818662%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20FXLS8471Q%20%20-%20FIFO%20Fill%20mode%20example%20code%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1818662%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E8%B0%A2%E8%B0%A2%E3%80%82%3C%2FP%3E%3CP%3E%E5%A6%82%E6%9E%9C%E8%83%BD%E4%B8%BA%20FXLS896xAF%20%E6%8F%90%E4%BE%9B%E4%B8%80%E4%BA%9B%E8%BF%99%E6%A0%B7%E7%9A%84%E6%A0%B7%E6%9C%AC%EF%BC%8C%E5%B0%86%E9%9D%9E%E5%B8%B8%E6%9C%89%E7%94%A8%EF%BC%8C%E8%B0%A2%E8%B0%A2...%3C%2FP%3E%3C%2FLINGO-BODY%3E%3CLINGO-SUB%20id%3D%22lingo-sub-1818491%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%20translate%3D%22no%22%3ERe%3A%20FXLS8471Q%20%20-%20FIFO%20Fill%20mode%20example%20code%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1818491%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E4%BD%A0%E5%A5%BD%EF%BC%8C%E5%AE%89%E5%BE%B7%E9%B2%81%E3%80%81%3C%2FP%3E%0A%3CP%3E%E5%86%8D%E6%AC%A1%E6%84%9F%E8%B0%A2%E6%82%A8%E7%9A%84%E5%8F%8D%E9%A6%88%EF%BC%8C%E6%82%A8%E8%AF%B4%E5%BE%97%E6%B2%A1%E9%94%99%EF%BC%8C%E8%BE%93%E5%87%BA%E6%A8%A1%E5%BC%8F%EF%BC%88%E6%8E%A8%E6%8C%BD%E4%B8%8E%E5%BC%80%E6%BC%8F%EF%BC%89%E5%92%8C%E6%9E%81%E6%80%A7%EF%BC%88%E4%BD%8E%E7%94%B5%E5%B9%B3%E6%9C%89%E6%95%88%E4%B8%8E%E9%AB%98%E7%94%B5%E5%B9%B3%E6%9C%89%E6%95%88%EF%BC%89%E9%83%BD%E5%8F%AF%E4%BB%A5%E9%80%9A%E8%BF%87%20CTRL_REG3%20%E5%AF%84%E5%AD%98%E5%99%A8%E4%B8%AD%E7%9A%84%20pp_od%20%E5%92%8C%20ipol%20%E4%BD%8D%E8%BF%9B%E8%A1%8C%E9%85%8D%E7%BD%AE%E3%80%82%3C%2FP%3E%0A%3CP%3E%E6%88%91%E5%B7%B2%E7%BB%8F%E6%9B%B4%E6%96%B0%E4%BA%86%20FXLS8471Q_Init%20%E5%87%BD%E6%95%B0%EF%BC%8C%E4%BB%A5%E6%98%8E%E7%A1%AE%E8%BF%99%E4%B8%80%E7%82%B9%E3%80%82%3C%2FP%3E%0A%3CPRE%20class%3D%22lia-code-sample%20language-c%22%3E%3CCODE%20translate%3D%22no%22%3Evoid%20FXLS8471Q_Init%20(void)%0A%7B%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG1%2C%20%20%200x00)%3B%20%2F%2F%20Standby%20mode%0A%20%20FXLS8471Q_WriteRegister(F_SETUP_REG%2C%200xA0)%3B%20%2F%2F%20FIFO%20Fill%20mode%2C%2032%20samples%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG3%2C%20%20%200x00)%3B%20%2F%2F%20Push-pull%2C%20active%20low%20interrupt%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG4%2C%20%20%200x40)%3B%20%2F%2F%20Enable%20FIFO%20interrupt%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG5%2C%20%20%200x40)%3B%20%2F%2F%20Route%20the%20FIFO%20interrupt%20to%20INT1%20-%20PTA5%20%20%20%0A%20%20FXLS8471Q_WriteRegister(CTRL_REG1%2C%20%20%200x19)%3B%20%2F%2F%20ODR%20%3D%20100Hz%2C%20Active%20mode%0A%7D%0A%3C%2FCODE%3E%3C%2FPRE%3E%0A%3CBR%20%2F%3E%0A%3CP%3EBR%2C%20Tomas%3C%2FP%3E%3C%2FLINGO-BODY%3E