FXLS8471Q - FIFO Fill mode example code

キャンセル
次の結果を表示 
表示  限定  | 次の代わりに検索 
もしかして: 

FXLS8471Q - FIFO Fill mode example code

ソリューションへジャンプ
1,928件の閲覧回数
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 解決策
1,910件の閲覧回数
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 返答(返信)
1,911件の閲覧回数
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

1,904件の閲覧回数
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%E3%83%95%E3%82%A3%E3%83%AB%E3%83%A2%E3%83%BC%E3%83%89%E3%81%AE%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%82%B3%E3%83%BC%E3%83%89%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1817711%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%3CP%3E%E3%81%93%E3%81%93%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%3C%2FP%3E%3CP%3E%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%E3%82%88%E3%82%8A%3C%2FP%3E%3CP%3E%E6%9C%80%E5%88%9D%E3%81%AE%E3%82%B3%E3%83%BC%E3%83%89%20%E3%83%96%E3%83%AD%E3%83%83%E3%82%AF%E3%81%A7%E3%81%AF%E3%80%81CTRL_REG4%20%E3%81%AB%E5%AF%BE%E3%81%99%E3%82%8B%E3%82%B3%E3%83%A1%E3%83%B3%E3%83%88%E3%81%8C%E9%96%93%E9%81%95%E3%81%A3%E3%81%A6%E3%81%84%E3%82%8B%20(%E3%81%BE%E3%81%9F%E3%81%AF%E5%B0%91%E3%81%AA%E3%81%8F%E3%81%A8%E3%82%82%E8%AA%A4%E8%A7%A3%E3%82%92%E6%8B%9B%E3%81%8F)%20%E3%81%A8%E6%80%9D%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%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%E3%83%87%E3%83%BC%E3%82%BF%E3%82%B7%E3%83%BC%E3%83%88%E3%81%AB%E3%82%88%E3%82%8B%E3%81%A8%E3%80%81CTRL_REG%20%3CSTRONG%3E4%3C%2FSTRONG%3E%E3%81%AB%E3%81%AF%E5%89%B2%E3%82%8A%E8%BE%BC%E3%81%BF%E6%9C%89%E5%8A%B9%E5%8C%96%E3%83%93%E3%83%83%E3%83%88%E3%81%AE%E3%81%BF%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%A6%E3%81%8A%E3%82%8A%E3%80%81%E3%83%97%E3%83%83%E3%82%B7%E3%83%A5%E3%83%97%E3%83%AB%E3%82%84%E3%82%A2%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%20%E3%83%AD%E3%83%BC%E5%88%B6%E5%BE%A1%E3%81%AF%E5%90%AB%E3%81%BE%E3%82%8C%E3%81%A6%E3%81%84%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82%3C%2FP%3E%3CP%3E%E3%83%97%E3%83%83%E3%82%B7%E3%83%A5%20%E3%83%97%E3%83%AB%E3%81%8A%E3%82%88%E3%81%B3%E3%82%A2%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%20%E3%83%AD%E3%83%BC%E3%81%AE%E5%88%B6%E5%BE%A1%E3%81%AF%20CTRL_REG%20%3CSTRONG%3E3%3C%2FSTRONG%3E%E3%81%AB%E3%81%82%E3%82%8A%E3%81%BE%E3%81%99%20(%E3%83%87%E3%83%95%E3%82%A9%E3%83%AB%E3%83%88%E3%81%AF%E3%83%97%E3%83%83%E3%82%B7%E3%83%A5%20%E3%83%97%E3%83%AB%E3%81%A8%E3%82%A2%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%20%E3%83%AD%E3%83%BC%E3%81%A7%E3%81%99)%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%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%81%94%E3%81%96%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%3C%2FP%3E%3CP%3EFXLS896xAF%20%E7%94%A8%E3%81%AE%E3%81%93%E3%81%AE%E3%82%88%E3%81%86%E3%81%AA%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%81%8C%E3%81%84%E3%81%8F%E3%81%A4%E3%81%8B%E3%81%82%E3%82%8C%E3%81%B0%E4%BE%BF%E5%88%A9%E3%81%A7%E3%81%99%E3%80%82%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%E3%81%93%E3%82%93%E3%81%AB%E3%81%A1%E3%81%AF%E3%80%81%E3%82%A2%E3%83%B3%E3%83%89%E3%83%AA%E3%83%A5%E3%83%BC%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%83%95%E3%82%A3%E3%83%BC%E3%83%89%E3%83%90%E3%83%83%E3%82%AF%E3%82%92%E3%81%84%E3%81%9F%E3%81%A0%E3%81%8D%E3%80%81%E3%81%82%E3%82%8A%E3%81%8C%E3%81%A8%E3%81%86%E3%81%94%E3%81%96%E3%81%84%E3%81%BE%E3%81%99%E3%80%82%E3%81%8A%E3%81%A3%E3%81%97%E3%82%83%E3%82%8B%E9%80%9A%E3%82%8A%E3%80%81%E5%87%BA%E5%8A%9B%E3%83%A2%E3%83%BC%E3%83%89%20(%E3%83%97%E3%83%83%E3%82%B7%E3%83%A5%E3%83%97%E3%83%AB%20vs.%20%E3%82%AA%E3%83%BC%E3%83%97%E3%83%B3%E3%83%89%E3%83%AC%E3%82%A4%E3%83%B3)%20%E3%81%A8%E6%A5%B5%E6%80%A7%20(%E3%82%A2%E3%82%AF%E3%83%86%E3%82%A3%E3%83%96%20%E3%83%AD%E3%83%BC%20vs.%20%E3%83%8F%E3%82%A4)%20%E3%81%AF%E3%80%81%E3%81%A9%E3%81%A1%E3%82%89%E3%82%82%20CTRL_REG3%20%E3%83%AC%E3%82%B8%E3%82%B9%E3%82%BF%E3%81%AE%E3%83%93%E3%83%83%E3%83%88%20pp_od%20%E3%81%A8%20ipol%20%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E8%A8%AD%E5%AE%9A%E5%8F%AF%E8%83%BD%E3%81%A7%E3%81%99%E3%80%82%3C%2FP%3E%0A%3CP%3E%E3%81%93%E3%82%8C%E3%82%92%E6%98%8E%E7%A2%BA%E3%81%AB%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AB%E3%80%81FXLS8471Q_Init%20%E9%96%A2%E6%95%B0%E3%82%92%E6%9B%B4%E6%96%B0%E3%81%97%E3%81%BE%E3%81%97%E3%81%9F%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%E3%80%81%E3%83%88%E3%83%BC%E3%83%9E%E3%82%B9%3C%2FP%3E%3C%2FLINGO-BODY%3E