Defrag.exe

  • File Path: C:\Windows\system32\Defrag.exe
  • Description: Disk Defragmenter Module

Hashes

Type Hash
MD5 F7AC2F29879A0789A74F87012861A956
SHA1 7F690ED5DEED179A5B0834783A39C0035E9AFE5E
SHA256 D90DF37806E6F4A59D51B2D6FEDFDAF129436C4A0BC27DC271650B53B4848053
SHA384 D797295A1DCA8C8883E8D0B9A2483F4C5A5F2FDD6E438CE5090640D4E53220350B646FBBE90AD517E3F2EA79D20FEF5F
SHA512 93981E904171CAC7F050E277DF270B93984F7F85C5B64802112EE00668811EC61D4431FA9258999FBFB6AC104879751322ED51BA6CDDAF01DD800083D647798E
SSDEEP 3072:EswPgZs/8fsIlnK0tRrDrTkJKk/V5W86uvsb4C6c5Q3eSjlR+8qxLijgJyfFOG8l:P02o8PK+q+uJ3lRGOUZGKc4YFnwjCpW
IMP 9233D07CE8B477A0DE3511C3B6B4B24D
PESHA1 8FEF5F428B441A89487AD10189C8354F6769E4D2
PE256 B270B551385887434E5B0D73E35213D49777F8B76E5A1E943F2CCCEF041C55E8

Runtime Data

Usage (stdout):


Please specify a volume to perform the operation on. (0x89000007)

Defrag <Volumes> <Operations> [<Options>]

Volumes:
  /C | /AllVolumes      On each volume run only the preferred operations from
                        the given list of operations.
  /E | /VolumesExcept <volume paths>
                        Perform all the given operations on each volume except.
                        those specified. If the exception list is empty, this
                        behaves as /AllVolumes.
  volume paths          Specifies the drive letter followed by a colon, mount point
                        or volume name. More than one volume can be specified.  Run
                        all the given operations on each specified volume..

Operations:
  /A | /Analyze         Perform analysis.
  /B | /BootOptimize    Perform boot optimization to increase boot performance.
  /D | /Defrag          Perform traditional defrag (this is the default). On a tiered
                        volume, traditional defrag is performed only on the Capacity
                        tier.
  /G | /TierOptimize    On tiered volumes, optimize files to reside on the appropriate
                        storage tier.
  /K | /SlabConsolidate On thinly provisioned volumes, perform slab consolidation to
                        increase slab usage efficiency.
  /L | /Retrim          On thinly provisioned volumes, perform retrim to release free
                        slabs. On SSDs perform retrim to improve write performance.
  /O | /Optimize        Perform the proper optimization for each media type.
  /T | /TrackProgress   Track progress of a running operation for a given volume. An
                        instance can show progress only for a single volume. To see
                        progress for another volume launch another instance.
  /U | /PrintProgress   Print the progress of the operation on the screen.
  /V | /Verbose         Print verbose output containing the fragmentation statistics.
  /X | /FreespaceConsolidate
                        Perform free space consolidation, moves free space towards
                        the end of the volume (even on thin provisioned volumes). On
                        tiered volumes consolidation is performed only on the Capacity
                        tier.

Options:
  /H | /NormalPriority  Run the operation at normal priority (default is low).
  /I | /MaxRuntime n    Available only with TierOptimize. Tier optimization would
                        run for at most n seconds on each volume.
       /LayoutFile <file path>
                        Available only with BootOptimize. This file contains the list
                        of files to be optimized.  The default location is
                        %windir%\Prefetch\layout.ini.
  /M | /MultiThread [n] Run the operation on each volume in parallel in the background.
                        For TierOptimize, at most n threads optimize the storage tiers
                        in parallel. Default value of n is 8. All other optimizations
                        ignore n.
       /OnlyPreferred   When volumes are specified explicitly, defrag performs all
                        the given operations on each specified volume.  This switch
                        lets defrag run only the preferred operations, from the
                        given list of operations, on each specified volume.

