2426d150fe80c4c9dd6f2f28e73de43903b5267c
[hashcat.git] / docs / changes.txt
1 * changes v3.00 -> v3.xx:
2
3 ##
4 ## Improvements
5 ##
6
7 - Make Linux build POSIX compatible; Also allow it to actually compile on musl-libc systems
8 - Add support to compile on FreeBSD
9 - Make use of cl_context_properties[] to clCreateContext(), even if OpenCL specification allow the use of NULL, some runtimes fail without
10 - The Time.Estimated attribute in status display should also show --runtime limit if user set it
11 - Fix some strict aliasing rule violation on older compilers
12 - Fix some variable initializers on older compilers
13 - Replace DARWIN macro with compiler predefined macro __APPLE__
14 - Replace LINUX macro with compiler predefined macro __linux__
15 - Allow the use of enc_id == 0 in hash-mode 10600 and 10700 as it takes no part in the actual computation
16 - Get rid of exit() calls in OpenCL wrapper library with the goal to have a better control which error can be ignored under special circumstances
17 - Do not error and exit if an OpenCL platform has no devices, just print a warning and continue with the next platform
18 - Workaround for OpenCL runtimes which do not accept -I parameter in the OpenCL kernel build options even if this is an OpenCL standard option
19 - Workaround for OpenCL runtimes which do accept -I parameter in the OpenCL kernel build options, but do not allow quotes
20 - Output cracked hashes on Windows using \r\n and not \n
21 - Replace RegGetValue() with RegQueryValueEx() to enable Windows XP 32 bit compatibility
22
23 ##
24 ## Bugs
25 ##
26
27 - Fixed a bug where hashcat is suppressing --machine-readable output in the final status update
28 - Fixed a bug where hashcat did not check the return of realpath() and crashes uncontrolled if the path does not exist
29 - Fixed a bug where hashcat crashes for accessing deallocated buffer if user spams "s" shortly before hashcat shuts down
30 - Fixed a bug where hashcat crashes in case of a scrypt P setting > 1
31 - Fixed a bug where hashcat did not correctly use the newly cracked plains whenever --loopback or the induction folder was used
32 - Fixed a bug where hashcat did not correctly remove hashes of type WPA/WPA2 even if present in potfile
33 - Fixed a bug where hashcat reported an invalid password for a zero-length password in LM
34 - Fixed a bug where hashcat did not take into account how long it takes to prepare a session when auto-aborting with --runtime is in use
35
36 * changes v2.01 -> v3.00:
37
38 This release markes the fusion of "hashcat" and "oclHashcat" into "hashcat".
39 It combines all features of all hashcat projects in one project.
40
41 ##
42 ## Features
43 ##
44
45 - Support for Apple OpenCL runtime
46 - Support for NVidia OpenCL runtime (replaces CUDA)
47 - Support for Mesa (Gallium) OpenCL runtime
48 - Support for pocl OpenCL runtime
49 - Support for Khronos' OSS OpenCL reference implementation for building
50 - Support to utilize OpenCL devices-types other than GPU, ex: CPU and FPGA
51 - Support to utilize multiple different OpenCL platforms in parallel, ex: AMD + NV
52 - Support to utilize multiple different OpenCL device-types in parallel, ex: GPU + CPU
53 - Added option --opencl-platform to select a specific OpenCL platform
54 - Added option --opencl-device-types select specific OpenCL device types
55 - Added option --opencl-vector-width to override automatically selected vector-width size
56 - Added makefile native compilation target
57 - Added makefile install and uninstall targets
58 - Added autotuning engine and user-configurable tuning database
59 - Added current engine clock, current memory clock and pci-e lanes to the status display
60 - Added support for --gpu-temp-retain for NVidia GPU, both Linux and Windows
61 - Added execution timer of the running kernel to the status display
62 - Added command prompt to quit at next restore checkpoint
63 - Added human-readable error message for the OpenCL error codes
64 - Added option --potfile-path to override potfile path
65 - Added option --veracrypt-keyfile to set Keyfiles used, can be multiple
66 - Added option --veracrypt-pim to set the VeraCrypt personal iterations multiplier
67 - Added option --machine-readable for easier parsing of output
68 - Added option --powertune-enable to work with NVidia devices as well, not just AMD
69 - Added option --stdout to print candidates instead of trying to crack a hash
70
71 ##
72 ## Algorithms
73 ##
74
75 - Added new hash-mode   125 = ArubaOS
76 - Added new hash-mode 12900 = Android FDE (Samsung DEK)
77 - Added new hash-mode 13000 = RAR5
78 - Added new hash-mode 13100 = Kerberos 5 TGS-REP etype 23
79 - Added new hash-mode 13200 = AxCrypt
80 - Added new hash-mode 13300 = AxCrypt in memory SHA1
81 - Added new hash-mode 13400 = Keepass 1 (AES/Twofish) and Keepass 2 (AES)
82 - Added new hash-mode 13500 = PeopleSoft PS_TOKEN
83 - Added new hash-mode 13600 = WinZip
84 - Added new hash-mode 137** = VeraCrypt
85 - Added new hash-mode 13800 = Windows 8+ phone PIN/Password
86
87 ##
88 ## Performance
89 ##
90
91 - Full Table: https://docs.google.com/spreadsheets/d/1B1S_t1Z0KsqByH3pNkYUM-RCFMu860nlfSsYEqOoqco/edit#gid=0
92
93 ##
94 ## Improvements
95 ##
96
97 - Reordering of files to help integration into linux distributions ~/.hashcat etc
98 - Use a profile directory to write temporary files (session, potfile etc.)
99 - Workaround depencies on AMD APP-SDK AMD ADL, NV CUDA-SDK, NV ForceWare, NVML and NVAPI; they are no longer required
100 - Load external libraries dynamic at runtime instead of link them static at compile-time
101 - Benchmark accuracy improved; Is now on par to: singlehash -a 3 -w 3 ?b?b?b?b?b?b?b
102 - Benchmark no longer depends on a fixed time
103 - Removed option --benchmark-mode, therefore support --workload-profile in benchmark-mode
104 - Enabled support of --machine-readable in combination with --benchmark for automated benchmark processing
105 - Replaced --status-automat entirely with --machine-readable to make it more consistent among benchmark and non-benchmark mode
106 - Extended support from 14 to 255 functions calls per rule
107 - Extended password length up to 32 for 7zip
108 - Extended salt length up to 55 for raw hash types, eg: md5($pass.$salt)
109 - Extended version information
110 - Removed some duplicate rules in T0XlCv1, d3ad0ne and dive
111 - Redesigned changes.txt layout
112 - Redesigned --help menu layout
113
114 ##
115 ## Bugs
116 ##
117
118 - Fixed a bug in speed display: In some situation, especially with slow hashes or lots of salts, it showed a speed of 0H/s
119 - Fixed a bug in restore handling: user immediately aborting after restart broke the restore file
120 - Fixed a bug in line counter: conditional jump or move depends on an uninitialised value
121 - Fixed a bug in rule-engine for NVidia devices: code for left- and right-shift were switched
122 - Fixed a bug in dive.rule: rules were not updated after the function 'x' was renamed to 'O'
123 - Fixed a bug in memory allocation "OpenCL -4 error": used unitialized value in a special situation
124 - Fixed a bug in memory handling: heap buffer overflow
125 - Fixed a bug in memory handling: out of bounds access
126 - Fixed a bug in implementation of DCC2: forced default iteration count for hashes to 10240
127 - Fixed a bug in implementation of WPA/WPA2: MAC and nonce stay one their original position as in the hccap file
128 - Fixed a bug in implementation of GOST R 34.11-94: zero length passwords were not cracked
129
130 ##
131 ## Technical
132 ##
133
134 - Removed deprecated GCC version check requirement
135 - Removed NPROCS from Makefile, let make automatically detect the optimal number of parallel threads
136 - Dropped all C++ overloading functions to normal function which helps support more OpenCL platforms
137 - Renamed functions in common.h to emphasize their purpose
138 - Refactorized fast-hash kernels to enable SIMD on all OpenCL platforms
139 - Refactorized SIMD handling: SIMD the inner-loop not the outer-loop to save registers
140 - Workaround missing clEnqueueFillBuffer() support in certain OpenCL runtimes
141 - Added amd_bytealign() support in non-AMD OpenCL runtimes
142 - Added amd_bfe() support in non-AMD OpenCL runtimes
143 - Added several macros to allow writing optimized code for the different OpenCL platforms
144 - Replaced typedef for bool with stdbool.h
145 - Added special DEBUG environment variables to the makefile
146 - Hashcat now acquires an exclusive lock before writing to any file
147 - Changed buffers to not use same buffer for both input and output at the same time with snprintf()
148 - Check for allocatable device-memory depending on kernel_accel amplifier before trying to allocate
149 - Added additional check for max. ESSID length to prevent possible crashes
150 - Use a GCC equivalent for __stdcall where applicable
151 - Synchronize maximum output line size with input line size
152 - Increased maximum hash line size to 0x50000
153 - Run weak-hash checks only in straight-attack mode, this greatly reduces code complexity
154 - Restrict loopback option to straight attack-mode
155 - Moved rules_optimize to hashcat-utils
156 - Stick to older libOpenCL in binary package to avoid errors like this: version `OPENCL_2.0' not found
157 - Tightened hash parser for several algorithms
158 - Updated old RC4 code in Kerberos 5
159 - Limited the salt length of Juniper Netscreen/SSG (ScreenOS) hashes to 10
160 - Updated algorithm used to automatically select an ideal --scrypt-tmto value
161 - Renamed option --gpu-accel to --kernel-accel
162 - Renamed option --gpu-loops to --kernel-loops
163 - Renamed option --gpu-devices to --opencl-devices
164 - Added inline declaration to functions from simd.c, common.c, rp.c and types_ocl.c to increase performance
165 - Dropped static declaration from functions in all kernel to achieve OpenCL 1.1 compatibility
166 - Added -cl-std=CL1.1 to all kernel build options
167 - Created environment variable to inform NVidia OpenCL runtime to not create its own kernel cache
168 - Created environment variable to inform pocl OpenCL runtime to not create its own kernel cache
169 - Dropped special 64-bit rotate() handling for NV, it seems that they've added it to their OpenCL runtime
170 - Completely get rid of HAVE_ADL, HAVE_NVML and HAVE_NVAPI in sources
171 - Replaced NVAPI with NVML on windows