4.37. SBC

4.37.1. Module Files

4.37.1.1. Vendor Driver

Note

This driver has been provided by NXP Semiconductors, Inc. under the 3-Clause BSD License. It has been adapted to pass the interface configuration as parameter into the functions to enable the usage of multiple ICs in the system.

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x_assert.h

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x_common.h

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x_communication.c

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x_communication.h

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x_map.h

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x.c

  • src/app/driver/sbc/fs8x_driver/sbc_fs8x.h

4.37.1.2. Driver

  • src/app/driver/sbc/sbc.c

  • src/app/driver/sbc/sbc.h

  • src/app/driver/sbc/nxpfs85xx.c

  • src/app/driver/sbc/nxpfs85xx.h

4.37.1.3. Configuration

none

4.37.1.4. Unit Test

  • tests/unit/app/driver/sbc/test_sbc.c

  • tests/unit/app/driver/sbc/test_nxpfs85xx.c

4.37.2. Description

As long as the Ignition signal is present, the SBC is operating normally in Running mode. If the Ignition signal is removed, the MCU will request to send the SBC to Standby mode. If no Ignition signal is present in Standby mode, the SBC will power down and also stop powering the MCU, which will then also shut down. When the Ignition signal is detected again at the SBC, it will start up and power the MCU. The MCU will then initialize the SBC, which will return to normal operation in Running mode after the initialization is complete. This sequence is shown in Fig. 4.18.

# Copyright (c) 2010 - 2024, Fraunhofer-Gesellschaft zur Foerderung der angewandten Forschung e.V.
# All rights reserved.
#
# SPDX-License-Identifier: BSD-3-Clause
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# 1. Redistributions of source code must retain the above copyright notice, this
#    list of conditions and the following disclaimer.
#
# 2. Redistributions in binary form must reproduce the above copyright notice,
#    this list of conditions and the following disclaimer in the documentation
#    and/or other materials provided with the distribution.
#
# 3. Neither the name of the copyright holder nor the names of its
#    contributors may be used to endorse or promote products derived from
#    this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#
# We kindly request you to use one or more of the following phrases to refer to
# foxBMS in your hardware, software, documentation or advertising materials:
#
# - "This product uses parts of foxBMS®"
# - "This product includes parts of foxBMS®"
# - "This product is derived from foxBMS®"

digraph sbc_wakeup_states {
    rankdir=LR;

    node [shape = doublecircle]     sbc_running
                                    sbc_power_down;

    node [shape = circle]           sbc_standby
                                    sbc_initialize
                                    ;

    sbc_running        [label=<<B>Running</B>>];
    sbc_standby        [label=<<B>Standby</B>>];
    sbc_power_down     [label=<<B>Power Down</B>>];
    sbc_initialize     [label=<<B>Initialize</B>>];

    sbc_running -> sbc_running [label = "Ignition = 1"]
    sbc_running -> sbc_standby [label = "Ignition = 0"]
    sbc_standby -> sbc_running [label = "Ignition = 1"]
    sbc_standby -> sbc_power_down [label = "Ignition = 0"]
    sbc_power_down -> sbc_initialize [label = "Ignition = 1"]
    sbc_power_down -> sbc_power_down [label = "Ignition = 0"]
    sbc_initialize -> sbc_running
    ;
}

Fig. 4.18 SBC wakeup state chart

4.37.3. FAQs

Question:

The MC33FS830A0ES needs to be programmed. Can the programming procedure for NXP MC33FS8530A0ES be shared?

Answer:

Unfortunately not. The details of how to program the MC33FS830A0ES cannot be shared due to NDAs. You need to get in contact with the manufacturer for this information.