Skip to content

Commit

Permalink
Grant LOCAL SERVICE permission to read and execute debug DLLs (micros…
Browse files Browse the repository at this point in the history
…oft#4095)

Update setup-ebpf.ps1 to also explicitly grant LOCAL SERVICE permission
to execute the required debug DLLS. This seems to be necessary to avoid
error 1053 when installing on a new system via SSH.
  • Loading branch information
lmb authored Dec 17, 2024
1 parent 20334ef commit 85623c6
Showing 1 changed file with 8 additions and 4 deletions.
12 changes: 8 additions & 4 deletions scripts/setup-ebpf.ps1
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,14 @@ if ($Uninstall) {
Write-Host("Visual C++ Redistributable installation completed successfully!") -ForegroundColor Green
}

# Move the Visual C++ Redistributable Debug DLLs to the JIT directory, so that ebpfsvc.exe
# does not fail to start with error 1053.
# Copy the Visual C++ Redistributable Debug DLLs to the JIT directory and give
# LOCAL SERVICE read access.
# This is so that ebpfsvc.exe does not fail to start with error 1053.
Write-Host("Copying Visual C++ Redistributable debug runtime DLLs to the $EbpfSvcPath directory...")
# Test if the VC debug runtime DLLs are present in the working directory (indicating a debug build).
$VCDebugRuntime = $VCDebugRuntime | Where-Object { Test-Path (Join-Path $WorkingDirectory $_) }
if (-not $VCDebugRuntime) {
Write-Host("Visual C++ Redistributable debug runtime DLLs not found in the working directory (i.e., release build or already installed). Skipping this step.") -ForegroundColor Yellow
Write-Host("Visual C++ Redistributable debug runtime DLLs not found in the working directory. Skipping this step.") -ForegroundColor Yellow
} else {
if (-not (Test-Path $EbpfSvcPath)) {
New-Item -Path $EbpfSvcPath -ItemType Directory
Expand All @@ -76,7 +77,10 @@ if ($Uninstall) {
$VCDebugRuntime | ForEach-Object {
$sourcePath = Join-Path $WorkingDirectory $_
$destinationPath = Join-Path $EbpfSvcPath $_
Move-Item -Path $sourcePath -Destination $destinationPath -Force
Copy-Item -Path $sourcePath -Destination $destinationPath -Force
$acl = Get-Acl $destinationPath
$acl.AddAccessRule((New-Object System.Security.AccessControl.FileSystemAccessRule("NT AUTHORITY\LOCAL SERVICE", "ReadAndExecute", "Allow")))
Set-Acl $destinationPath $acl
}
Write-Host("Visual C++ Redistributable debug runtime DLLs copied successfully!") -ForegroundColor Green
}
Expand Down

0 comments on commit 85623c6

Please sign in to comment.