🎉 SmartCode v10.4r1 available! We're happy to announce the public release of our SmartCode v10.4r1 Contact us

Emulator buffer is full

09-Jun-2025

When the Analyzer stops sampling with the note Trace sampling stopped, reason: Emulator buffer full. A situation has occurred in which the trace RAM buffer of the BlueBox is full and no longer able to accept new data. This happens when trace data is being received faster than the BlueBox is capable of sending out to the PC.




Possible solutions

    Use USB communication instead of Ethernet

    USB settings
    • Use a USB 3.0 port and cable to achieve maximum USB speed.
    • Check if your USB port is connected directly to the chipset/CPU and that it isn't connected to PCIe bus (usually slower).


      Check UL/crossbar USB speed

      Check UL/crossbar speed to get an indication of how fast the data can be read from the BlueBox through the USB connection:

      1. Enable logging via Help | Support | Log, option 3.

      2. Attach to the target.

      3. Search in the log file for Xbar INFO. The value reported here is representing bandwidth in KBytes/s. This speed must be higher than that of the trace filling the buffer. 


      Capable PC storage

      Check if the storage on your PC, on which the trace data is saved, is fast enough to keep up with the USB transfer rate. Windows has receive/transmit buffers for USB communication, but these buffers are small,   and if the disk is slow, the USB communication speed is consequently reduced.


      %ISYSTEM_TEMP% pointing to SSD storage

      If your %TEMP% folder is not yet located on an SSD, set the %ISYSTEM_TEMP% environment variable to point to a location on an SSD storage.


      More temp space

      Make sure you have at least 5 times more temp space as is the TRD file limit.


      Reduce the amount of trace data

      If USB speed and the disk drive speed can not be further improved, reduce the amount of trace data that is recorded by the Analyzer by:

      • Limiting the scope of the recorded variables or
      • Excluding code sections that generate excessive amounts of trace messages (such as idle loops)
      • Using instrumentation trace (either via data trace, if it can be separated from program trace, or STM trace) is more recommended for large trace recordings than raw program trace.


      More resources

          Was this answer helpful?