All Downloads are FREE. Search and download functionalities are using the official Maven repository.

uk.pigpioj.PigpioWaveformInterface Maven / Gradle / Ivy

package uk.pigpioj;

public interface PigpioWaveformInterface {
	/**
	 * This function clears all waveforms and any data added by calls to the gpioWaveAdd* functions.
	 * @return Returns 0 if OK.
	 */
	int gpioWaveClear();
	
	/**
	 * This function starts a new empty waveform.
	 * You wouldn't normally need to call this function as it is automatically called after a
	 * waveform is created with the gpioWaveCreate function.
	 * @return Returns 0 if OK.
	 */
	int gpioWaveAddNew();
	
	/**
	 * This function adds a number of pulses to the current waveform.
	 * The pulses are interleaved in time order within the existing waveform (if any).
	 * Merging allows the waveform to be built in parts, that is the settings for GPIO#1 can be added, and then GPIO#2 etc.
	 * If the added waveform is intended to start after or within the existing waveform then the first pulse should
	 * consist of a delay.
	 * @param pulses An array of pulses
	 * @return Returns the new total number of pulses in the current waveform if OK, otherwise PI_TOO_MANY_PULSES.
	 */
	int gpioWaveAddGeneric(GpioPulse[] pulses);
	
	/**
	 * This function adds a waveform representing serial data to the existing waveform (if any).
	 * The serial data starts offset microseconds from the start of the waveform.
	 * NOTES:
	 * The serial data is formatted as one start bit, data_bits data bits, and stop_bits/2 stop bits.
	 * It is legal to add serial data streams with different baud rates to the same waveform.
	 * numBytes is the number of bytes of data in str.
	 * The bytes required for each character depend upon data_bits.
	 * For data_bits 1-8 there will be one byte per character.
	 * For data_bits 9-16 there will be two bytes per character.
	 * For data_bits 17-32 there will be four bytes per character.
	 * @param userGpio 0-31
	 * @param baud 50-1000000
	 * @param dataBits 1-32
	 * @param stopBits 2-8
	 * @param offset >= 0
	 * @param str An array of chars (which may contain nulls)
	 * @return Returns the new total number of pulses in the current waveform if OK, otherwise PI_BAD_USER_GPIO,
	 * PI_BAD_WAVE_BAUD, PI_BAD_DATABITS, PI_BAD_STOPBITS, PI_TOO_MANY_CHARS, PI_BAD_SER_OFFSET, or PI_TOO_MANY_PULSES.
	 */
	int gpioWaveAddSerial(int userGpio, int baud, int dataBits, int stopBits, int offset,
			byte[] str);
	
	/**
	 * This function creates a waveform from the data provided by the prior calls to the gpioWaveAdd* functions.
	 * Upon success a wave id greater than or equal to 0 is returned, otherwise PI_EMPTY_WAVEFORM, PI_TOO_MANY_CBS,
	 * PI_TOO_MANY_OOL, or PI_NO_WAVEFORM_ID.
	 * The data provided by the gpioWaveAdd* functions is consumed by this function.
	 * As many waveforms may be created as there is space available. The wave id is passed to gpioWaveTxSend to specify the waveform to transmit.
	 * Normal usage would be
	 * Step 1. gpioWaveClear to clear all waveforms and added data.
	 * Step 2. gpioWaveAdd* calls to supply the waveform data.
	 * Step 3. gpioWaveCreate to create the waveform and get a unique id
	 * Repeat steps 2 and 3 as needed.
	 * Step 4. gpioWaveTxSend with the id of the waveform to transmit.
	 * A waveform comprises one of more pulses. Each pulse consists of a GpioPulse structure.
	 * The fields specify
	 * 1) the GPIO to be switched on at the start of the pulse.
	 * 2) the GPIO to be switched off at the start of the pulse.
	 * 3) the delay in microseconds before the next pulse.
	 * Any or all the fields can be zero. It doesn't make any sense to set all the fields to zero (the pulse will be ignored).
	 * When a waveform is started each pulse is executed in order with the specified delay between the pulse and the next.
	 * @return Returns the new waveform id if OK, otherwise PI_EMPTY_WAVEFORM, PI_NO_WAVEFORM_ID, PI_TOO_MANY_CBS, or PI_TOO_MANY_OOL.
	 */
	int gpioWaveCreate();
	
	/**
	 * Similar to gpioWaveCreate, this function creates a waveform but pads the consumed resources.
	 * Padded waves of equal dimension can be re-cycled efficiently allowing newly created waves to re-use the
	 * resources of deleted waves of the same dimension.
	 * Waveform data provided by gpioWaveAdd* and rawWaveAdd* functions are consumed by this function.
	 * A usage would be the creation of two waves where one is filled while the other is being transmitted.
	 * Each wave is assigned 50% of the resources. This buffer structure allows the transmission of infinite wave sequences.
	 * @param pctCB 0-100, the percent of all DMA control blocks to consume.
	 * @param pctBOOL 0-100, percent On-Off-Level (OOL) buffer to consume for wave output.
	 * @param pctTOOL 0-100, the percent of OOL buffer to consume for wave input (flags).
	 * @return Upon success a wave id greater than or equal to 0 is returned, otherwise PI_EMPTY_WAVEFORM,
	 * PI_TOO_MANY_CBS, PI_TOO_MANY_OOL, or PI_NO_WAVEFORM_ID.
	 */
	int gpioWaveCreatePad(int pctCB, int pctBOOL, int pctTOOL);
	
