RELEASE_NOTES 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. ************************************
  2. ** Greaseweazle Release Notes
  3. ** Keir Fraser <keir.xen@gmail.com>
  4. ************************************
  5. ** v0.19 - 8 June 2020
  6. - F7 v2: Support for the new board design
  7. - gw update: Signature and CRC validation checks
  8. - gw read: Fix end-track field in single-sided SCP images
  9. ** v0.18 - 28 May 2020
  10. - gw read: New parameters --rate and --rpm
  11. - rate: Bitcell data rate in kbit/s (eg 250=DD 500=HD)
  12. - Used only for HFE images right now, where default is DD (250)
  13. - rpm: Normalise track timings to the given RPM value
  14. - This occurs before any other conversion or analysis
  15. - gw info: New command to display information about the Greaseweazle setup
  16. - gw bandwidth: Improved stats output
  17. - SCP: Fix single-sided image handling according to latest SCP spec.
  18. - Operates correctly with latest beta version of HxC software
  19. - F7: Support new board designs
  20. - AmberTronic F7 Plus: Kryoflux form factor, output buffers, 12v supply
  21. - F7 Lightning: High Speed USB, output buffers
  22. ** v0.17 - 19 May 2020
  23. - Windows: New self-contained executable distribution
  24. - No need to install Python, or module dependencies
  25. - Mac, Linux: Main script is directly executable
  26. - No need to manually invoke the Python interpreter
  27. - GW host tool: Help-text description for each available action
  28. ** v0.16 - 15 May 2020
  29. - F7 Firmware: Enable over-drive voltage mode
  30. - Required for reliable 216MHz operation (see datasheet)
  31. - Bootloader update:
  32. - 'gw.py update --bootloader' updates the bootloader
  33. - Not normally required
  34. - Failure may brick the Weazle and require full reflash: Take care!
  35. - Update build system to work with Windows MinGW environment
  36. ** v0.15 - 5 May 2020
  37. - Host tool improvements:
  38. - IPF: More robust conversion to raw flux for writeout
  39. - HFE: Fix crash when writing out HFE from third party tools
  40. - F7 Firmware improvements:
  41. - Preparation for High Speed USB (future board using 730Z8 MCU)
  42. - Enable Instruction and Data caches (10x execution speedup)
  43. - Various improvements to bandwidth as reported by 'gw.py bandwidth'
  44. ** v0.14 - 29 April 2020
  45. - IPF: Full write support (weak data, index misalignment)
  46. - New GW commands: bandwidth, erase
  47. - bandwidth: Measure USB read/write bandwidth
  48. - erase: Erase a disk
  49. - F7 USB: Improved bandwidth when writing to disk
  50. - Much less likely to see FluxUnderflow failures
  51. - update: Fix a bug which could fail to reopen the GW device for update
  52. - update: Automatically find the update file if filename not specified
  53. - Control script: Tidier notification of errors (no scary backtrace)
  54. ** v0.13 - 25 April 2020
  55. - HFE: Read & write support
  56. - IPF: Preliminary write support
  57. - Requires SPS/CAPS support library. See the wiki.
  58. - Weak data not yet supported (RNC "Protect Process" protection, & others)
  59. - Write splice is always rotated to the index (affects Speedlock & others)
  60. - Also TODO: Verified writes
  61. - USB: Use the VID:PID pair assigned to Greaseweazle (1201:4d69)
  62. - New prerequisite: 'bitarray' module. See the wiki.
  63. ** v0.12 - 10 March 2020
  64. - GW Autodetect: General improvements, and now works on Windows 7
  65. - New read parameter --double-step to double-step drive heads
  66. - Useful for reading a 40-cylinder disk in an 80-cylinder drive
  67. - New 'pin' command allows a floppy pin to be set to specified level
  68. - Currently supported only for pin 2 (DENSEL)
  69. - New 'reset' command resets the Greaseweazle to power-on settings
  70. - Motors off, drives deselected, power-on pin levels and delay values
  71. ** v0.11 - 21 January 2020
  72. - GW.py: Auto-detect the COM/serial port device name
  73. - The device argument is now optional!
  74. - USB: Provide a serial-id string to the host
  75. - Identifier is unique to each Greaseweazle device
  76. - Allows disambiguation between multiple Greaseweazle devices
  77. - Recommended: Full flash from HEX file (embeds serial in bootloader)
  78. - Ubuntu: Udev script now creates a /dev/greaseweazle symlink
  79. ** v0.10 - 17 January 2020
  80. - STM32F7xx: Multi-drive support via drive-select config option
  81. - Up to three Shugart drives or two IBM/PC drives
  82. - gw.py read|write --drive {a,b,0,1,2}
  83. - See the "Drive Select" wiki page
  84. ** v0.9 - 7 January 2020
  85. - Activity LED
  86. - Lights while a USB-issued command is in progress
  87. - Flashes when enumerated but idle in the firmware-update bootloader
  88. ** v0.8 - 6 January 2020
  89. - STM32F73xx: Various Fixes and Improvements
  90. - Allow Firmware Update mode to be forced via strapping Serial RX/TX
  91. - Fix bogus sample values at start of read flux values
  92. - Fix some time constants to be in units of the sample clock
  93. - USB: Advertise USB 2.0 device descriptor
  94. ** v0.7 - 6 December 2019
  95. - USB: Fix end-of-stream detection on track writes
  96. - Writes of empty/unformatted tracks sometimes hung forever
  97. - No Flux Area: Firmware automatically masters long NFAs during track writes
  98. - Generating no flux transitions does not read back as a NFA
  99. - STM32F73xx: Initial support for new STM32 MCU
  100. - Two HEX files are included: Use Greaseweazle-F1-* for existing boards!
  101. - Single unified UPD file containing both firmware images
  102. ** v0.6 - 15 November 2019
  103. - gw.py: Big overhaul of underlying Python package
  104. - Action (read, write, update) must come first on the command line
  105. - eg. "python3 gw.py read --ecyl=39 foo.scp COM3"
  106. - gw.py: New action "delays" to print/set delay parameters
  107. - eg. "python3 gw.py delays --step=10000" to increase step time to 10ms
  108. ** v0.5 - 11 November 2019
  109. - USB: Overhaul the protocol and allow writes to be terminated at index
  110. - Terminate-at-index is always used by current Python control script
  111. - Terminate-at-index prevents an over-long write from overwriting itself
  112. - Fix interruption of track writes (eg. KeyboardInterrupt)
  113. - gw.py: New option --adjust-speed to normalise flux times for target drive
  114. - Measures RPM of the target drive and calculates an adjustment factor
  115. ** v0.4 - 5 November 2019
  116. - Blinky: Diagnostic test firmware to detect fake STM32 chips
  117. - https://github.com/keirf/Greaseweazle/wiki/STM32-Fakes
  118. - Floppy Write: Fix for very short flux timings
  119. - Floppy Read: Fix for very long flux timings
  120. - USB: Small improvement to double-buffer logic
  121. ** v0.3 - 30 October 2019
  122. - Bootloader: Fix Programming-Jumper detection
  123. - Read Track: Various minor fixes
  124. - SCP: Fix the SCP file headers generated by "gw.py read"
  125. ** IMPORTANT USER INSTRUCTIONS **:
  126. - Users must serial-update using the v0.3 HEX file
  127. - DO NOT update from v0.2 using the UPD file
  128. - May need to install the crcmod package: eg "pip3 install crcmod"
  129. ** v0.2 - 29 October 2019
  130. - USB: Fix hangs during "gw.py read"
  131. - Thanks to Charlie Smurthwaite for telling me how to fix this!
  132. - USB: Improved bandwidth (double-buffered IN/OUT endpoints)
  133. - Reduces risk of buffer underflow/overflow during disk operations
  134. - Firmware Update: Requires a jumper across A14 (aka DCL) and GND
  135. - eg. "python gw.py update Greaseweazle-v0.2.upd COM3"
  136. ** v0.1 - 17 October 2019
  137. - First release