ZuluSCSI_platform_msc.h 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. /**
  2. * Copyright (c) 2023-2024 zigzagjoe
  3. *
  4. * ZuluSCSI™ firmware is licensed under the GPL version 3 or any later version. 
  5. *
  6. * https://www.gnu.org/licenses/gpl-3.0.html
  7. * ----
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version. 
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  16. * GNU General Public License for more details. 
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program.  If not, see <https://www.gnu.org/licenses/>.
  20. **/
  21. #ifdef PLATFORM_MASS_STORAGE
  22. #pragma once
  23. #include "usbd_msc_mem.h"
  24. // private constants/enums
  25. #define SD_SECTOR_SIZE 512
  26. /* USB Mass storage Standard Inquiry Data */
  27. const uint8_t storageInquiryData[] = {
  28. /* LUN 0 */
  29. 0x00,
  30. 0x80,
  31. 0x00,
  32. 0x01,
  33. (USBD_STD_INQUIRY_LENGTH - 5U),
  34. 0x00,
  35. 0x00,
  36. 0x00,
  37. 'Z', 'u', 'l', 'u', 'S', 'C', 'S', 'I', /* Manufacturer : 8 bytes */
  38. 'G', 'D', '3', '2', 0, 0, 0, 0, /* Product : 16 Bytes */
  39. 0, 0, 0, 0, 0, 0, 0, 0,
  40. '1', '.', '0', '0', /* Version : 4 Bytes */
  41. };
  42. /* return true if USB presence detected / eligble to enter CR mode */
  43. bool platform_sense_msc();
  44. /* perform MSC-specific init tasks */
  45. void platform_enter_msc();
  46. /* set to present images as storage rather than SD */
  47. void platform_set_msc_image_mode(bool image_mode);
  48. /* return true if we should remain in card reader mode. called in a loop. */
  49. bool platform_run_msc();
  50. /* perform any cleanup tasks for the MSC-specific functionality */
  51. void platform_exit_msc();
  52. #endif