Examples:
  Defrag C: /U /V
  Defrag C: D: /TierOptimize /MultiThread
  Defrag C:\mountpoint /Analysis /U
  Defrag /C /H /V

Loaded Modules:

Path
C:\Windows\system32\Defrag.exe
C:\Windows\System32\KERNEL32.DLL
C:\Windows\System32\KERNELBASE.dll
C:\Windows\SYSTEM32\ntdll.dll

Signature

  • Status: Signature verified.
  • Serial: 3300000266BD1580EFA75CD6D3000000000266
  • Thumbprint: A4341B9FD50FB9964283220A36A1EF6F6FAA7840
  • Issuer: CN=Microsoft Windows Production PCA 2011, O=Microsoft Corporation, L=Redmond, S=Washington, C=US
  • Subject: CN=Microsoft Windows, O=Microsoft Corporation, L=Redmond, S=Washington, C=US

File Metadata

  • Original Filename: Defrag.EXE.MUI
  • Product Name: Windows Drive Optimizer
  • Company Name: Microsoft Corp.
  • File Version: 10.0.19041.1 (WinBuild.160101.0800)
  • Product Version: 10.0.19041.1
  • Language: English (United States)
  • Legal Copyright: Microsoft Corp.
  • Machine Type: 64-bit

File Scan

  • VirusTotal Detections: 0/76
  • VirusTotal Link: https://www.virustotal.com/gui/file/d90df37806e6f4a59d51b2d6fedfdaf129436c4a0bc27dc271650b53b4848053/detection

File Similarity (ssdeep match)

File Score
C:\WINDOWS\system32\Defrag.exe 71
C:\WINDOWS\system32\Defrag.exe 60
C:\windows\system32\Defrag.exe 65
C:\Windows\system32\Defrag.exe 74
C:\Windows\system32\Defrag.exe 69
C:\Windows\system32\Defrag.exe 74

Possible Misuse

The following table contains possible examples of Defrag.exe being misused. While Defrag.exe is not inherently malicious, its legitimate functionality can be abused for malicious purposes.

Source Source File Example License
sigma win_apt_slingshot.yml title: Defrag Deactivation DRL 1.0
sigma win_apt_slingshot.yml TaskName: '\Microsoft\Windows\Defrag\ScheduledDefrag' DRL 1.0
sigma sysmon_suspicious_remote_thread.yml - '\defrag.exe' DRL 1.0
sigma proc_creation_win_apt_slingshot.yml title: Defrag Deactivation DRL 1.0
sigma proc_creation_win_apt_slingshot.yml - '\Microsoft\Windows\Defrag\ScheduledDefrag' DRL 1.0

Additional Info*

*The information below is copied from MicrosoftDocs, which is maintained by Microsoft. Available under CC BY 4.0 license.


defrag

Applies to: Windows Server 2022, Windows Server 2019, Windows 10, Windows Server 2016, Windows Server 2012 R2, Windows Server 2012

Locates and consolidates fragmented files on local volumes to improve system performance.

Membership in the local Administrators group, or equivalent, is the minimum required to run this command.

Syntax

defrag <volumes> | /c | /e <volumes>    [/h] [/m [n]| [/u] [v]]
defrag <volumes> | /c | /e <volumes> /a [/h] [/m [n]| [/u] [v]]
defrag <volumes> | /c | /e <volumes> /x [/h] [/m [n]| [/u] [v]]
defrag <volume> [<parameters>]

Parameters

