92 lines
2.1 KiB
C++

/******************************************************************************
* Copyright (c) 2018(-2025) STMicroelectronics.
* All rights reserved.
*
* This file is part of the TouchGFX 4.25.0 distribution.
*
* This software is licensed under terms that can be found in the LICENSE file in
* the root directory of this software component.
* If no LICENSE file comes with this software, it is provided AS-IS.
*
*******************************************************************************/
/**
* @file touchgfx/hal/NoDMA.hpp
*
* Declares the touchgfx::NoDMA class.
*/
#ifndef TOUCHGFX_NODMA_HPP
#define TOUCHGFX_NODMA_HPP
#include <assert.h>
#include <touchgfx/hal/BlitOp.hpp>
#include <touchgfx/hal/DMA.hpp>
namespace touchgfx
{
/**
* This is an "empty" DMA subclass that does nothing except assert if accidentally used. An
* instance of this object can be used if DMA support is not desired.
*
* @see DMA_Interface
*/
class NoDMA : public DMA_Interface
{
public:
NoDMA()
: DMA_Interface(q), q(&b, 1)
{
}
/**
* No blit operations supported by this DMA implementation.
*
* @return Zero (no blit ops supported).
*/
virtual BlitOperations getBlitCaps()
{
return static_cast<BlitOperations>(0);
}
/**
* Asserts if used.
*
* @param blitOp The blit operation to be performed by this DMA instance.
*/
virtual void setupDataCopy(const BlitOp& blitOp)
{
assert(false && "DMA operation not supported");
}
/**
* Asserts if used.
*
* @param blitOp The blit operation to be performed by this DMA instance.
*/
virtual void setupDataFill(const BlitOp& blitOp)
{
assert(false && "DMA operation not supported");
}
/** Does nothing. */
virtual void signalDMAInterrupt()
{
}
/**
* Block until all DMA transfers are complete. Since this particular DMA does not do
* anything, return immediately.
*/
virtual void flush()
{
}
private:
LockFreeDMA_Queue q;
BlitOp b;
};
} // namespace touchgfx
#endif // TOUCHGFX_NODMA_HPP