2020-05-05 11:22:16 -04:00
/*
* Copyright ( c ) 2020 DarkMatterCore
*
* This program is free software ; you can redistribute it and / or modify it
* under the terms and conditions of the GNU General Public License ,
* version 2 , as published by the Free Software Foundation .
*
* This program is distributed in the hope it will be useful , but WITHOUT
* ANY WARRANTY ; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE . See the GNU General Public License for
* more details .
*
* You should have received a copy of the GNU General Public License
* along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# pragma once
# ifndef __USB_H__
# define __USB_H__
# include <switch.h>
2020-05-06 10:04:10 -04:00
# define USB_TRANSFER_BUFFER_SIZE 0x800000 /* 8 MiB */
2020-05-05 11:22:16 -04:00
2020-05-06 10:04:10 -04:00
/// Initializes the USB interface, input and output endpoints and allocates an internal transfer buffer.
2020-05-05 11:22:16 -04:00
bool usbInitialize ( void ) ;
/// Closes the USB interface, input and output endpoints and frees the transfer buffer.
void usbExit ( void ) ;
2020-05-07 07:08:54 -04:00
/// Returns a pointer to a heap-allocated, page-aligned memory buffer that's suitable for USB transfers.
void * usbAllocatePageAlignedBuffer ( size_t size ) ;
2020-05-05 11:22:16 -04:00
2020-05-07 23:48:22 -04:00
/// Starts a data transfer session with the connected host device. Returns true if the host device replies with valid data within a certain time span.
2020-05-07 07:08:54 -04:00
/// This should be called before usbSendFileProperties().
2020-05-07 23:48:22 -04:00
bool usbStartSession ( void ) ;
2020-05-05 11:22:16 -04:00
2020-05-07 23:48:22 -04:00
/// Sends file properties to the host device before starting a file data transfer. Must be called before usbSendFileData(), and after usbStartSession().
2020-05-05 11:22:16 -04:00
bool usbSendFileProperties ( u64 file_size , const char * filename ) ;
2020-05-07 07:08:54 -04:00
/// Performs a file data transfer. Must be continuously called after usbSendFileProperties() until all file data has been transferred.
2020-05-05 11:22:16 -04:00
/// Data chunk size must not exceed USB_TRANSFER_BUFFER_SIZE.
2020-05-07 07:08:54 -04:00
bool usbSendFileData ( void * data , u64 data_size ) ;
2020-05-05 11:22:16 -04:00
2020-05-07 23:48:22 -04:00
/// Ends a previously started data transfer session with the connected host device.
void usbEndSession ( void ) ;
2020-05-05 11:22:16 -04:00
# endif /* __USB_H__ */