# ±30 Gauss, Monolithic, High Performance, 3-axis Magnetic Sensor with FIFO # **MMC5616WA** #### **FEATURES** - Monolithic integrated 3-axis AMR magnetic sensor and electronic circuits requiring fewer external components - Superior Dynamic Range and Accuracy: - √ ±30 G FSR - √ 20bits operation mode - √ 16bits resolution with FIFO - √ 0.0625mG per LSB resolution - √ 2 mG total RMS noise - ✓ Enables heading accuracy of ±10 - Sensor true frequency response up to 1KHz - Ultra-Small Wafer Level Package 0.82x0.82x0.4 mm - On-chip automatic degaussing with built-in SET/RESET function - Eliminates thermal variation induced offset error (Null field output) - ✓ Clears the residual magnetization resulting from strong external fields - On-chip sensitivity compensation - On-chip temperature sensor - · Selftest signal available - Data\_ready Interrupt (I3C only) - Low power consumption - 1 µA power down current - I<sup>2</sup>C slave, FAST (≤400 KHz) mode - I3C interface, per MIPI spec V1.0 - 1.2V to 3.6V compatible I2C interface - 1.2V to 1.8V compatible I3C interface - RoHS compliant ### **APPLICATIONS** - Electronic Compass & GPS Navigation - Position Sensing **FUNCTIONAL BLOCK DIAGRAM** ### **DESCRIPTION** The MMC5616WA is a monolithic complete 3-axis AMR magnetic sensor with on-chip signal processing and integrated digital bus (I<sup>2</sup>C fast mode and I3C interface), the device can be connected directly to a microprocessor, eliminating the need for A/D converters or timing resources. It can measure magnetic fields within the full scale range of $\pm 30$ Gauss (G), with up to 0.0625mG per LSB resolution at 20bits operation mode and 2mG total RMS noise level, enabling heading accuracy of $\pm 1^{\rm o}$ in electronic compass applications. Contact MEMSIC for access to advanced calibration and tilt-compensation algorithms. An integrated SET/RESET function provides for the elimination of error due to Null Field output change with temperature. In addition, it clears the sensors of any residual magnetic polarization resulting from exposure to strong external magnets. The SET/RESET function can be performed for each measurement or periodically as the specific application requires. The MMC5616WA is in wafer level package with an ultra-small size of 0.82x 0.82 x 0.4 mm and with an operating temperature range from -40 °C to +85 °C. Information furnished by MEMSIC is believed to be accurate and reliable. However, no responsibility is assumed by MEMSIC for its use, or for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of MEMSIC. ©MEMSIC, Inc. One Technology Drive, Suite 325, Andover, MA 01810, USA Tel: +1 978 738 0900 Fax: +1 978 738 0196 www.memsic.com # **SPECIFICATIONS** (Measurements @ 25 °C, unless otherwise noted; V<sub>DD</sub>= 1.8 V, Auto\_SR\_en=1, unless otherwise specified) | Parameter | Conditions | Min | Тур | Max | Units | |-----------------------------------------------------------|-----------------------------|------|--------|----------|----------| | Field Range (Each Axis) <sup>1</sup> | Total applied field | | ±30 | | G | | Supply Voltage (V <sub>DD</sub> ) <sup>10</sup> | | 1.7 | 1.8 | 3.6 | V | | Interface(I2C/I3C) Voltage (V <sub>IO</sub> ) 9 | | 1.1 | 1.8 | $V_{DD}$ | V | | Supply Voltage rise time | | | | 10.0 | ms | | | BW=00 | | 3.4 | | mA | | Supply Current <sup>2,3</sup> | BW=01 | | 2.4 | | mA | | (100 measurements/second) | BW=10 | | 1.3 | | mA | | | BW=11 | | 0.75 | | mA | | Power Down Current <sup>3</sup> | | | 1.0 | 1.2 | μA | | Operating Temperature | | -40 | | 85 | °C | | Storage Temperature | | -55 | | 125 | °C | | Linearity Error <sup>3</sup> | FS=±30 G | | 0.5 | 0.75 | 0/50 | | (Best fit straight line) | H <sub>applied</sub> =±15 G | | 0.5 | 0.75 | %FS | | Hysteresis <sup>3</sup> | 3 sweeps across ±30 G | | 0.02 | 0.1 | %FS | | Repeatability Error <sup>3</sup> | 3 sweeps across ±30 G | | 0.02 | 0.1 | %FS | | Alignment Error | | | ±1.0 | ±3.0 | Degrees | | Transverse Sensitivity <sup>3</sup> | | | ±2.0 | | % | | , , , , , , , , , , , , , , , , , , , | BW=00 | | 1.5 | 2.5 | mG | | T | BW=01 | | 2.0 | 4.0 | mG | | Total RMS Noise <sup>3</sup> | BW=10 | | 3.0 | 5.0 | mG | | | BW=11 | | 4.0 | 7.0 | mG | | Output resolution | | | 20 | | Bits | | • | BW=00 | 75 | | | Hz | | Mary Output data rate4 | BW=01 | 125 | | | Hz | | Max Output data rate <sup>4</sup> | BW=10 | 255 | | | Hz | | | BW=11 | 255 | | 800 | Hz | | Heading accuracy <sup>3,5</sup> | | | ±1.0 | ±3.0 | Degrees | | • | ±30 G | -5 | | 5 | % | | Sensitivity <sup>3,6,8</sup> | With16bits operation | | 1024 | | counts/G | | , | With18bits operation | | 4096 | | counts/G | | | With 20bits operation | | 16384 | | counts/G | | Sensitivity Change Over | -40~+85 °C | | | | | | Temperature <sup>3</sup> | Delta from 25 °C | | | ±5 | % | | · | | -1.0 | | 1.0 | G | | N " F" 1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | With16bits operation | | 32768 | | Counts | | Null Field Output <sup>8</sup> | With18bits operation | | 131072 | | Counts | | | With 20bits operation | | 524288 | | Counts | | Null Field Output Change Over<br>Temperature <sup>3</sup> | · | | ±0.2 | ±1.0 | mG/°C | | Temperature Sensor Output <sup>3</sup> | | 0.6 | 0.8 | 1.0 | °C/Count | | Disturbing Field <sup>7</sup> | | 32 | 0.0 | 1.0 | G | | Maximum Exposed Field | | 32 | | 10,000 | G | | Output Repeatability <sup>3</sup> | | | 2.0 | 10,000 | mG | #### Notes: - 1. External magnetic field on each axis not continuously higher than 16G. - 2. Supply current is proportional to how many measurements performed per second, 50Hz for BW=00. - 3. Based on 3lots characterization result. - 4. The 800 Hz ODR is available by writing 255 into Register ODR , setting hpower to 1, en\_odr2k = 1 - 5. MEMSIC product enables users to utilize heading accuracy to be 1.0 degree typical when using MEMSIC's proprietary software or algorithm. - 6. Sensitivity of the orthogonal axes is analytically derived from raw data and is subsequently processed by MEMSIC software drivers. - This is the magnitude of external field that can be tolerated without changing the sensor characteristics. If the disturbing field is exceeded, a SET/RESET operation is required to restore proper sensor operation. - 8. Based on shipment test result. - A dedicated block automatically samples the high voltage of the bus interface (sda and scl), averages the sampled high voltage in time domain and holds this average voltage as V<sub>IO</sub> - 10. 3.6V VDD is supported only under I2C interface communication. Under I3C interface communication, VDD should not be larger than 1.8V. ### I<sup>2</sup>C INTERFACE I/O CHARACTERISTICS | Parameter | Symbol | Test Condition | Min. | Тур. | Max. | Unit | |--------------------------------------|---------------------|-----------------------------------------------------------|---------------------|------|----------------------|------| | Logic Input Low Level | VIL | | -0.5 | | 0.3* V <sub>IO</sub> | V | | Logic Input High Level | V <sub>IH</sub> | | 0.7*V <sub>IO</sub> | | V <sub>IO</sub> | V | | Hysteresis of Schmitt input | V <sub>hys</sub> | | 0.2 | | | V | | Logic Output Low Level | Vol | | | | 0.4 | V | | Input Leakage Current | li | 0.1V <sub>IO</sub> <v<sub>in&lt;0.9V<sub>IO</sub></v<sub> | -10 | | 10 | μΑ | | SCL Clock Frequency | fscL | | 0 | | 400 | kHz | | START Hold Time | t <sub>HD;STA</sub> | | 0.6 | | | μS | | START Setup Time | tsu;sta | | 0.6 | | | μS | | LOW period of SCL | t <sub>LOW</sub> | | 1.3 | | | μS | | HIGH period of SCL | tніgн | | 0.6 | | | μS | | Data Hold Time | thd;dat | | 0 | | 0.9 | μS | | Data Setup Time | t <sub>SU;DAT</sub> | | 0.1 | | | μS | | Rise Time | tr | From V <sub>IL</sub> to V <sub>IH</sub> | | | 0.3 | μS | | Fall Time | t <sub>f</sub> | From V <sub>IH</sub> to V <sub>IL</sub> | | | 0.3 | μS | | Bus Free Time Between STOP and START | t <sub>BUF</sub> | | 1.3 | | | μS | | STOP Setup Time | tsu;sто | | 0.6 | | | μS | ### **I3C INTERFACE I/O CHARACTERISTICS** | Parameter | Symbol | Test Condition | Min. | Тур. | Max. | Unit | |-----------------------------------------|---------------------|-----------------------------------------------------------|---------------------|------|----------------------|------| | Logic Input Low Level | VIL | | -0.5 | | 0.3* V <sub>IO</sub> | V | | Logic Input High Level | V <sub>IH</sub> | | 0.7*V <sub>IO</sub> | | Vio | V | | Hysteresis of Schmitt input | V <sub>hys</sub> | | 0.2 | | | V | | Logic Output Low Level | Vol | | | | 0.3* Vio | V | | Logic Output High Level(Push-Pull only) | V <sub>OH</sub> | | 0.8*V <sub>IO</sub> | | 1.2*V <sub>IO</sub> | V | | Input Leakage Current | li | 0.1V <sub>IO</sub> <v<sub>in&lt;0.9V<sub>IO</sub></v<sub> | -10 | | 10 | μΑ | | SCL Clock Frequency | fscL | | 0.95 | | 12.9 | MHz | | START Hold Time | thd;sta | | 38.4 | | | nS | | START Setup Time | t <sub>SU;STA</sub> | | 19.2 | | | nS | | LOW period of SCL | tLOW | | 33 | | | nS | | HIGH period of SCL | thigh | | 33 | | | nS | | Data Hold Time | thd;dat | | 0 | | 24 | nS | | Data Setup Time | tsu;dat | | 3 | | | nS | | Rise Time | tr | From V <sub>IL</sub> to V <sub>IH</sub> | | | 12 | nS | | Fall Time | t <sub>f</sub> | From VIH to VIL | | | 12 | nS | | Clock in to data out | tsco | | | | 12 | nS.! | | Bus Free Time Between STOP and START | t <sub>BUF</sub> | | 1.3 | | | μS | | STOP Setup Time | tsu;sto | | 19.2 | | | nS | ### **POWER ON SEQUENCE** (Measurements @ 25 $^{\circ}$ C, unless otherwise noted; $V_{DD}$ = 1.8 V, unless otherwise specified) | Parameter | Symbol | Min. | Тур. | Max. | Unit | |----------------------------------------------------|--------|------|------|------|------| | Supply Voltage Rise Time | Tvr | 1e-3 | | 10 | ms | | Time to operate device after V <sub>DD</sub> valid | Тор | 5 | | | ms | | Time sequence between VDD and V <sub>IO</sub> * | Tio | 0 | | | us | ### **OPERATING TIMING DIAGRAM WITH THE PARAMETERS** The parameters for the operating timing diagram above | Description | Symbol | Min | Max | Unit | |----------------------------------------|---------|-----|-----|------| | Time to operate device after VDD valid | top | 5 | | ms | | Time to guarantee to be in I3C mode | top_i3c | 100 | | us | #### **ABSOLUTE MAXIMUM RATINGS\*** Supply Voltage -0.5 to +5 V Storage Temperature -55 °C to +125 °C Maximum Exposed Field 10000 G **Note:** Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. This is a stress rating only; the functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect the device's reliability. ### Pin Description: WLP Package | Pin | Name | Description | I/O | |-----|------|-------------------|-----| | A1 | VSA | Connect to Ground | Р | | A2 | SCL | Serial Clock Line | ı | | B1 | VDD | Power Supply | Р | | B2 | SDA | Serial Data Line | I/O | All parts are shipped in tape and reel packaging with 10000pcs (or 5000pcs per requested) per 7" reel. #### Caution: This is an Electro-static Discharge (ESD) sensitive device. ### **Ordering Guide:** Package type: | Code | Туре | | | | | |------|-------------------------------|--|--|--|--| | W | WLP package<br>RoHS compliant | | | | | ### Performance Grade: | Code | Performance Grade | |------|-------------------| | Α | Temp compensated | #### MARKING ILLUSTRATION **Note:** "Number" (top-left character) is used to differentiate between similar devices. The black dot marks the location of pin one (1). The 2<sup>nd</sup> line represents the device's Lot Number. ### THEORY OF OPERATION The Anisotropic Magneto-Resistive (AMR) sensors are special resistors made of permalloy thin film deposited on a silicon wafer. During manufacturing, a strong magnetic field is applied to the film to orient its magnetic domains in the same direction, establishing a magnetization vector. Subsequently, an external magnetic field applied perpendicularly to the sides of the film causes the magnetization to rotate and change angle. This effect causes the film's resistance to vary with the intensity of the applied magnetic field. The MEMSIC AMR sensor is incorporated into a Wheatstone bridge configuration to maximize Signal to Noise ratio. A change in magnetic field produces a proportional change in differential voltage across the Wheatstone bridge However, the influence of a strong magnetic field (more than 30 G) in any direction could upset, or flip, the polarity of the film, thus changing the sensor characteristics. A strong restoring magnetic field must be applied momentarily to restore, or set, the sensor characteristics. The MEMSIC magnetic sensor has an on-chip magnetically coupled strap: a SET/RESET strap pulsed with a high current, to provide the restoring magnetic field. The MMC5616WA can operate from a single 1.7V to 3.6V supply (3.6V VDD is supported only under I2C interface communication. Under I3C interface communication, VDD should not be larger than 1.8V). The circuit connection diagrams below illustrate power supply connection options. <Top View> ### **Connection Block Diagram** ### **PIN DESCRIPTIONS** $\mbox{VDD}$ – This is the power supply pin. MEMSIC recommends a minimum bypass capacitor of 2.2 $\mu\mbox{F}$ placed in close proximity to the VDD pin. **VSA** – This is the ground pin for the magnetic sensor. **SDA** – This pin is the I3C/I<sup>2</sup>C serial data line. **SCL**– This pin is the I3C/I<sup>2</sup>C serial clock line. ### HARDWARE DESIGN CONSIDERATION - ✓ Provide adequate separation distance to devices that contain permanent magnets or generate magnetic fields (e.g. speakers, coils, inductors) The combined magnetic field to be measured and interference magnetic field should be less than the full scale range of the MMC5616WA (±30 G). - ✓ Provide adequate separation distance to current carrying traces. Do not route current carrying traces under the sensor or on the other side of the PCB opposite the device. - ✓ Do not cover the sensor with magnetized material or material that may become magnetized, (e.g., shield box, LCD, battery, iron bearing material). - ✓ Do not place the device opposite magnetized material or material that may become magnetized located on the other side of the PCB. Details please refer to MEMSIC Magnetic Sensor Hardware Design Layout Guideline for Electronic Device. #### POWER CONSUMPTION The power consumed by the device is proportional to the number of measurements taken per second. For example, when BW<1:0>=10, MMC5616WA consumes 1.3mA (typical) at 1.8V with 100 measurements per second. If only 1 measurement are performed per second, the current will be $1300*1/100=13\mu A$ . #### I<sup>2</sup>C INTERFACE DESCRIPTION The I<sup>2</sup>C (or Inter IC bus) is an industry standard bi-directional two-wire interface bus. A master I<sup>2</sup>C device can operate READ/WRITE controls to 128 devices by device addressing. The MEMSIC magnetic sensor operates only in a slave mode, i.e. only responding to calls by a master device. #### I<sup>2</sup>C BUS CHARACTERISTICS The two wires in the I<sup>2</sup>C bus are called SDA (serial data line) and SCL (serial clock line). In order for a data transfer to start, the bus has to be free, which is defined by both wires in a HIGH output state. Due to the open-drain/pull-up resistor structure and wired Boolean "AND" operation, any device on the bus can pull lines low and overwrite a HIGH signal. The data on the SDA line has to be stable during the HIGH period of the SCL line. In other words, valid data can only change when the SCL line is LOW. Note: Rp selection guide: 2.7Kohm for a short I<sup>2</sup>C bus length (less than 10 cm), and 10Kohm for a bus length less than 5 cm. ### **13C INTERFACE DESCRIPTION** ### **13C BUS CHARACTERISTICS** Include information that $V_{IO}$ in I3C is 1.7 – 1.8V. We support 1.2V I3C. I3C is a two-wire bidirectional serial Bus developed by MIPI Alliance (<u>www.MIPI.org</u>). In order to receive detailed description of I3C interface please contact MIPI Alliance directly. I3C interface is backward compatible with I2C, but offers additional features, such faster clock rate, in-band interrupts, and event timing control. I3C bus interface is compliant with Open-Drain mode and Push-Pull mode. Open-Drain/Push-Pull mode is selected automatically by I3C function. I3C defines several roles for devices connected to the I3C bus. MMC5616WA is an I3C Slave. It does not have Master capabilities. MMC5616WA supports SDR and HDR-DDR¹ modes with clock speed up to 12.9MHz. It does not support High Data Rate Ternary modes. Notes: 1. In single test mode, when auto\_sr\_en is set to 1'b1, send TMM command with HDR-DDR, read xout/yout/zout values after exit HDR-DDR, MMC5616WA supports in-band interrupts (IBI) MMC5616WA does not support Hot Join mechanism. I3C Spec defines two special 8-bit registers BCR and DCR. MX5616WA has BCR= 0x27 and DCR=0x00. I3C interface defines Common Command Codes (CCC), which can be Broadcast or Direct. MMC5616WA supports the following CCC's, both Broadcast and Direct: - Enable Events Command (ENEC) - Disable Events Command (DISEC) - Enter Activity State 0 (ENTAS0) - Reset Dynamic Address Assignment (RSTDAA) - Enter Dynamic Address Assignment (ENTDAA) - Enter HDR Mode 0 (ENTHDR0) - Exchange Timing Information (SETXTIME) - Set Dynamic Address from Static Address (SETDASA) - Set New Dynamic Address (SETNEWDA) - Get Provisional ID (GETPID) - Get Bus Characteristics Register (GETBCR) - Get Device Characteristics Register (GETDCR) - Get Device Status (GETSTATUS) - Get HDR Capability (GETHDRCAP) ### **REGISTER MAP** | Register Name | Address (HEX) | Description | |--------------------|---------------|-------------------------------------| | Xout0 | 00H | Xout[19:12] | | Xout1 | 01H | Xout[11:4] | | Yout0 | 02H | Yout[19:12] | | Yout1 | 03H | Yout[11:4] | | Zout0 | 04H | Zout[19:12] | | Zout1 | 05H | Zout[11:4] | | Xout2 | 06H | Xout[3:0],fifo_usage[3:0] | | Yout2 | 07H | Yout[3:0],2'b0,fifo_full,fifo_empty | | Zout2 | 08H | Zout[3:0],4'b0 | | Tout | 09H | Temperature output | | TPH0 | 0AH | TPH_Format, TPH[7:1] | | TPH1 | 0BH | 6'h00,TPH[9:8] | | TU | 0CH | TU[1:0] | | Fifo control | 0EH | FIFO control | | Status1 | 18H | Device status1 | | Status0 | 19H | Device status0 | | ODR | 1AH | Output Data Rate | | Internal control 0 | 1BH | Control register 0 | | Internal control 1 | 1CH | Control register 1 | | Internal control 2 | 1DH | Control register 2 | | ST_X_TH | 1EH | X-axis selftest threshold | | ST_Y_TH | 1FH | Y-axis selftest threshold | | ST_Z_TH | 20H | Z-axis selftest threshold | | Chip ID | 21H | mask programmable. Rev I -> 0xD2 | | Ana control | 22H | Analog addr | | ST_X | 27H | X-axis selftest set value | | ST_Y | 28H | Y-axis selftest set value | | ST_Z | 29H | Z-axis selftest set value | | Product ID | 39H | Product ID | ### **REGISTER DETAILS** ### Xout0, Xout1, Xout2 | Nouto, Nout 1, No | <u> </u> | | | 1 . | | | | | |-------------------|----------------------------------|-------------|---|-----------|------|---|---|---| | Xout0 | / | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Addr: 00H | | Xout[19:12] | | | | | | | | Mode | | | | Read- | only | | | | | | | | | | | | | | | Xout1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Addr: 01H | | Xout[11:4] | | | | | | | | Mode | | Read-only | | | | | | | | | | | | | | | | | | Xout2 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | Addr: 06H | r: 06H Xout[3:0] Fifo_usage[3:0] | | | Xout[3:0] | | | | | | Mode | | Read-only | | | | | | | | Bit Name | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------| | Fifo_usage[3:0] | fifo usage bits, fifo depth is 16. 4'b0000 means fifo is empty, 4'b1111 means that there are 15 sets of tmm measurement data in fifo. | X-axis output, unsigned format. | X-axis output | Data | |-----------------------|------------| | 16bits operation mode | Xout[19:4] | | 18bits operation mode | Xout[19:2] | | 20bits operation mode | Xout[19:0] | ### Yout0, Yout1, Yout2 | Yout0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------|-----------|-------------|---|---|---|---|---|---|--|--| | Addr: 02H | | Yout[19:12] | | | | | | | | | | Mode | Read-only | | | | | | | | | | | Yout1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|------------|---|---|---|---|---|---|---|--| | Addr: 03H | Yout[11:4] | | | | | | | | | | Mode | Read-only | | | | | | | | | | Yout2 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-----------|-----|--------|---|---|---|-----------|------------| | Addr: 07H | | You | t[3:0] | | 0 | 0 | Fifo_full | Fifo_empty | | Mode | Read-only | | | | | | | | | Bit Name | Description | |------------|------------------------------------------------| | Fifo_full | fifo full indicator, 1'b1 means fifo is full | | Fifo_empty | fifo empty indicator, 1'b1 means fifo is empty | Y-axis output, unsigned format. | Y-axis output | Data | |-----------------------|------------| | 16bits operation mode | Yout[19:4] | | 18bits operation mode | Yout[19:2] | | 20bits operation mode | Yout[19:0] | ### Zout0, Zout1, Zout2 | Zout0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---|---|---|--------|--------|---|---|---| | Addr: 04H | | | | Zout[′ | 19:12] | | | | | Mode | | Read-only | | | | | | | | | | | |-----------|---|------------|---------|------|--------|---|---|---|--|--|--|--| | | | | | | | | | | | | | | | Zout1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | Addr: 05H | | Zout[11:4] | | | | | | | | | | | | Mode | | Read-only | | | | | | | | | | | | | | | | | - | | | | | | | | | Zout2 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | | | | Zou | ıt[3:0] | | 0 | 0 | 0 | 0 | | | | | | Addr: 08H | | | | | | | | | | | | | | Mode | | | | Read | d-only | | | | | | | | Z-axis output, unsigned format. | Z-axis output | Data | |-----------------------|------------| | 16bits operation mode | Zout[19:4] | | 18bits operation mode | Zout[19:2] | | 20bits operation mode | Zout[19:0] | ### **Temperature Out** | Temperature | 7 | 6 | 5 | | 4 | 3 | 2 | 1 | 0 | | | |-------------|---|---|-----------|--|---|---|---|---|---|--|--| | Addr: 09H | | | Tout[7:0] | | | | | | | | | | Mode | | | Read-only | | | | | | | | | Temperature output, unsigned format. The range is -75-125°C, about 0.8°C/LSB, 00000000 stands for -75°C #### TPH0 | TPH0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|------------|----------|---|---|---|---|---|---|--| | Addr: 0AH | TPH_Format | TPH[7:1] | | | | | | | | | Mode | | | W | | | | | | | This byte, together with the next register, TPH1, defines the parameter called TPH for the synchronizations of measurements according to I3C protocol. TPH is the time between two adjacent synchronization events. The master should send a synchronization tick (ST) to slaves, with a period of TPH, as a reference for the internal circuits of the sensor to adjust the period and phase of its measurements. The MSB of this byte defines whether the TPH contains 1 byte (TPH\_Format=0), or 2 bytes (TPH\_Format=1). If TPH has only 1 byte, its value is defined as {TPH[7:1], 1'b0}, and if TPH has 2 bytes, its value is defined as {TPH[9:1], 1'b0}, where TPH[9:8] comes from the next register, TPH1. The unit of TPH is the number of measurements. For example, TPH=100 means 100 measurements, and the time interval of two adjacent synchronization will be 1 second in case of 100Hz ODR. Alternatively, TPH can be defined by SETXTIME CCC command, with the defining byte of 0x3F, followed by the TPH value. Only one data byte is allowed if TPH is defined by SETXTIME CCC, and the value of that byte is the same as this register. #### TPH1 | TPH1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----------|---|---|---|---|---|---|----------|---|--| | Addr: 0BH | 0 | 0 | 0 | 0 | 0 | 0 | TPH[9:8] | | | | Mode | | W | | | | | | | | This byte defines the higher portion of the TPH, and is valid only when TPH\_Format=1. MMC5616WA supports up to 10 bits of TPH, so that only TPH[9:8] are used to define TPH, and the rest of this byte should be set to 0. ### TU | TU | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|---|---|---|---|---|---|-----|------| | Addr: 0CH | х | Х | Х | Х | Х | Х | TU[ | 1:0] | | Mode | | | | V | | | | | This byte is used to define the time unit of the synchronization events. Only 2 bits are used, and the corresponding time units are 2^(-11), 2^(-12), 2^(-13), and 2^(-14) of the TPH, respectively, for the TU value of 00, 01, 10, and 11. Alternatively, this byte can be defined by I3C CCC command, with the defining byte of 0x9F, followed by one byte of data. ### **Fifo Control** | Fifo | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |---------|--------------|------------|------------|------------|------------|------|-------------|---------|--|--| | control | | | | | | | | | | | | Addr: | Addr_loop_en | Fifo_wm[3] | Fifo_wm[2] | Fifo_wm[1] | Fifo_wm[0] | 1'b0 | Fifo_int_en | Fifo_en | | | | 0EH | | | | | | | | | | | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Value | U | U | U | U | U | U | U | U | | | | Mode | Read-only | | | | | | | | | | | Bit Name | Description | |-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------| | Addr_loop_en | fifo address loopback enable, when this bit set to 1, address will loopback in address range 0h-5h (x0,x1,y0,y1,z0,z1). | | Fifo_wm[3:0] | fifo watermark, interrupt will be raised up if usage is greater than watermark | | Fifo_int_en | fifo interrupt enable, when enable, fifo will generate interrupt when watermark has been reached | | Fifo_en1 <sup>1</sup> | fifo enable bit, fifo is bypassed when this bit set to 0. when this bit is set to 1'b1, 6tytes(xout0,xout1,yout0,yout1,zout0,zout1) should be read at a time | #### Notes: ### Status1 | Device Status1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|-----------------|-----------------|----------------|-------------------|---------|------------------|---------------------|---------------------| | Addr: 18H | Meas_t_<br>done | Meas_m<br>_done | Sat_se<br>nsor | OTP_read<br>_done | ST_Fail | Mdt_flag<br>_int | Meas_t_d<br>one_int | Meas_m_<br>done_int | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Mode | Read-only | | | | | | | | | Bit Name | Description | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--| | Meas_m_done_int <sup>1</sup> | This bit indicates whether Take Measurement of Magnetic field command has been completed and data ready to be read by the host. This bit is primarily for the I3C in-band interrupt (IBI). This bit is reset if a new Take Measurement command is received or if any of the magnetic data registers is access through I <sup>2</sup> C. However, this bit is also reset if either the I3C In-Band Interrupt (IBI) is sent, or this bit is read. | | | | | Meas_t_done_int <sup>1</sup> | This bit indicates whether Take Measurement of Temperature command has been completed and data ready to be read by the host. This bit is also for I3C IBI, it is reset if a new Take Measurement command is received or if the temperature data register is accessed through I2C. However, this bit is also reset if either the IBI interrupt is sent, or this bit is read. | | | | | Mdt_flag_int | This bit indicates whether a motion is detected by the motion detector. This bit is set High when a motion is detected, and it is reset when Start_MDT is received, or an IBI is sent to the master, or this bit is read. | | | | | ST_Fail | This bit is specifically for I3C IBI. When the sensor receives the ST and/or DT command via I3C interface, and parity bit is incorrect, this bit will be set High and the sensor will send an IBI to inform the master. This bit is reset after the IBI is sent. | | | | | OTP_read_done <sup>1</sup> | This bit is an indicator of successfully reading its OTP memory either as part of its power up sequence, or after an I2C command that reloads the OTP memory, such as resetting the chip and refreshing the OTP registers. | | | | | Sat_sensor | This bit is an indicator of the selftest signal, it keeps low once the device PASS selftest. | | | | | Meas_m_done <sup>1</sup> | This bit indicates that a measurement of magnetic field is done and the data is ready to be read. This bit is reset only when any of the magnetic data registers is read. | | | | | Meas_t_done <sup>1</sup> This bit is reset only when the temperature is done and the data is ready to This bit is reset only when the temperature register is read. | | | | | | Notes: | Sala de l'octation, in tra temperature regioner le rough | | | | <sup>1.</sup> When fifo\_en and addr\_loop\_en are set to 1'b1, at most 8\*6bytes can be read at a time ### Status0 | Device Status0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |----------------|--------------------|---|----------------|---|---|----------|----------------------------------|---| | Addr: 19H | Activity Mode[1:0] | | Protocol error | 0 | 0 | Mdt_flag | Pending Interrupt<br>Number[1:0] | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Mode | | | • | | R | | | | | Bit Name | Description | | | | | | |-------------------|---------------------------------------------------------------------------------------------|--|--|--|--|--| | | 0b00 – no interrupts pending. | | | | | | | Pending Interrupt | 0b01 - either of the Meas_m_done_int or Meas_t_done_int is high | | | | | | | Number[1:0] | 0b10 - Mdt_flag_int bit is high | | | | | | | | 0b11 – protocol error is detected. | | | | | | | Mdt_flag | This bit becomes high when motion is detected. This bit is cleared when a new Start_MDT bit | | | | | | | wut_nay | is written t 1. FACTORY USE ONLY. DO WE WANT TO REVEAL THIS BIT? | | | | | | | Protocol error | I3C Protocol error is detected. | | | | | | | Activity Mode[0] | Always 0 | | | | | | | Activity Mode[1] | 0 – MMC5616WA is in power down mode. | | | | | | | Activity Mode[1] | 1 – MMC5616WA is actively performing a measurement | | | | | | ### ODR | ODR | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|---|------------|---|---|---|---|---|---|--|--|--| | Addr: 1AH | | ODR[7:0] | | | | | | | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | | Read/Write | | | | | | | | | | | Bit Name | Descrip | Description | | | | | | | | | |----------|----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|---|--|--|--|--|--|--| | | by eithe<br>defining<br>configur | This byte defines the frequency of the continuous-mode measurements. ODR can be defined by either writing the number into this register, or using SETXTIME CCC command, followed by defining byte of 0x8F. In order to enter the continuous mode, this byte should not be zero. The configurable ODR is 1 to 255, with increment of 1. The 1000 Hz or 1500 Hz ODR is available by writing 255 into this byte and setting hpower to 1. The maximum reachable ODR as below: | | | | | | | | | | ODR[7:0] | BW | Automatic SET/RESET | No SET/RESET | | | | | | | | | | 00 | 75Hz | 150 Hz | 1 | | | | | | | | | 01 | 125 Hz | 255 Hz | 1 | | | | | | | | | 10 | 255 Hz | 255 Hz | 1 | | | | | | | | | 11 | hpower=0: 255Hz; | hpower=0: 255 Hz; | | | | | | | | | | | hpower=1 en_odr2k=0: 500 Hz; | hpower=1 en_odr2k=0: 1000 Hz; | | | | | | | | | | | hpower=1 en_odr2k=1: 800 Hz | hpower=1 en odr2k=1: 1500 Hz | | | | | | | | ### **Internal Control 0** | Control<br>Register 0 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-----------------------|-----------------|----------------|----------------|----------|--------|---------------|-----------------|-----------------|--|--| | Addr: 1BH | Cmm_fre<br>q_en | Auto_st_<br>en | Auto_SR<br>_en | Do Reset | Do Set | Start_MD<br>T | Take_me<br>as_T | Take_me<br>as_M | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Mode | Read/Write | | | | | | | | | | | Bit Name | Description | |--------------|------------------------------------------------------------------------------------------------| | Take_meas_M¹ | Take Measure of Magnetic field, or TM_M bit. Writing a 1 into this location causes the chip to | | | perform a magnetic measurement. This bit is self-clearing at the end of each measurement. | | Take_meas_T | Take Measure of Temperature, or TM_T bit. Writing a 1 into this location causes the chip to | | rake_meas_r | perform a temperature measurement. This bit is self-clearing at the end of each measurement. | | Start_MDT | Factory use only, reset value is 0. | | Do Set | Writing a 1 into this location will cause the chip to do the Set operation, which will allow large set current to flow through the sensor coils for 375ns. This bit is self-cleared at the end of Set operation. | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Do Reset | Writing a 1 into this location will cause the chip to do the Reset operation, which will allow large reset current to flow through the sensor coils for 375ns. This bit is self-cleared at the end of Reset operation. | | Auto_SR_en | Writing a 1 into this location will enable the function of automatic set/reset. This function applies to both on-demand and continuous-time measurements. This bit must be set to 1 in order to activate the feature of periodic set. This bit is recommended to set to "1" in the application. | | Auto_st_en | Writing a 1 into this location will enable the function of automatic self-test. The threshold in register 1EH, 1FH, 20H should be set before this bit is set to 1. This bit clears itself after the operation is completed. | | Cmm_freq_en | Writing a 1 into this location will start the calculation of the measurement period according to the ODR. This bit should be set before continuous-mode measurements are started. This bit is self-cleared after the measurement period is calculated by internal circuits. | ### **Internal Control 1** | Control | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|------------|--------|--------|-----------|-----------|-----------|-----|-----|--|--|--| | Register 1 | | | | | | | | | | | | | Addr: 1CH | Sw_reset | St_enm | St_enp | Z-inhibit | Y-inhibit | X-inhibit | BW1 | BW0 | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | Read/Write | | | | | | | | | | | | Bit Name | | | | Description | | | | | | | | |-----------|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------|---------------------------|----------------------------------------------------------------------------------|--|--|--|--|--|--|--| | | These ban | ndwidth se | ection bits adjust the le | ength of the decimation filter. They control the duration | | | | | | | | | | of each measurement. | | | | | | | | | | | | | BW1 | BW0 | Measurement Time | | | | | | | | | | BW0 & | 0 | 0 | 6.6ms | | | | | | | | | | BW1 | 0 | 1 | 3.5ms | | | | | | | | | | DVVI | 1 | 0 | 2.0ms | | | | | | | | | | | 1 | 1 | 1.2ms | | | | | | | | | | | Note: X/Y/Z channel measurements are taken sequentially. Delay Time among the | | | | | | | | | | | | | measurem | measurements is 1/3 of the Measurement Time defined in the table. | | | | | | | | | | | X-inhibit | _ | Writing "1" will disable this channel, and reduce Measurement Time and total charge per | | | | | | | | | | | Y-inhibit | | | | it is simply skipped during Take Measure routine. Its | | | | | | | | | Z-inhibit | | | | ain the last value written to it when this channel was same time in case needed. | | | | | | | | | | 1 | | | current through the self-test coil of the sensor. This | | | | | | | | | St_enp | | | • | tic field. This function is used to check whether the | | | | | | | | | | sensor has | | • | | | | | | | | | | St onm | The functi | on of this | bit is similar to ST_EN | NP, but the offset of the magnetic field is of opposite | | | | | | | | | St_enm | polarity. | | | | | | | | | | | | Sw_reset | | | | art to reset, similar to power-up. It will clear all registers | | | | | | | | | OW_ICSEL | and also re | e-read OT | P as part of its startup | routine. The power on time is 20mS. | | | | | | | | ### **Internal Control 2** | Control | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|------------|----------------------|----------------|--------|----------------|--------------|---|---|--|--|--| | Register 2 | | | | | | | | | | | | | Addr: 1DH | hpower | INT_meas<br>_done_en | INT_mdt_<br>en | Cmm_en | En_prd_s<br>et | Prd_set[2:0] | | | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | Read/Write | | | | | | | | | | | | Bit Name | Description | |---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Prd_set[2:0] | These bits determine how many measurements are done before a set is executed, when the part is in continuous mode and the automatic set/reset is enabled. From 000 to 111, the sensor will do one set for every 1, 25, 75, 100, 250, 500, 1000, and 2000 samples. In order to enable this feature, both En_prd_set and Auto_SR must be set to 1, and the part should work in continuous mode. Please note that during this operation, the sensor will not be reset. | | En_prd_set | Writing 1 into this location will enable the function of periodical set. | | Cmm_en <sup>4</sup> | The device will enter continuous mode, if ODR has been set to a non-zero value and a 1 has been written into Cmm_freq_en. The internal counter will start counting as well since this bit is set. | | INT_mdt_en | Factory use only, reset value is 0. | | INT_meas_done_en | Factory use only, reset value is 0. | | hpower | If this bit is set to 1 to achieve 1000Hz or 1500Hz ODR. | ### $\mathbf{ST}\_\mathbf{X}\_\mathbf{TH}$ | ST_X_TH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|--------------|---|---|---|---|---|---|---|--|--|--| | Addr: 1EH | ST_X_TH[7:0] | | | | | | | | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | Write-only | | | | | | | | | | | X-axis selftest threshold ### ST\_Y\_TH | ST_Y_TH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|--------------|---|---|---|---|---|---|---|--|--| | Addr: 1FH | ST_Y_TH[7:0] | | | | | | | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Mode | Write-only | | | | | | | | | | Y-axis selftest threshold ### ST\_Z\_TH | ST_Z_TH | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|--------------|---|---|---|---|---|---|---|--|--|--| | Addr: 20H | ST_Z_TH[7:0] | | | | | | | | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | Write-only | | | | | | | | | | | Z-axis selftest threshold ### **Ana Control** | Ana Control | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | |-------------|------------|---|---|---|---|---|---|----------|--|--| | Addr: 22H | | | | | | | | En_odr2k | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | Mode | Read/Write | | | | | | | | | | | Bit Name | Description | | | | | | |----------|-------------------------------------------------|--|--|--|--|--| | En_odr2k | set odr to 2000 and set over sample rate to 256 | | | | | | ### Chip ID | Chip ID | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|--|--|--| | Addr: 21H | Chip<br>id[7][1] | Chip<br>id[6][1] | Chip<br>id[5][0] | Chip<br>id[4][1] | Chip<br>id[3][0] | Chip<br>id[2][0] | Chip<br>id[1][0] | Chip<br>id[0][1] | | | | | Reset Value | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | Mode | | Read-only | | | | | | | | | | ### ST\_X | ST_X | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|------------|----------------------|---|---|---|---|---|---|--|--|--| | Addr: 27H | ST_X[7:0] | | | | | | | | | | | | Reset Value | | Factory stored value | | | | | | | | | | | Mode | Read/Write | | | | | | | | | | | X-axis selftest set value ### ST\_Y | ST_Y | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | |-------------|------------|----------------------|---|---|---|---|---|---|--|--|--| | Addr: 28H | ST_Y[7:0] | | | | | | | | | | | | Reset Value | | Factory stored value | | | | | | | | | | | Mode | Read/Write | | | | | | | | | | | Y-axis selftest set value ### ST\_Z | ST_Z | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | | | | |-------------|------------|----------------------|---|---|---|---|---|---|--|--|--|--| | Addr: 29H | | ST_Z[7:0] | | | | | | | | | | | | Reset Value | | Factory stored value | | | | | | | | | | | | Mode | Read/Write | | | | | | | | | | | | Z-axis selftest set value ### **Product ID 1** | Product ID 1 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |--------------|-----------|------------------|---|---|---|---|---|---| | Addr: 39H | | Product ID1[7:0] | | | | | | | | Reset Value | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | | Mode | Read-only | | | | | | | | Product ID, used to recognize device. ### I<sup>2</sup>C Interface operation: #### **DATA TRANSFER** A data transfer is started with a "START" condition and ended with a "STOP" condition. A "START" condition is defined by a HIGH to LOW transition on the SDA line while SCL line is HIGH. A "STOP" condition is defined by a LOW to HIGH transition on the SDA line while the SCL line is held HIGH. All data transfer in I<sup>2</sup>C system are 8-bits long. Each byte has to be followed by an acknowledge bit. Each data transfer involves a total of 9 clock cycles. Data is transferred starting with the most significant bit (MSB). After a START condition, the master device calls a specific slave device by sending its 7-bit address with the 8<sup>th</sup> bit (LSB) indicating that either a READ or WRITE operation will follow, [1] for READ and [0] for WRITE. The MEMSIC device 7-bit device address is [0110000] where the three LSB's are pre-programmed into the MMC5616WA by the factory. Note: A total of 8 different addresses can be pre-programmed into MEMSIC device by the factory. This variation of I<sup>2</sup>C address avoids a potential address conflict, either by ICs from other manufacturers or by other MEMSIC devices on the same bus. The initial addressing of the slave is always followed by the master writing the number of the slave register to be read or written, so this initial addressing always indicates a WRITE operation by sending **[01100000]**. After being addressed, the MEMSIC device being called should respond by an "Acknowledge" signal by pulling SDA line LOW. Subsequent communication bytes can either be - a) The data to be written to the device register, or - **b)** Another START condition followed by the device address indicating a READ operation **[01100001]**, and then the master reads the register data. Multiple data bytes can be written or read to numerically sequential registers without the need of another START condition. Data transfer is terminated by a STOP condition or another START condition. Two detailed examples of communicating with the MEMSIC device are listed below for the actions of acquiring a magnetic field measurement and magnetizing the sensor. ### **EXAMPLE OF MEASUREMENT** 1st cycle: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (MEMSIC device pulls SDA line low during 9<sup>th</sup> SCL pulse), the master device sends the address of Control Register 0 as the target register to be written. The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse, SDA pulled low). **3rd cycle**: The Master device writes to the Internal Control Register 0 the code [00100001] (TM\_M and Auto\_SR\_en high) to initiate data acquisition. The MEMSIC device should send an Acknowledge and internally initiate a measurement (collect x, y and z data). A STOP condition indicates the end of the write operation. **4<sup>th</sup> cycle**: The Master device sends a START command followed by the MEMSIC device's seven bit address, and finally the eighth bit set low to indicate a WRITE. An Acknowledge should be send by the MEMSIC device in response. 5<sup>th</sup> cycle: The Master device sends the MEMSIC Device Status Register1 as the address to read. **6**<sup>th</sup> **cycle**: The Master device sends a START command followed by the MEMSIC device's seven bit address, and finally the eighth bit set high to indicate a READ. An Acknowledge should be send by the MEMSIC device in response. **7**<sup>th</sup> **cycle**: The Master device cycles the SCL line. This causes the Status Register data to appear on SDA line. Continuously read the Device Status Register1 until the Meas\_M\_Done bit (bit 1) is set to '1'. This indicates that data for the x, y, and z sensors is available to be read. **8**<sup>th</sup> **cycle**: The Master device sends a START command followed by the MEMSIC device's seven bit address, and finally the eighth bit set low to indicate a WRITE. An Acknowledge should be send by the MEMSIC device in response. 9th cycle: The Master device sends a [00000000] (Xout LSB register address) as the register address to read. **10**<sup>th</sup> **cycle**: The Master device calls the MEMSIC device's address with a READ (8<sup>th</sup> SCL cycle SDA line high). An Acknowledge should be send by the MEMSIC device in response. **11<sup>th</sup> cycle**: Master device continues to cycle the SCL line, and each consecutive byte of data from the X, Y and Z registers should appear on the SDA line. The internal memory address pointer automatically moves to the next byte. The Master device acknowledges each. Thus: 12<sup>th</sup> cycle: Xout[19:12]. 13<sup>th</sup> cycle: Xout[11:4]. 14<sup>th</sup> cycle: Yout[19:12]. 15<sup>th</sup> cycle: Yout[11:4]. 16<sup>th</sup> cycle: Zout[19:12]. 17<sup>th</sup> cycle: Zout[11:4]. 18<sup>th</sup> cycle: Xout[3:2] for 18bits mode. Xout[3:0] for 20bits mode 19<sup>th</sup> cycle: Yout[3:2] for 18bits mode. Yout[3:0] for 20bits mode 20<sup>th</sup> cycle: Zout[3:2] for 18bits mode. Zout[3:0] for 20bits mode:0]. Master ends communications by NOT sending an 'Acknowledge' and also follows with a 'STOP' command. ### **EXAMPLE OF CONTINUOUS MODE** The MMC5616WA is designed with an on-chip continuous mode, or CMM. When enabled, the part will periodically take a measurement and store the results in I<sup>2</sup>C register. The frequency of these measurements is controlled by a setting in I<sup>2</sup>C register. The results of the last measurement can be read by the host. This mode, while it consumes more current, eliminates the need for the host to request measurements every time. First the user needs to write the desired number into ODR[7:0]. It should be a non-zero integer, otherwise the continuous mode will not be activated. Then Cmm\_freq\_en is set to 1 to let the internal circuitry to calculate the target number for the counter. After that Cmm\_en is set to 1 and the continuous mode is started and the internal counter starts to count at the same time. #### **EXAMPLE OF RESET** 1<sup>st</sup> cycle: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (The MEMSIC device pulls the SDA line low during the 9<sup>th</sup> SCL pulse), the master device sends [00011011] as the target address (Internal Control Register 0). The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse). **3<sup>rd</sup> cycle**: The Master device writes to the MEMSIC device's Internal Control 0 register the code [00010000] (RESET bit) to initiate a RESET action. The MEMSIC device should send an Acknowledge. At this point, the MEMSIC AMR sensors have been conditioned for optimum performance and data measurements can commence. #### **EXAMPLE OF SET** 1st cycle: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (The MEMSIC device pulls the SDA line low during the 9<sup>th</sup> SCL pulse), the master device sends [00011011] as the target address (Internal Control Register 0). The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse). **3<sup>rd</sup> cycle**: The Master device writes to the MEMSIC device's Internal Control 0 register the code [00001000] (SET bit) to initiate a SET action. The MEMSIC device should send an Acknowledge. #### USING SET AND RESET TO REMOVE BRIDGE OFFSET The integrated SET and RESET functions of the MMC5616WA enables the user to remove the error associated with bridge Offset change as a function of temperature, thereby enabling more precise heading measurements over a wider temperature than competitive technologies. The SET and RESET functions effectively alternately flip the magnetic sensing polarity of the sensing elements of the device. - 1) The most accurate magnetic field measurements can be obtained by using the protocol described as follows: Perform SET. This sets the internal magnetization of the sensing resistors in the direction of the SET field. - 2) Perform MEASUREMENT. This measurement will contain not only the sensors response to the external magnetic field. H, but also the Offset; in other words. ### Output1 = +H + Offset. - 3) Perform RESET. This resets the internal magnetization of the sensing resistors in the direction of the RESET field, which is opposite to the SET field (180° opposed). - 4) Perform MEASUREMENT. This measurement will contain both the sensors response to the external field and also the Offset. In other words, Output2 = -H + Offset. 5) Finally, calculate H by subtracting the two measurements and dividing by 2. This procedure effectively eliminates the Offset from the measurement and therefore any changes in the Offset over temperature. H = (Output1-Ouput2)/2. #### Note: • To calculate and store the offset; add the two measurements and divide by 2. This calculated offset value can be subtracted from subsequent measurements to obtain H directly from each measurement. ### **EXAMPLE OF SELFTEST** The MMC5616WA is designed with an on-chip selftest signal to do self-diagnose of the sensor: - 1) Read out the selftest signal stored at register 27H, 28H, and 29H. - 2) Calculate the selftest signal threshold with 80% of the data readout from above registers. - 3) Write the threshold in to the register 1EH, 1FH, and 20H. - 4) Write [01000001] (TM\_M and auto\_st\_en high) to Internal Control Register 1BH to initiate a selftest. - 5) Read out value of Sat\_sensor bit at the Device Status register 18H. - 6) Sat\_sensor=0, PASS selftest. ### **EXAMPLE OF PASSWORD** **1st cycle**: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (The MEMSIC device pulls the SDA line low during the 9<sup>th</sup> SCL pulse), the master device sends [00100001] as the target address (Internal Control Register 0). The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse). **3<sup>rd</sup> cycle**: The Master device writes to the MEMSIC device's Internal Control 0 register the code [11100001] (PASSWORD bit) to initiate a SET action. The MEMSIC device should send an Acknowledge. #### **EXAMPLE OF FIFO ENABLE** **1**<sup>st</sup> **cycle**: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (The MEMSIC device pulls the SDA line low during the 9<sup>th</sup> SCL pulse), the master device sends [00001110] as the target address (Internal Control Register 0). The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse). **3<sup>rd</sup> cycle**: The Master device writes to the MEMSIC device's Internal Control 0 register the code [00000001] (PASSWORD bit) to initiate a SET action. The MEMSIC device should send an Acknowledge. #### **EXAMPLE OF FIFO ENABLE AND ADDRESS LOOPBACK ENABLE** 1<sup>st</sup> cycle: A START condition is established by the Master Device followed by a call to the slave address [0110000] with the eighth bit held low to indicate a WRITE request. **2<sup>nd</sup> cycle**: After an acknowledge signal is received by the master device (The MEMSIC device pulls the SDA line low during the 9<sup>th</sup> SCL pulse), the master device sends [00001110] as the target address (Internal Control Register 0). The MEMSIC device should acknowledge receipt of the address (9<sup>th</sup> SCL pulse). **3<sup>rd</sup> cycle**: The Master device writes to the MEMSIC device's Internal Control 0 register the code [10000001] (PASSWORD bit) to initiate a SET action. The MEMSIC device should send an Acknowledge. ### INITIATING I3C COMMUNICATION AND DYNAMIC ADDRESS ASSIGNMENT. MMC5616WA defaults to I2C mode of communication when power is first applied. Once it detects a READ or WRITE command to address 0x7E MMC5616WA will switch to I3C mode. It will remain in I3C mode until power is removed. Since MMC5616WA has Static I2C address 0x30 (unless ordered in a different configuration) it is recommended to use SETDASA CCC to assign Dynamic Address. MMC5616WA also supports Minimal Bus Point-To-Point Communication, which is a special case of SETDASA CCC. The I3C Master may use ENTDAA CCC to assign Dynamic Address. The 48-bit Provisional ID is 0x08\_A2\_00\_00\_00\_00. (Haidong, this is assuming we did not program anything into its OTP registers. I think we should program something just to be different. Also need to verify this is true.) ### SDR COMMUNICATION Once MMC5616WA is assigned a Dynamic Address it is ready for SDR communication. The Master can read and write to various registers. List of registers and their definitions are provided later in this document. Also at this point MMC5616WA will respond to supported CCC's. ### **DEVICE STATUS** I3C defines a 2-byte Status word. The first byte is Status1 register 0x18, and the second byte is the Status0 register 0x19. These registers are defined below. in register map #### **GETHDRCAP CCC** MMC5616WA supports HDR-DDR mode. It will return 0x01 in response to GETHDRCAP CCC. ### IN-BAND INTERRUPT (IBI) If there is a pending interrupt MMC5616WA will initiate an IBI request. There is a Mandatory Data Byte which the Master must read if the IBI was accepted. The Mandatory Data Byte is the same as Status1 register 0x18 defined below. Need to verify this. #### SETXTIME CCC MMC5616WA supports the synchronous timing control as described in the section of SETXTIME of the I3C specification V1.0. This technique provides an approach to synchronize the activities of sensors on I3C bus. In order for the timing control to work properly, five messages are necessary, which include output data rate (ODR), time period and phase (TPH), time unit (TU), synchronization tick (ST) and delay time (DT). ODR, TPH and TU can be defined by either writing to corresponding registers, or through SETXTIME CCC command followed by defining bytes. ST and DT are delivered by SETXTIME CCC command followed by defining bytes. If SETXTIME CCC commands are preferred, users should refer to the following table for the values of the defining bytes. | Defining<br>byte<br>value | Sub-<br>Command<br>Function | Description | Additional Data Bytes | | |---------------------------|-----------------------------|---------------------------------------------------------------------------------------------------|------------------------------------------------------------|--| | 0x7F | Sync Tick<br>"ST" | Marks the START condition, which is used as the reference time for the synchronization procedure. | None | | | 0xBF | Delay Time<br>"DT" | Transfers the Delay Time value | One byte: Delay from correct TPH Start to ST marked START. | | | 0x3F | TPH | Specifies the repetition period of synchronization event. | One byte. | | | 0x9F | TU | Specifies the Time Unit used for DT command. | One byte. | | | 0x8F | ODR | Specifies the output data rate of the sensor. | One byte. | | The registers for ODR, TPH and TU will be provided in later sections as well, in case users prefer writing to registers to define such parameters. ### HDR-DDR MODE. MMC5616WA supports HDR-DDR mode. It is invoked with ENTHDR0 CCC. It does not support other HDR modes. If the Master issues any of the ENTHDR2 – ENTHDR7 CCC's, MMC5616WA will tristate its SDA output and wait for the HDR-EXIT pattern. Once MMC5616WA received an ENTHDR0 CCC it will switch to HDR-DDR mode. It will remain in this mode until it detects HDR-EXIT pattern. HDR-DDR WRITE commands. Basic structure of an HDR-DDR command is as following: 2 preamble bits P1 and P0 16 bits of data called Payload. 2 parity bits, also called P1 and P0 The whole frame is 20 bits long. The MSB of the Payload is the R/W bit. It should be 0 for the Write commands. The next 7 bits of the Payload are the Command. MMC5616WA only allows a single Write command value 7'h3B. The next 7 bits of the Payload are the Dynamic Address The last (LSB) bit of the Payload is calculated to make parity bit P0 = 1. A Data Word follows the Command word. Its structure is: 2 preamble bits P1, P0 2 data bytes #### 2 Parity bits P1 and P0. The two data bytes of the Data Word define how MMC5616WA is going to respond. The following six Write commands are defined: Data Word = 16'h0001 -> Take Measure Magnetic. This has the same effect as writing bit Take\_meas\_M high. Data Word = 16'h0003 -> Take Measure Temperature. This has the same effect as writing bit Take meas T high. Data Word = 16'h0004 -> Turn On Continuous Mode. This has the same effect as writing bit Cmm\_en high. Data Word = 16'h0005 -> Do Set. This has the same effect as writing bit "Do Set" high. Data Word = 16'h0006 -> Turn Off Continuous Mode This has the same effect as writing bit Cmm en low. Data Word = 16'h0007 -> Do Reset. This has the same effect as writing bit "Do Reset" high. A CRC word must follow the Data Word as defined in the MIPI I3C Specification. HDR-DDR READ commands. In case of READ command from the Master, the format is a little different. There is no Data Word. The first frame following the HDR Restart has a preamble of 01 and then a Command. The Command has MSB as R/W bit set high, 7-bit Dynamic Address, and a 7-bit Command Code. The last bit of this 16-bit word is picked to make parity bit P0 = 1. MMC5616WA allows the following Command Codes: 7'h21 -> RDSHORT 7'h22 -> RDLONG 7'h23 -> RDSTAT If MMC5616WA receives RDSHORT command it will return 3 frames (6 bytes) of data. This data is 16-bit values of X, Y, and Z magnetic field. The first frame payload consists of registers 0x00 followed by register 0x01. The second frame payload consists of registers 0x02 and 0x03. The third fame payload consists of registers 0x04 and 0x05. If MMC5616WA receives RDLONG command it will return 5 frames (10 bytes) of data. This allows the user to read 20-bit magnetic field values as well as 8-bit temperature value. The first frame payload consists of registers 0x00 followed by register 0x01. The second frame outputs registers 0x02 and 0x03. The third one registers 0x04 and 0x05. The fourth one outputs registers 0x06 and 0x07, and the fifth one registers 0x08 and 0x09. If MMC5616WA receives a RDSTAT command, it will output a single frame (16 bits). The output data consists of Status registers 0x18 and 0x19. These Data Words are followed by a CRC word as defined in the MIPI I3C Spec. Table 1. I3C I/O Stage Characteristics Common to Push-Pull Mode and Open Drain Mode | Parameter | Symbol | Conditions | Min | Тур | Max | Unit | Notes | |-------------------------|----------------------------------------------------|------------|------|-----|-------------------------------------|------|-------| | Operating Voltage | V <sub>IO</sub><br>(different<br>from I3C<br>Spec) | - | 1.1 | | VDD<br>(power<br>supply<br>voltage) | V | | | Low Level Input Voltage | V <sub>IL</sub> | - | -0.3 | - | 0.3* V <sub>IO</sub> | V | | | High Level Input<br>Voltage | V <sub>IH</sub> | - | 0.7*V <sub>IO</sub> | - | V <sub>IO</sub> +0.3 | V | |--------------------------------------------|-----------------|--------------------------------------------------------------|-----------------------|---|----------------------|----| | Output Low Level | V <sub>OL</sub> | Iol=3mA | - | - | 0.27 | V | | Input Current (per Input-<br>Only I/O Pin) | | -100 mV < Vi < V <sub>IO</sub> + | -10 | | 10 | μΑ | | Capacitance (per I/O<br>Pin) | C <sub>i</sub> | | | | 10 | pF | | Capacitance Mismatch<br>Between pins | ΔC | Difference between<br>SDA and SCL<br>capacitance CI ≤<br>5pF | | | 1.5 | pF | | | | Difference between SDA and SCL capacitance CI > 5pF | | | 3 | pF | | Output High Level.<br>Push-Pull only. | V <sub>он</sub> | I <sub>OH</sub> = -3mA | V <sub>DD</sub> -0.27 | | | V | Table 2. I3C Push-Pull Timing Parameters for SDR and HDR-DDR Modes | Parameter | Symbol | Timing<br>Diagram | Min | Тур | Max | Units | Notes | |--------------------------------|--------------------|-------------------|------|-----|---------------------------------------------|-------|----------------------------| | SCL clock | F <sub>SCL</sub> | | 0.95 | | 12.9 | MHZ | | | SCL Clock Low Period | t <sub>LOW</sub> | | 24 | | | | | | | t <sub>DIG_L</sub> | | 32 | | | | | | SCL Clock High Period | t <sub>HIGH</sub> | | 24 | | | | | | | t <sub>DIG_H</sub> | | 32 | | | | | | Clock in to Data Out for Slave | tsco | | | | 17 | ns | I3C Spec<br>says 12<br>max | | SCL Clock Rise Time | t <sub>CR</sub> | | | | 150*1/f <sub>SCL</sub><br>(capped<br>at 60) | ns | | | SCL Clock Fall Time | t <sub>CF</sub> | | 150*1/f <sub>SCL</sub><br>(capped<br>at 60) | ns | | |----------------------------------------|--------------------|---|---------------------------------------------|----|--| | SDA Signal Data Hold in Push-Pull Mode | t <sub>SU_PP</sub> | 0 | | ns | | ### **OPERATING TIMING** SET/RESET Take Measurement Read data Repeat T & R Wait the device to be ready for next operation ### **Operating Timing Diagram** | Parameter | Symbol | Min. | Max. | Unit | |----------------------------------------------------------------|-----------------------|------|------|------| | Time to operate device after V <sub>DD</sub> valid | top | 5 | | ms | | Minimum time interval between SET or RESET to other operations | tsr | 1 | | ms | | | t <sub>TM</sub> BW=00 | 6.6 | | ms | | | t™ BW=01 | 3.5 | | ms | | | t™ BW=10 | 2.0 | | ms | | | t™ BW=11 | 1.2 | | ms | ### **SOLDERING RECOMMENDATIONS** MEMSIC magnetic sensor is capable of withstanding an MSL1 / 260 °C solder reflow. Following is the reflow profile: Time (S) ### Note: - The second reflow cycle should be applied after device has cooled down to 25 °C (room temperature) - This is the reflow profile for Pb free process - The peak temperature on the sensor surface should be limited under 260 $^{\circ}$ C for 10 seconds. - Solder paste's reflow recommendation should be followed to get the best SMT quality. If the part is mounted manually, please ensure the temperature could not exceed 260 $^{\circ}$ C for 10 seconds. ### **PACKAGE DRAWING (WLP package)** ### RECOMMENDED LAND PATTERN DESIGN UNIT: mm ### RELATIONSHIP BETWEEN THE MAGNETIC FIELD AND OUTPUT CODE The measurement data increases as the magnetic flux density increases in the arrow directions. ## **Revision History** | Date | Revision | Description | |---------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 2023-02 | Preliminary | Preliminary version for internal review | | 2023-05 | Version 1.0 | <ol> <li>Change V<sub>DD</sub> minimum value from 1.62V to 1.7V</li> <li>Change I3C minimum frequency from 0.01MHz to 0.4MHz</li> <li>Remove I3C CCC command GETMXDS and GETXTIME</li> <li>Add description of auto voltage detection method for determining the value of V<sub>IO</sub></li> </ol> | | 2023-05 | Version 1.1 | Remove max. value of Transverse Sensitivity | | 2023-05 | Version 1.2 | Change I3C minimum frequency from 0.4MHz to 0.95MHz based on the 1000 hours Qual. testing results. | | 2023-06 | Version 1.4 | <ol> <li>Add operating timing on I<sup>2</sup>C/I3C bus right after power on.</li> <li>Update the Max Output Data Rate of BW=01 and 11.</li> </ol> | | 2023-12 | Version 1.5 | Remove the 3.6V VDD supporting with I3C interface | | 2024-01 | Version 1.6 | Correct some typos | ## **X-ON Electronics** Largest Supplier of Electrical and Electronic Components Click to view similar products for Board Mount Hall Effect/Magnetic Sensors category: Click to view products by Memsic manufacturer: Other Similar products are found below: HGPRDT005A AH1894-FA-7 AH277AZ4-AG1 AV-10448 SS41C AH1894-Z-7 TLE4946-1L TLE4976L SS85CA BU52003GUL-E2 AH277AZ4-BG1 AH3376-P-B TLE4941 TLE4945-2L AH3360-FT4-7 TLE4941-1 AH374-P-A SS41-JL AH1913-W-7 AH3373-P-B MA732GQ-Z MA330GQ-Z S-57K1NBL2A-M3T2U S-57P1NBL9S-M3T4U S-576ZNL2B-L3T2U S-576ZNL2B-A6T8U S-57P1NBL0S-M3T4U S-57A1NSL1A-M3T2U S-57K1RBL1A-M3T2U S-57P1NBH9S-M3T4U S-57P1NBH0S-M3T4U S-57A1NSH1A-M3T2U S-57A1NSH2A-M3T2U S-57K1NBH1A-M3T2U S-57A1NNL1A-M3T2U S-5701BC11B-L3T2U5 S-57GNNL3S-A6T8U S-57TZ1L1S-A6T8U S-57GSNL3S-A6T8U S-57RBNL9S-L3T2U S-57GNNL3S-L3T2U S-57RBNL8S-L3T2U S-57RBNL9S-A6T8U S-57RBNL8S-L3T2U S-57RBNL9S-L3T2U S-57TZ1L1S-L3T2U S-57TZNL1S-A6T8U