	/**
	 * This function deletes the waveform with id wave_id.
	 * The wave is flagged for deletion. The resources used by the wave will only be reused when either of the following apply.
	 * - all waves with higher numbered wave ids have been deleted or have been flagged for deletion.
	 * - a new wave is created which uses exactly the same resources as the current wave (see the C source for gpioWaveCreate for details).
	 * Wave ids are allocated in order, 0, 1, 2, etc.
	 * @param waveId >= 0, as returned by gpioWaveCreate
	 * @return Returns 0 if OK, otherwise PI_BAD_WAVE_ID.
	 */
	int gpioWaveDelete(int waveId);
	
	/**
	 * This function transmits the waveform with id wave_id. The mode determines whether the waveform is sent once or
	 * cycles endlessly. The SYNC variants wait for the current waveform to reach the end of a cycle or finish before
	 * starting the new waveform.
	 * WARNING: bad things may happen if you delete the previous waveform before it has been synced to the new waveform.
	 * NOTE: Any hardware PWM started by gpioHardwarePWM will be cancelled.
	 * @param waveId >= 0, as returned by gpioWaveCreate
	 * @param waveMode PI_WAVE_MODE_ONE_SHOT, PI_WAVE_MODE_REPEAT, PI_WAVE_MODE_ONE_SHOT_SYNC, PI_WAVE_MODE_REPEAT_SYNC
	 * @return Returns the number of DMA control blocks in the waveform if OK, otherwise PI_BAD_WAVE_ID, or PI_BAD_WAVE_MODE.
	 */
	int gpioWaveTxSend(int waveId, int waveMode);

	/**
	 * This function transmits a chain of waveforms.
	 * NOTE: Any hardware PWM started by gpioHardwarePWM will be cancelled.
	 * The waves to be transmitted are specified by the contents of buf which contains an ordered list of wave_ids and
	 * optional command codes and related data.
	 * Each wave is transmitted in the order specified. A wave may occur multiple times per chain.
	 * A blocks of waves may be transmitted multiple times by using the loop commands. The block is bracketed by loop start and end commands. Loops may be nested.
	 * Delays between waves may be added with the delay command.
	 * The following command codes are supported:
	 * 
	 * Name          Cmd & Data  Meaning
	 * Loop Start    255 0       Identify start of a wave block
	 * Loop Repeat   255 1 x y   loop x + y*256 times
	 * Delay         255 2 x y   delay x + y*256 microseconds
	 * Loop Forever  255 3       loop forever
	 * 
* If present Loop Forever must be the last entry in the chain. * The code is currently dimensioned to support a chain with roughly 600 entries and 20 loop counters. * @param buf The wave_ids and optional command codes * @return Returns 0 if OK, otherwise PI_CHAIN_NESTING, PI_CHAIN_LOOP_CNT, PI_BAD_CHAIN_LOOP, PI_BAD_CHAIN_CMD, * PI_CHAIN_COUNTER, PI_BAD_CHAIN_DELAY, PI_CHAIN_TOO_BIG, or PI_BAD_WAVE_ID. */ int gpioWaveChain(byte[] buf); /** * This function returns the id of the waveform currently being transmitted. * @return Returns the waveform id or one of the following special values: PI_WAVE_NOT_FOUND (9998) - transmitted wave not found. PI_NO_TX_WAVE (9999) - no wave being transmitted. */ int gpioWaveTxAt(); /** * This function checks to see if a waveform is currently being transmitted. * @return Returns 1 if a waveform is currently being transmitted, otherwise 0. */ int gpioWaveTxBusy(); /** * This function aborts the transmission of the current waveform. * This function is intended to stop a waveform started in repeat mode. * @return Returns 0 if OK. */ int gpioWaveTxStop(); /** * This function returns the length in microseconds of the current waveform. * @return The length in microseconds of the current waveform. */ int gpioWaveGetMicros(); /** * This function returns the length in microseconds of the longest waveform created since gpioInitialise was called. * @return The length in microseconds of the longest waveform created since gpioInitialise was called. */ int gpioWaveGetHighMicros(); /** * This function returns the maximum possible size of a waveform in microseconds. * @return The maximum possible size of a waveform in microseconds. */ int gpioWaveGetMaxMicros(); /** * This function returns the length in pulses of the current waveform. * @return The length in pulses of the current waveform. */ int gpioWaveGetPulses(); /** * This function returns the length in pulses of the longest waveform created since gpioInitialise was called. * @return The length in pulses of the longest waveform created since gpioInitialise was called. */ int gpioWaveGetHighPulses(); /** * This function returns the length in pulses of the longest waveform created since gpioInitialise was called. * @return The length in pulses of the longest waveform created since gpioInitialise was called. */ int gpioWaveGetMaxPulses(); /** * This function returns the length in DMA control blocks of the current waveform. * @return The length in DMA control blocks of the current waveform. */ int gpioWaveGetCbs(); /** * This function returns the length in DMA control blocks of the longest waveform created since gpioInitialise was called. * @return The length in DMA control blocks of the longest waveform created since gpioInitialise was called. */ int gpioWaveGetHighCbs(); /** * This function returns the maximum possible size of a waveform in DMA control blocks. * @return The maximum possible size of a waveform in DMA control blocks. */ int gpioWaveGetMaxCbs(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy