Sensor Control Technical Specification

Overview

This document specifies the functionality of the sensor control module. The sensor control module is a comportable front-end to the analog sensor top.

It provides basic alert functionality, pad debug hook ups, and a small amount of open source visible status readback. Long term, this is a module that can be absorbed directly into the analog sensor top.

Features

  • Alert hand-shake with analog sensor top
  • Alert forwarding to alert handler
  • Status readback for analog sensor top
  • Pad debug hook up for analog sensor top
  • Wakeup based on alert events

Theory of Operations

Block Diagram

The diagram below shows how sensor control helps analog sensor top integration into the overall design.

Recoverable and Fatal Alerts

The analog sensor top sends alert requests in independent, differential form to the sensor control. Each alert request consists of a pair of signals, one active high and one active low. The active polarity of each signal is independent, due to the imprecise sensor timing that drives the alert. This means that the sensor control recognizes an active alert as long as one of the lines is active, and not the pair of signals being in a particular state. Each signal in the differential pair is thus a separate dedicated alert indicator.

Once an alert request is detected as active, the sensor control formulates a proper alert event through the prim_alert_sender and sends a notification to the alert handler.

The sensor control can optionally generate alert acknowledgements back to the analog sensor top.

For each incoming alert, it can be programmed as fatal or recoverable through {{#regref sensor_ctrl.FATAL_ALERT_EN }}. If set to recoverable, an alert will be registered in {{#regref sensor_ctrl.RECOV_ALERT }} and the original analog sensor top event acknowledged. The acknowledgement prevents alerts from constantly being sent.

If set to fatal, an alert will be registered in {{#regref sensor_ctrl.FATAL_ALERT }} but the original analog sensor top event will not be acknowledged. This causes the alert to constantly send until the system escalates in some form.

Wakeup Requests

In addition to forwarding events to the alert handler, incoming events can also be aggregated into a wakeup request to the system. The sensor control does not make assumptions about its power domains and thus it is up to the integrating system to decide which power modes allow alert event wakeups.

As an example, if the sensor control is not placed in an always on domain, then it cannot send alert based wakeups if the system is in a deep low power state. It will only be able to send wakeups when the system is powered and the clk_aon_i input is available.

Hardware Interfaces

Signals

Programmer's Guide

Each available alert has a corresponding fatality configuration. If an alert event is set to 1 in {{#regref sensor_ctrl.FATAL_ALERT_EN }}, sensor control treats it as a fatal event instead of a recoverable event. Fatal events are not acknowledged, and continuously send alert events in the system until some kind of escalation is seen.

Device Interface Functions (DIFs)

{{< dif_listing “sw/device/lib/dif/dif_sensor_ctrl.h” >}}

Register Table