2016-03-25 07:19:46 +01:00
/**
2016-03-24 19:01:20 +01:00
* Marlin 3 D Printer Firmware
* Copyright ( C ) 2016 MarlinFirmware [ https : //github.com/MarlinFirmware/Marlin]
*
* Based on Sprinter and grbl .
* Copyright ( C ) 2011 Camiel Gubbels / Erik van der Zalm
*
* This program is free software : you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation , either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that 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/>.
*
*/
2012-06-02 20:44:17 +02:00
# ifndef CARDREADER_H
# define CARDREADER_H
2011-11-06 21:39:53 +01:00
2016-08-03 04:36:58 +02:00
# include "MarlinConfig.h"
2015-07-31 07:21:18 +02:00
# if ENABLED(SDSUPPORT)
2011-11-26 11:51:38 +01:00
2015-03-02 16:06:01 +01:00
# define MAX_DIR_DEPTH 10 // Maximum folder depth
2013-05-04 13:18:02 +02:00
2011-11-19 13:13:34 +01:00
# include "SdFile.h"
2016-08-03 04:36:58 +02:00
# include "types.h"
2016-07-19 15:31:09 +02:00
# include "enum.h"
2015-03-02 16:06:01 +01:00
class CardReader {
2011-11-06 21:39:53 +01:00
public :
CardReader ( ) ;
2015-03-02 16:06:01 +01:00
2011-11-06 21:39:53 +01:00
void initsd ( ) ;
void write_command ( char * buf ) ;
//files auto[0-9].g on the sd card are performed in a row
//this is to delay autostart and hence the initialisaiton of the sd card to some seconds after the normal init, so the device is available quick after a reset
2015-03-02 16:06:01 +01:00
void checkautostart ( bool x ) ;
2016-03-29 12:16:35 +02:00
void openFile ( char * name , bool read , bool push_current = false ) ;
2013-04-01 01:59:16 +02:00
void openLogFile ( char * name ) ;
2012-03-03 21:58:12 +01:00
void removeFile ( char * name ) ;
2013-10-22 10:04:08 +02:00
void closefile ( bool store_location = false ) ;
2011-11-06 22:48:15 +01:00
void release ( ) ;
2016-02-21 02:35:35 +01:00
void openAndPrintFile ( const char * name ) ;
2011-11-06 22:48:15 +01:00
void startFileprint ( ) ;
2016-06-18 03:27:14 +02:00
void stopSDPrint ( ) ;
2011-11-06 22:48:15 +01:00
void getStatus ( ) ;
2011-11-26 11:51:38 +01:00
void printingHasFinished ( ) ;
2011-11-19 20:18:54 +01:00
2015-07-31 07:21:18 +02:00
# if ENABLED(LONG_FILENAME_HOST_SUPPORT)
2015-05-18 02:36:32 +02:00
void printLongPath ( char * path ) ;
# endif
2014-12-18 08:07:36 +01:00
void getfilename ( uint16_t nr , const char * const match = NULL ) ;
2011-11-19 13:13:34 +01:00
uint16_t getnrfilenames ( ) ;
2015-03-02 16:06:01 +01:00
2013-10-22 10:02:18 +02:00
void getAbsFilename ( char * t ) ;
2011-11-06 22:48:15 +01:00
2011-11-19 13:13:34 +01:00
void ls ( ) ;
2015-10-03 08:08:58 +02:00
void chdir ( const char * relpath ) ;
2011-11-20 14:43:47 +01:00
void updir ( ) ;
2011-12-26 09:20:33 +01:00
void setroot ( ) ;
2017-02-09 14:02:25 +01:00
# if ENABLED(SDCARD_SORT_ALPHA)
void presort ( ) ;
void getfilename_sorted ( const uint16_t nr ) ;
# if ENABLED(SDSORT_GCODE)
FORCE_INLINE void setSortOn ( bool b ) { sort_alpha = b ; presort ( ) ; }
FORCE_INLINE void setSortFolders ( int i ) { sort_folders = i ; presort ( ) ; }
//FORCE_INLINE void setSortReverse(bool b) { sort_reverse = b; }
# endif
# endif
2016-08-12 12:21:10 +02:00
FORCE_INLINE void pauseSDPrint ( ) { sdprinting = false ; }
2012-12-12 11:47:03 +01:00
FORCE_INLINE bool isFileOpen ( ) { return file . isOpen ( ) ; }
2015-03-02 16:06:01 +01:00
FORCE_INLINE bool eof ( ) { return sdpos > = filesize ; }
FORCE_INLINE int16_t get ( ) { sdpos = file . curPosition ( ) ; return ( int16_t ) file . read ( ) ; }
FORCE_INLINE void setIndex ( long index ) { sdpos = index ; file . seekSet ( index ) ; }
FORCE_INLINE uint8_t percentDone ( ) { return ( isFileOpen ( ) & & filesize ) ? sdpos / ( ( filesize + 99 ) / 100 ) : 0 ; }
FORCE_INLINE char * getWorkDirName ( ) { workDir . getFilename ( filename ) ; return filename ; }
2011-11-06 21:39:53 +01:00
public :
2015-03-02 16:06:01 +01:00
bool saving , logging , sdprinting , cardOK , filenameIsDir ;
char filename [ FILENAME_LENGTH ] , longFilename [ LONG_FILENAME_LENGTH ] ;
2015-01-24 07:55:13 +01:00
int autostart_index ;
2011-11-06 22:48:15 +01:00
private :
2015-03-02 16:06:01 +01:00
SdFile root , * curDir , workDir , workDirParents [ MAX_DIR_DEPTH ] ;
2016-03-29 12:18:53 +02:00
uint8_t workDirDepth ;
2017-02-09 14:02:25 +01:00
// Sort files and folders alphabetically.
# if ENABLED(SDCARD_SORT_ALPHA)
uint16_t sort_count ; // Count of sorted items in the current directory
# if ENABLED(SDSORT_GCODE)
bool sort_alpha ; // Flag to enable / disable the feature
int sort_folders ; // Flag to enable / disable folder sorting
//bool sort_reverse; // Flag to enable / disable reverse sorting
# endif
uint8_t sort_order [ SDSORT_LIMIT ] ;
// Cache filenames to speed up SD menus.
# if ENABLED(SDSORT_USES_RAM)
// If using dynamic ram for names, allocate on the heap.
# if ENABLED(SDSORT_CACHE_NAMES)
char sortshort [ SDSORT_LIMIT ] [ FILENAME_LENGTH ] ;
char sortnames [ SDSORT_LIMIT ] [ FILENAME_LENGTH ] ;
# elif DISABLED(SDSORT_USES_STACK)
char sortnames [ SDSORT_LIMIT ] [ FILENAME_LENGTH ] ;
# endif
// Folder sorting uses an isDir array when caching items.
# if HAS_FOLDER_SORTING && (ENABLED(SDSORT_CACHE_NAMES) || DISABLED(SDSORT_USES_STACK))
uint8_t isDir [ ( SDSORT_LIMIT + 7 ) > > 3 ] ;
# endif
# endif // SDSORT_USES_RAM
# endif // SDCARD_SORT_ALPHA
2011-11-06 22:48:15 +01:00
Sd2Card card ;
SdVolume volume ;
2011-11-06 21:39:53 +01:00
SdFile file ;
2016-03-29 12:15:01 +02:00
2013-10-22 10:02:18 +02:00
# define SD_PROCEDURE_DEPTH 1
2015-03-02 16:06:01 +01:00
# define MAXPATHNAMELENGTH (FILENAME_LENGTH*MAX_DIR_DEPTH + MAX_DIR_DEPTH + 1)
2013-10-22 10:02:18 +02:00
uint8_t file_subcall_ctr ;
uint32_t filespos [ SD_PROCEDURE_DEPTH ] ;
2016-03-29 12:15:01 +02:00
char proc_filenames [ SD_PROCEDURE_DEPTH ] [ MAXPATHNAMELENGTH ] ;
2011-11-06 21:39:53 +01:00
uint32_t filesize ;
2015-03-02 16:06:01 +01:00
uint32_t sdpos ;
2011-11-06 21:39:53 +01:00
2016-03-29 12:19:27 +02:00
millis_t next_autostart_ms ;
2011-11-06 22:48:15 +01:00
bool autostart_stilltocheck ; //the sd start is delayed, because otherwise the serial cannot answer fast enought to make contact with the hostsoftware.
2015-03-02 16:06:01 +01:00
2011-11-19 13:13:34 +01:00
LsAction lsAction ; //stored for recursion.
2015-03-02 16:06:01 +01:00
uint16_t nrFiles ; //counter for the files in the current directory and recycled as position counter for getting the nrFiles'th name in the directory.
2011-11-19 13:13:34 +01:00
char * diveDirName ;
2014-12-18 08:07:36 +01:00
void lsDive ( const char * prepend , SdFile parent , const char * const match = NULL ) ;
2017-02-09 14:02:25 +01:00
# if ENABLED(SDCARD_SORT_ALPHA)
void flush_presort ( ) ;
# endif
2011-11-06 21:39:53 +01:00
} ;
2015-03-02 16:06:01 +01:00
2012-12-03 12:13:20 +01:00
extern CardReader card ;
2015-03-02 16:06:01 +01:00
2012-02-29 15:33:23 +01:00
# define IS_SD_PRINTING (card.sdprinting)
2011-11-07 22:33:13 +01:00
2015-08-01 01:40:50 +02:00
# if PIN_EXISTS(SD_DETECT)
# if ENABLED(SD_DETECT_INVERTED)
# define IS_SD_INSERTED (READ(SD_DETECT_PIN) != 0)
2015-03-02 16:06:01 +01:00
# else
2015-08-01 01:40:50 +02:00
# define IS_SD_INSERTED (READ(SD_DETECT_PIN) == 0)
2015-03-02 16:06:01 +01:00
# endif
2012-12-03 12:52:00 +01:00
# else
2015-03-02 16:06:01 +01:00
//No card detect line? Assume the card is inserted.
# define IS_SD_INSERTED true
2012-12-03 12:52:00 +01:00
# endif
2011-11-07 22:33:13 +01:00
# else
2011-11-19 20:18:54 +01:00
2012-02-29 15:33:23 +01:00
# define IS_SD_PRINTING (false)
2011-11-07 22:33:13 +01:00
2011-11-06 21:39:53 +01:00
# endif //SDSUPPORT
2015-03-02 16:06:01 +01:00
# endif //__CARDREADER_H