-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathanalyze_log.py
434 lines (391 loc) · 24.4 KB
/
analyze_log.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
import re
from collections import defaultdict
def analyze_log_file(log_file_path):
# Initialize variables
custom_config_found = False
last_core_index = -1
critical_issues = defaultdict(list)
game_issues = defaultdict(list)
non_default_settings = defaultdict(list)
pad_issues = defaultdict(list)
firmware_detected = False
firmware_version = None
emulator_info = {"version": "", "cpu": "", "os": "", "gpu": ""}
language_message = ""
# Sets to track duplicate issues
onedrive_issues = set()
save_issues = set()
graphics_device_notifications = set()
# Attempt to open and read the log file with different encodings
encodings = ['utf-8', 'latin-1', 'cp1252'] # Add more encodings if needed
lines = []
for encoding in encodings:
try:
with open(log_file_path, 'r', encoding=encoding) as file:
lines = file.readlines()
break # Exit loop if successful
except UnicodeDecodeError:
continue # Try next encoding
else:
return "**Error**: Unable to read the log file with the provided encodings."
# Check if this is a Rock Band 3 log
if not any("SYS: Title: Rock Band 3" in line for line in lines) or \
not any("SYS: Serial: BLUS30463" in line for line in lines):
return "**Yuck!** This isn't a log for Rock Band 3. Feed me something better, or boot the game first to generate a log."
# Extract emulator information
emulator_info["version"] = lines[0].strip() if lines else ""
emulator_info["cpu"] = lines[1].strip() if len(lines) > 1 else ""
emulator_info["os"] = lines[2].strip() if len(lines) > 2 else ""
# Detect emulator version number and flag if in the range 16920-17034
version_match = re.search(r"RPCS3 v0\.0\.\d+-(\d+)-[a-f0-9]+", emulator_info["version"])
if version_match:
version_number = int(version_match.group(1))
if 16920 <= version_number <= 17034:
critical_issues["- **The version you're on is prone to crashing!** Update your RPCS3 as soon as possible!"] \
.append("L-1") # Assuming the version is always on the first line
# Check for GPU information
gpu_found = False
for i, line in enumerate(lines):
if "CFG: Setting the default renderer to Vulkan. Default GPU:" in line:
gpu_match = re.search(r"Default GPU: '(.*)'", line)
if gpu_match:
emulator_info["gpu"] = gpu_match.group(1)
gpu_found = True
break # Stop searching once found
if not gpu_found:
critical_issues[f"- **Vulkan compatible GPU not found!** We can't really help you with this one."].append(f"L-{i}")
# Check log for firmware version and language, with firmware first
for line in lines:
firmware_match = re.search(r"SYS: Firmware version: (\d+\.\d+)", line)
if firmware_match:
firmware_version = firmware_match.group(1)
firmware_detected = True
if float(firmware_version) < 4.88:
game_issues[f"- **Outdated firmware.** You are on `{firmware_version}`. **Please update to the latest PS3 firmware!**"].append(f"L-{lines.index(line) + 1}")
# Check for language setting
if "Language: Spanish" in line:
language_message = "Hola. Explica lo que paso. / This user speaks Spanish."
# Scan the log file for "Used configuration" and track indices
for i, line in enumerate(lines):
if "Applying custom config" in line:
custom_config_found = True
if "Used configuration" in line:
last_core_index = i
# Process log information if custom config was found
if custom_config_found and last_core_index != -1:
core_section_lines = lines[last_core_index:]
high_memory_detected = False
debug_console_mode_off = False
enable_upnp = False
upnp_error_detected = False
ipadd_found = False
bindadd_found = False
dns_found = False
gocentral_found = False
vsyncoff_found = False
above60_vblank_found = False
# Non-default stuff
ppudef_found = False
spudef_found = False
shaderdef_found = False
spudmadef_found = False
rsxresdef_found = False
spuprofdef_found = False
mfcdef_found = False
xfloatdef_found = False
ppufixdef_found = False
clocksdef_found = False
maxcpudef_found = False
rsxtiledef_found = False
strictrenderdef_found = False
disvercachedef_found = False
disdiskshaderdef_found = False
msaaresolvedef_found = False
shaderthreadsdef_found = False
gpulabelsdef_found = False
asynchtexdef_found = False
startpausedef_found = False
pausefocusdef_found = False
pausehomedef_found = False
wrdbufdef_found = False
rcbufdef_found = False
rdbufdef_found = False
# Check for specific conditions in the extracted section
for i, line in enumerate(core_section_lines, start=last_core_index + 1):
# Check for high memory
if 'CELL_ENOENT, "/dev_hdd0/game/BLUS30463/USRDIR/dx_high_memory.dta"' in line:
game_issues[f"- **High memory file is missing!** Check out `!mem` for more information."].append(f"L-{i}")
# Frame limit settings
if "Frame limit" in line:
match = re.search(r"Frame limit:\s*(\d+|Auto|Off)", line, re.IGNORECASE)
if match:
frame_value = match.group(1)
if frame_value not in ["Auto", "Off", "Display"]:
game_issues[f"- **Weird Framelimit settings.** Set it to `Auto`, `Off`, or `Display` in the GPU tab of RB3's Custom Configuration. Yours is on {frame_value}"].append(f"L-{i}")
else:
game_issues[f"- **Weird framerate settings:** Unknown"].append(f"L-{i}")
# OpenGL Detect
if "Renderer: OpenGL" in line:
game_issues[f"- **You're using OpenGL!** You should really be on Vulkan. Set this in the GPU tab of RB3's Custom Configuration."].append(f"L-{i}")
# 1920x1080 Detect
if "Resolution: 1920x1080" in line:
critical_issues[f"- **Forcing Rock Band to run at 1920x1080 will cause crashes!** You should really set this back to 1280x720."].append(f"L-{i}")
# OneDrive install detection
if "OneDrive" in line:
if "OneDrive install detected" not in onedrive_issues:
onedrive_issues.add("- **OneDrive detected! This can lead to corrupted files and saves!** Please move files to `C:\\Games`**")
critical_issues[f"- **OneDrive detected! This can lead to corrupted files and saves!** Please move files to `C:\\Games`"].append(f"L-{i}")
# Busted save
if "dev_hdd0/home/00000001/savedata/BLUS30463-AUTOSAVE/ (Already exists)" in line:
if "Busted save detected" not in save_issues:
save_issues.add("- **Busted save detected!** Move the `BLUS30463-AUTOSAVE`folder out of savedata folder in `dev_hdd0`.")
critical_issues[f"- **Busted save detected!** Move the `BLUS30463-AUTOSAVE` folder out of `dev_hdd0\\home\\00000001\\savedata`."].append(f"L-{i}")
# Vblank Rate
if re.search(r"Vblank Rate: (\d+)", line):
vblank_frequency = int(re.search(r"\d+", line).group())
if vblank_frequency < 60:
critical_issues[f"- **VBlank should not be below 60**. Set it back to at least 60 in the Advanced tab of RB3's Custom Configuration."].append(f"L-{i}")
elif vblank_frequency > 60:
above60_vblank_found = True
game_issues[f"- Playing on a VBlank higher than 60 is not suggested. Use `!vsyncmeta` for more information."].append(f"L-{i}")
# VSync False
if "VSync: false" in line:
vsyncoff_found = True
# OpenGL
if "Renderer: OpenGL" in line:
game_issues[f"- **You're using OpenGL!** You should really be on Vulkan. Set this in the GPU tab of RB3's Custom Configuration."].append(f"L-{i}")
# High Audio Buffer Duration
match = re.search(r"Desired Audio Buffer Duration: (\d+)", line)
if match:
buffer_duration = int(match.group(1))
if buffer_duration >= 100:
game_issues[f"- **Audio Buffer is quite high.** Consider lowering it to 32 in the Audio tab of RB3's Custom Configuration. It's set to {buffer_duration} ms"].append(f"L-{i}")
# Audio Broken
if "cellAudio: Failed to open audio backend" in line:
critical_issues[f"- **Audio device doesn't work!** Check to make you selected the proper audio device in the Audio tab of RB3's Custom Configuration."].append(f"L-{i}")
# Fullscreen settings
if "Exclusive Fullscreen Mode: Enable" in line or "Exclusive Fullscreen Mode: Automatic" in line:
game_issues[f"- Depending on your graphics driver, **you may experience issues with the Automatic or Exclusive Fullscreen settings** when clicking in and out of RPCS3. Consider setting it to `Prefer Borderless Fullscreen` in the Advanced tab of RB3's Custom Configuration."].append(f"L-{i}")
# Shader Compilation Broke
if "Shader does not write to any output register and will be NOPed" in line:
critical_issues[f"- **Shader compilation failed!** Clear the cache and update RPCS3 if you haven't. Use `!caches` for more information."].append(f"L-{i}")
# Vulkan Device Lost
if "Driver crashed with unspecified error or stopped responding and recovered" in line:
critical_issues[f"- **Display error!** Check your graphics card drivers. Use `!vkdiag` for more information."].append(f"L-{i}")
# PSF Broken
if "PSF: Error loading PSF" in line:
critical_issues[f"- **PARAM.SFO file is busted!** DLC will probably not load! Replace them with working ones."].append(f"L-{i}")
# Debug Console
if "Debug Console Mode: false" in line:
debug_console_mode_off = True
game_issues[f"- **Debug Console Mode is off. Why?** Use `!mem`"].append(f"L-{i}")
# Configuration not found
if 'Selected config: mode=custom config, path=""' in line:
critical_issues[f"- **Custom config not found**. Use `!rpcs3`"].append(f"L-{i}")
# Pad profile
if 'input_configs/BLUS30463/Default.yml' in line:
pad_issues[f"- **Per-game pad profile detected**. This will lock you out of being able to switch profiles. Use `!padprofiles`."].append(f"L-{i}")
# MIDI Detection
if "log: Could not open port" in line:
critical_issues[f"- **MIDI device failed**. Close out any other programs using MIDI or restart computer."].append(f"L-{i}")
# Driver Wake-Up Delay
if re.search(r"Driver Wake-Up Delay: (\d+)", line):
delay_value = int(re.search(r"\d+", line).group())
if delay_value < 20:
critical_issues[f"- **Driver Wake-Up Delay is too low. Yours is set to ({delay_value}). Use `!dwd`"].append(f"L-{i}")
elif delay_value % 20 != 0:
game_issues[f"- **Driver Delay Wake-Up Settings isn't a multiple of 20**. Yours is at (value: {delay_value}). Use `!dwd`"].append(f"L-{i}")
# WCB
if "Write Color Buffers: false" in line:
critical_issues[f"- **Write Color Buffers isn't on**. Use `!wcb`"].append(f"L-{i}")
# Firmware missing
if "SYS: Missing Firmware" in line:
critical_issues[f"- **No firmware installed**. Check the guide at `!rpcs3`"].append(f"L-{i}")
# SPU Block Size
if "SPU Block Size: Giga" in line:
critical_issues[f"- **SPU Block Size is on Giga, which is very unstable!** Set it back to Auto or Mega in the GPU tab of RB3's Custom Configuration."].append(f"L-{i}")
# Network Status
if "Network Status: Disconnected" in line:
critical_issues[f"- **Incorrect Network settings.** Use !netset"].append(f"L-{i}")
# High Memory file
if "Regular file, “/dev_hdd0/game/BLUS30463/USRDIR/dx_high_memory.dta”" in line:
high_memory_detected = True
# GPU features
if any(gpu_issue in line for gpu_issue in ["Physical device reports a low amount of allowed deferred descriptor updates", "Will use graphics queue instead"]):
if "Graphics device notice" not in graphics_device_notifications:
graphics_device_notifications.add("- **Graphics device issue!** Get a nerd to check this out.")
game_issues[f"- **Graphics device issue!** Get a nerd to check this out."].append(f"L-{i}")
# GPU does not feature
if "Your GPU does not support" in line:
critical_issues[f"- **Graphics card is missing features.**"].append(f"L-{i}")
# USB overload
if "sys_usbd: Transfer Error" in line:
critical_issues[f"- **Usbd error.** Too many PS3 instruments or passthrough devices connected?"].append(f"L-{i}")
# Crash
if any(error in line for error in ["Thread terminated due to fatal error: Verification failed", "VM: Access violation reading location"]):
critical_issues[f"- **Crash detected.** Tell us what you were doing before crashing."].append(f"L-{i}")
#Network stuff
if "rpcn: User is already logged in" in line:
critical_issues[f"- **Zombie RPCN login!** You lost connection to RPCN and it did not log out correctly. Wait around 20 minutes before trying again."].append(f"L-{i}")
if "UPNP Enabled: true" in line:
enable_upnp = True
if "No UPNP device was found" in line:
upnp_error_detected = True
# IP address detection
if "IP address: 0.0.0.0" in line:
ipadd_found = True
# Bind address detection
if "Bind address: 0.0.0.0" in line:
bindadd_found = True
# DNS address detection
if "DNS address: 8.8.8.8" in line:
dns_found = True
# GoCentral address detection
if "IP swap list: rb3ps3live.hmxservices.com=45.33.44.103" in line:
gocentral_found = True
# Non-default settings detection
if "PPU Decoder: Recompiler (LLVM)" in line:
ppudef_found = True
if "SPU Decoder: Recompiler (LLVM)" in line:
spudef_found = True
if "Shader Mode: Async Shader Recompiler" in line:
shaderdef_found = True
if "Accurate SPU DMA: false" in line:
spudmadef_found = True
if "Accurate RSX reservation access: false" in line:
rsxresdef_found = True
if "SPU Profiler: false" in line:
spuprofdef_found = True
if "MFC Commands Shuffling Limit: 0" in line:
mfcdef_found = True
if "XFloat Accuracy: Approximate" in line:
xfloatdef_found = True
if "PPU Fixup Vector NaN Values: false" in line:
ppufixdef_found = True
if "Clocks scale: 100" in line:
clocksdef_found = True
if "Max CPU Preempt Count: 0" in line:
maxcpudef_found = True
if "Handle RSX Memory Tiling: false" in line:
rsxtiledef_found = True
if "Strict Rendering Mode: false" in line:
strictrenderdef_found = True
if "Disable Vertex Cache: false" in line:
disvercachedef_found = True
if "Disable On-Disk Shader Cache: false" in line:
disdiskshaderdef_found = True
if "Write Depth Buffer: false" in line:
wrdbufdef_found = True
if "Read Color Buffers: false" in line:
rcbufdef_found = True
if "Read Depth Buffer: false" in line:
rdbufdef_found = True
if "Force Hardware MSAA Resolve: false" in line:
msaaresolvedef_found = True
if "Shader Compiler Threads: 0" in line:
shaderthreadsdef_found = True
if "Allow Host GPU Labels: false" in line:
gpulabelsdef_found = True
if "Asynchronous Texture Streaming 2: false" in line:
asynchtexdef_found = True
if "Start Paused: false" in line:
startpausedef_found = True
if "Pause emulation on RPCS3 focus loss: false" in line:
pausefocusdef_found = True
if "Pause Emulation During Home Menu: false" in line:
pausehomedef_found = True
if not gocentral_found:
game_issues[f"- **You're not on GoCentral :(.** Why not join the fun? The guide at `!rpcs3` can walk you through this."].append(f"L-{i}")
# Non-default settings log
if not ppudef_found:
non_default_settings[f"- **CPU tab:** Set `PPU Decoder` back to `Recompiler (LLVM)`."].append(f"L-{i}")
if not spudef_found:
non_default_settings[f"- **CPU tab:** Set `SPU Decoder` back to `Recompiler (LLVM)`."].append(f"L-{i}")
if not maxcpudef_found:
non_default_settings[f"- **CPU tab:** Set `Max Power Saving CPU-preemptions` back to `0`."].append(f"L-{i}")
if not xfloatdef_found:
non_default_settings[f"- **CPU tab:** Set `SPU XFloat Accuracy` back to `Approximate XFloat`."].append(f"L-{i}")
if not shaderdef_found:
non_default_settings[f"- **GPU tab:** Set `Shader Mode` back to `Async (multi threaded)`."].append(f"L-{i}")
if not strictrenderdef_found:
non_default_settings[f"- **GPU tab:** Disable `Strict Rendering Mode` under the `Additional Settings` section."].append(f"L-{i}")
if not shaderthreadsdef_found:
non_default_settings[f"- **GPU tab:** Set `Number of Shader Compiler Threads` back to `Auto`."].append(f"L-{i}")
if not asynchtexdef_found:
non_default_settings[f"- **GPU tab:** You have enabled `Asynchronous Texture Streaming` under the `Additional Settings`. Only do this if you have a newer GPU and MTRSX enabled for your CPU."].append(f"L-{i}")
if not bindadd_found:
non_default_settings[f"- **Network tab:** Unless you have a good reason, `Bind address` should be set to `0.0.0.0`"].append(f"L-{i}")
if not dns_found:
non_default_settings[f"- **Network tab:** Unless you have a good reason, `DNS` should be set to `8.8.8.8`"].append(f"L-{i}")
if not spudmadef_found:
non_default_settings[f"- **Advanced tab:** Disable `Accurate SPU DMA` under the `Core` section."].append(f"L-{i}")
if not rsxresdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Accurate RSX reservation access` under the `Core` section."].append(f"L-{i}")
if not spuprofdef_found:
non_default_settings[f"- **Advanced tab:** Disable `SPU Profiler` under the `Core` section."].append(f"L-{i}")
if not ppufixdef_found:
non_default_settings[f"- **Advanced tab:** Disable `PPU Fixup Vector NaN Values` under the `Core` section."].append(f"L-{i}")
if not clocksdef_found:
non_default_settings[f"- **Advanced tab:** Set `Clocks scale` back to `100%`."].append(f"L-{i}")
if not wrdbufdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Write Depth Buffer` under the `GPU` section."].append(f"L-{i}")
if not rcbufdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Read Color Buffers DMA` under the `GPU` section."].append(f"L-{i}")
if not rdbufdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Read Depth Buffer` under the `GPU` section."].append(f"L-{i}")
if not rsxtiledef_found:
non_default_settings[f"- **Advanced tab:** Disable `Handle RSX Memory Tiling` under the `GPU` section."].append(f"L-{i}")
if not disvercachedef_found:
non_default_settings[f"- **Advanced tab:** Disable `Disable Vertex Cache` under the `GPU` section."].append(f"L-{i}")
if not disdiskshaderdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Disable On-Disk Shader Cache` under the `GPU` section."].append(f"L-{i}")
if not msaaresolvedef_found:
non_default_settings[f"- **Advanced tab:** Disable `Force Hardware MSAA Resolve` under the `GPU` section."].append(f"L-{i}")
if not gpulabelsdef_found:
non_default_settings[f"- **Advanced tab:** Disable `Allow Host GPU Labels (Experimental)` under the `GPU` section."].append(f"L-{i}")
if not startpausedef_found:
non_default_settings[f"- **Emulator tab:** Disable `Pause emulation after loading savestates` under the `Emulator Settings` section."].append(f"L-{i}")
if not pausefocusdef_found:
non_default_settings[f"- **Emulator tab:** You enabled `Pause emulation on RPCS3 focus loss` under the `Emulator Settings` section. This makes your emulator pause whenever you click out of it. Are you sure about this?"].append(f"L-{i}")
if not pausehomedef_found:
non_default_settings[f"- **Emulator tab:** You enabled `Pause emulation during home menu` under the `Emulator Settings` section. This makes your emulator pause whenever you bring up the home menu. Are you sure about this?"].append(f"L-{i}")
if not ipadd_found:
non_default_settings[f"- You have somehow changed the `IP address` in the config file. Unless you have a good reason, set it back to `0.0.0.0`"].append(f"L-{i}")
if not mfcdef_found:
non_default_settings[f"- You changed `MFC Commands Shuffling Limit` in the config file for RB3. Why? Set it back."].append(f"L-{i}")
# Check for combined issues
if high_memory_detected and debug_console_mode_off:
critical_issues[f"- **dx_high_memory is installed but Debug Console is off! YOUR GAME WILL CRASH!**"].append(f"L-{i}")
if enable_upnp and upnp_error_detected:
critical_issues[f"- **UPNP error detected! You will probably crash while online!**"].append(f"L-{i}")
if vsyncoff_found and above60_vblank_found:
game_issues[f"- **It could be better!** You may get a smoother experience with the new VSync meta. Use `!vsyncmeta` for more information."].append(f"L-{i}")
# Preparing the output
output = ""
if critical_issues:
output += "## Critical :exclamation:\n_Guaranteed to be a problem!_\n"
for issue, lines in critical_issues.items():
line_info = ", ".join(lines) # Combine all line numbers
output += f"{issue} (on {line_info})\n"
if game_issues:
output += "\n## Warning :warning:\n_May or may not cause issues._\n"
for issue, lines in game_issues.items():
line_info = ", ".join(lines) # Combine all line numbers
output += f"{issue} (on {line_info})\n"
if non_default_settings:
output += "\n## Non-default settings :question:\n_Set these in Rock Band 3's Custom Configuration. Use `!global` for more information._\n"
for issue, lines in non_default_settings.items():
line_info = ", ".join(lines) # Combine all line numbers
output += f"{issue} (on {line_info})\n"
if pad_issues:
output += "\n## Pad Issues :guitar:\n_Your controller might not be setup correctly._\n"
for issue, lines in non_default_settings.items():
line_info = ", ".join(lines) # Combine all line numbers
output += f"{issue} (on {line_info})\n"
if not critical_issues and not game_issues and not non_default_settings and not pad_issues:
output += "## No issues detected. Let us know if this is wrong."
# Add emulator information
output += f"\n\n**Version:** {emulator_info['version']}\n**CPU:** {emulator_info['cpu']}\n**GPU:** {emulator_info['gpu']}\n{emulator_info['os']}"
if language_message:
output += f"\n\n{language_message}"
return output