Parameter Description
<volume> Specifies the drive letter or mount point path of the volume to be defragmented or analyzed.
/a Perform analysis on the specified volumes.
/c Perform the operation on all volumes.
/d Perform traditional defrag (this is the default). On a tiered volume though, traditional defrag is performed only on the Capacity tier.
/e Perform the operation on all volumes except those specified.
/g Optimize the storage tiers on the specified volumes.
/h Run the operation at normal priority (default is low).
/i [n] Tier optimization would run for at most n seconds on each volume.
/k Perform slab consolidation on the specified volumes.
/l Perform retrim on the specified volumes.
/m [n] Run the operation on each volume in parallel in the background. At most n threads optimize the storage tiers in parallel.
/o Perform the proper optimization for each media type.
/t Track an operation already in progress on the specified volume.
/u Print the progress of the operation on the screen.
/v Print verbose output containing the fragmentation statistics.
/x Perform free space consolidation on the specified volumes.
/? Displays this help information.
Remarks
  • You can’t defragment specific file system volumes or drives, including:

    • Volumes locked by the file system.

    • Volumes the file system marked as dirty, indicating possible corruption.
      You must run chkdsk before you can defragment this volume or drive. You can determine if a volume is dirty by using the fsutil dirty command.

    • Network drives.

    • CD-ROMs.

    • File system volumes that aren’t NTFS, ReFS, Fat or Fat32.

  • To perform this procedure, you must be a member of the Administrators group on the local computer, or you must have been delegated the appropriate authority. If the computer is joined to a domain, members of the Domain Admins group might be able to perform this procedure. As a security best practice, consider using Run As to perform this procedure.

  • A volume must have at least 15% free space for defrag to completely and adequately defragment it. defrag uses this space as a sorting area for file fragments. If a volume has less than 15% free space, defrag will only partially defragment it. To increase the free space on a volume, delete unneeded files or move them to another disk.

  • While defrag is analyzing and defragmenting a volume, it displays a blinking cursor. When defrag is finished analyzing and defragmenting the volume, it displays the analysis report, the defragmentation report, or both reports, and then exits to the command prompt.

  • By default, defrag displays a summary of both the analysis and defragmentation reports if you do not specify the /a or /v parameters.

  • You can send the reports to a text file by typing >FileName.txt, where FileName.txt is a file name you specify. For example: defrag volume /v > FileName.txt

  • To interrupt the defragmentation process, at the command line, press CTRL+C.

  • Running the defrag command and Disk defragmenter are mutually exclusive. If you are using Disk defragmenter to defragment a volume and you run the defrag command at a command-line, the defrag command fails. Conversely, if you run the defrag command and open Disk defragmenter, the defragmentation options in Disk defragmenter are unavailable.

Examples

To defragment the volume on drive C while providing progress and verbose output, type:

defrag c: /u /v

To defragment the volumes on drives C and D in parallel in the background, type:

defrag c: d: /m

To perform a fragmentation analysis of a volume mounted on drive C and provide progress, type:

defrag c: mountpoint /a /u

To defragment all volumes with normal priority and provide verbose output, type:

defrag /c /h /v

Scheduled task

The defragmentation process runs scheduled task as a maintenance task, which typically runs every week. As an Administrator, you can change the how often the task runs by using the Optimize Drives app.

  • When run from the scheduled task, defrag uses the below policy guidelines for SSDs:

    • Traditional optimization processes. Includes traditional defragmentation, for example moving files to make them reasonably contiguous and retrim. This is done once per month. However, if both traditional defragmentation and retrim are skipped, then analysis isn’t run. Changing the frequency of the scheduled task does not affect the once per month cadence for the SSDs.

    • If you manually run traditional defragmentation on a SSD, between your normally scheduled runs, the next scheduled task run performs analysis and retrim, but skips traditional defragmentation on that SSD.

    • If you skip analysis, you won’t see an updated Last run time in the Optimize Drives app. Because of that, the Last run time can be up to a month old.

    • You might find that scheduled task hasn’t defragmented all volumes. This is typically because:

      • The process won’t wake the computer to run.

      • The computer isn’t plugged in. The process won’t run if the computer is running on battery power.

      • The computer started back up (resumed from idle).

Additional References


MIT License. Copyright (c) 2020-2021 Strontic.