mirror of
				https://github.com/espressif/esp-idf.git
				synced 2025-11-04 06:11:06 +00:00 
			
		
		
		
	Apply the pre-commit hook whitespace fixes to all files in the repo. (Line endings, blank lines at end of file, trailing whitespace)
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// Copyright 2017-2019 Espressif Systems (Shanghai) PTE LTD
 | 
						|
//
 | 
						|
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
// you may not use this file except in compliance with the License.
 | 
						|
// You may obtain a copy of the License at
 | 
						|
//
 | 
						|
//     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
//
 | 
						|
// Unless required by applicable law or agreed to in writing, software
 | 
						|
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
// See the License for the specific language governing permissions and
 | 
						|
// limitations under the License.
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
#include <stdint.h>
 | 
						|
typedef unsigned int UINT;
 | 
						|
typedef unsigned char BYTE;
 | 
						|
typedef uint32_t DWORD;
 | 
						|
 | 
						|
#define FF_DRV_NOT_USED 0xFF
 | 
						|
 | 
						|
#include "diskio.h"
 | 
						|
#include "esp_err.h"
 | 
						|
 | 
						|
/**
 | 
						|
 * Structure of pointers to disk IO driver functions.
 | 
						|
 *
 | 
						|
 * See FatFs documentation for details about these functions
 | 
						|
 */
 | 
						|
typedef struct {
 | 
						|
    DSTATUS (*init) (unsigned char pdrv);    /*!< disk initialization function */
 | 
						|
    DSTATUS (*status) (unsigned char pdrv);  /*!< disk status check function */
 | 
						|
    DRESULT (*read) (unsigned char pdrv, unsigned char* buff, uint32_t sector, unsigned count);  /*!< sector read function */
 | 
						|
    DRESULT (*write) (unsigned char pdrv, const unsigned char* buff, uint32_t sector, unsigned count);   /*!< sector write function */
 | 
						|
    DRESULT (*ioctl) (unsigned char pdrv, unsigned char cmd, void* buff); /*!< function to get info about disk and do some misc operations */
 | 
						|
} ff_diskio_impl_t;
 | 
						|
 | 
						|
/**
 | 
						|
 * Register or unregister diskio driver for given drive number.
 | 
						|
 *
 | 
						|
 * When FATFS library calls one of disk_xxx functions for driver number pdrv,
 | 
						|
 * corresponding function in discio_impl for given pdrv will be called.
 | 
						|
 *
 | 
						|
 * @param pdrv drive number
 | 
						|
 * @param discio_impl   pointer to ff_diskio_impl_t structure with diskio functions
 | 
						|
 *                      or NULL to unregister and free previously registered drive
 | 
						|
 */
 | 
						|
void ff_diskio_register(BYTE pdrv, const ff_diskio_impl_t* discio_impl);
 | 
						|
 | 
						|
#define ff_diskio_unregister(pdrv_) ff_diskio_register(pdrv_, NULL)
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 * Get next available drive number
 | 
						|
 *
 | 
						|
 * @param   out_pdrv            pointer to the byte to set if successful
 | 
						|
 *
 | 
						|
 * @return  ESP_OK              on success
 | 
						|
 *          ESP_ERR_NOT_FOUND   if all drives are attached
 | 
						|
 */
 | 
						|
esp_err_t ff_diskio_get_drive(BYTE* out_pdrv);
 | 
						|
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 |