新バージョンの特別な機能は、(CPU、GPU、Xeon Phi に加えて) FPGA サポートが登場したことです。 ボード用
bcrypt の場合、119^2 反復 (「$5b$2」)、消費電力約 05 ワットで達成されたパフォーマンス約 27k c/s は、ボードあたり、ハードウェア価格あたり、およびワットあたりの最新の GPU の結果を大幅に上回っています。 。 こちらもサポート
作業を高速化するために、マスク (他のモードとの組み合わせを含む「-マスク」モード) の使用と、計算されたハッシュと FPGA 側にロードされたハッシュの比較を実装しました。 実装の観点から見ると、多くの設計 (例:
その他の重要な変更点:
- 従来のパスワード ハッシュ (QNX の新しいバージョンなど) だけでなく、暗号通貨ウォレット、暗号化されたアーカイブ、暗号化されたファイル システム (Bitlocker や暗号化されたファイル システムなど) の両方を含む、多数の追加タイプのハッシュや暗号などのサポート。 FreeBSD geli) だけでなく、以前にサポートされていた新しいタイプの形式のサポート (たとえば、OpenBSD Softraid の bcrypt-pbkdf のサポートの追加) なども含まれます。 合計で、CPU に 80 のフォーマット、OpenCL に 47 のフォーマットが追加されました。 フォーマットの合計数は、CPU 上で 407 (または構成ファイルから設定された「動的」フォーマットを除く 262)、OpenCL 上で 88 になりました。
- OpenCL を支持して CUDA 言語のサポートを拒否することで、NVIDIA GPU の最大限の使用が妨げられることはありません (また、以前は XNUMX つ実装されていたのではなく、GPU の各フォーマットの XNUMX つの実装に開発と最適化が集中したおかげで、さらに役に立ちました)。
- 新しい SIMD 命令セット - AVX2、AVX-512 (第 86 世代 Xeon Phi 用を含む)、および MIC (第 64 世代用) のサポートに加え、多くのフォーマットの実装における SIMD のより汎用的かつ完全な使用。以前は xXNUMX(-XNUMX) で AVX および XOP までの命令セットをサポートしていました。
それぞれ ARM、Aarch64、および POWER 上の NEON、ASIMD、および AltiVec。 - CPU と OpenCL の多数の最適化により、多数のハッシュを同時により効率的に処理し (たとえば、320 億 1 万の SHA-XNUMX ハッシュを GPU にロードすることがテストされました)、ハッシュ計算の速度が向上しました。 これらの最適化の中には、普遍的なもの、フォーマットのさまざまなサブセットをカバーするもの、および個々のフォーマットに固有のものもあります。
- CPU 上のチェックされたパスワードの最適なバッファリング (「—tune=auto —verbosity=5」) および OpenCL 上の最適なジョブ サイズ (デフォルトで有効) の (自動) 構成 (最大動作周波数までのゆっくりとした立ち上がりを考慮したものなど) NVIDIA GTX シリーズ GPU 10xx 以降。 このような自動チューニングには、実際にロードされたハッシュと、チェックされるパスワードの実際の長さが (事前にわかっている場合) 使用されます。
- コマンドラインで直接指定された「動的式」用のコンパイラを追加し、SIMD を使用して CPU で計算される新しいハイブリッド ハッシュ タイプ (たとえば「-format=dynamic='sha1(md5($p).$s)'」) を実装します。 。 このような式のコンポーネントとして、数十の高速ハッシュ (MD5 のような一般的なものから Whirlpool のようなやや珍しいものまで)、部分文字列の連結、エンコードとデコード、文字の大文字と小文字の変換、パスワード、ソルト、ユーザー名、および文字列定数への参照がサポートされています。
- 以前の hashcat 固有のルール (ワードリスト ルール コマンド) のサポート、1 からの OpenCL デバイス番号付けへの移行、パフォーマンス テストでの同じパスワード長 (通常は長さ 7) のデフォルトの使用など、hashcat との不要な相違点の排除。
- hashcat の PRINCE (全長が長い順に複数の単語を組み合わせて「フレーズ」を形成する)、サブセット (これらの文字が含まれている場合でも、異なる文字の数が不十分なパスワードを表示する) を含む、検証可能なパスワードを生成するための新しいモード (クラッキング モード)可能なものの大規模なセットから)およびハイブリッド外部(C に似た言語で設定ファイルに記述された外部モードが、別のモードから受け取った各基本的な「単語」に基づいて多くの検証可能なパスワードを生成できるようにします)。 また、いくつかの新しい事前定義された外部モード。
- 複数のモードを同時に使用したり (重ねて使用する - スタッキング)、ルールのセットを使用したり (ワードリスト ルールのスタッキング) するための追加機能。
- マスク モード (指定された長さの範囲でマスクを段階的にストレッチする、OpenCL デバイスまたは FPGA ボードの側面にマスクを適用する) およびシングル クラック (多数のハッシュを並行して計算するデバイスでの合理的な動作) の改善、以前はこのモードでは検証可能なパスワードが十分ではなく、またメモリ消費量にも制限がありました)。
- さまざまなサブシステムで Unicode およびその他のエンコーディングをサポートするための多くの改善。
- *2john プログラム (さまざまな形式のファイルを変換するプログラム) に対する多くの改善。
john とともに使用します)、特に wpapcap2john (WiFi トラフィックを処理します)。 - 新しいコマンド ライン オプション、john.conf の設定、スクリプト オプションの構成、および対応する新機能が多数ありますが、そのすべてがここで説明されているわけではありません。
- AddressSanitizer (以前) および UnknownBehaviorSanitizer (追加) によるデバッグ ビルドの組み込みサポート、組み込み形式ファザー (GSoC 2015 の一部として) の追加、継続的統合の使用 (数十のオペレーティング システムおよびコンパイラー用のビルド) によるコード品質の向上組み合わせを確認し、すべての形式が正しくサポートされているかどうかをテストします)。
出所: オープンネット.ru