Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

RuntimeError: Access violation - no RTTI data! #7886

Closed
sentry-for-tribler bot opened this issue Feb 5, 2024 · 4 comments
Closed

RuntimeError: Access violation - no RTTI data! #7886

sentry-for-tribler bot opened this issue Feb 5, 2024 · 4 comments

Comments

@sentry-for-tribler
Copy link

sentry-for-tribler bot commented Feb 5, 2024

Sentry Issue: TRIBLER-1JG

RuntimeError: Access violation - no RTTI data!
  File "asyncio\events.py", line 81, in _run
  File "ipv8\taskmanager.py", line 131, in done_cb
  File "ipv8\taskmanager.py", line 18, in interval_runner
  File "ipv8\util.py", line 35, in call_async
  File "tribler\core\components\libtorrent\download_manager\download_manager.py", line 538, in _task_process_alerts
@xoriole xoriole added this to the 7.14.0 milestone Feb 5, 2024
@drew2a
Copy link
Contributor

drew2a commented Mar 26, 2024

    def _task_process_alerts(self):
        for hops, ltsession in list(self.ltsessions.items()):
            if ltsession:
                for alert in ltsession.pop_alerts():  # error has been raised here
                    self.process_alert(alert, hops=hops)

RTTI = Run Time Type Information.

pop_alerts documentation: https://libtorrent.org/reference-Session.html#pop_alerts()

Alerts is the main mechanism for libtorrent to report errors and events. pop_alerts fills in the vector passed to it with 
pointers to new alerts. The [session](https://libtorrent.org/reference-Session.html#session) still owns these alerts and 
they will stay valid until the next time pop_alerts is called. You may not delete the 
[alert](https://libtorrent.org/reference-Alerts.html#alert) objects.

A user has removed a torrent just before the crash:

Request: DELETE http://localhost:50729/downloads/<hash>
Finished: DELETE http://localhost:50729/downloads/<hash>
Request: GET http://localhost:50729/downloads?get_pieces=1
Finished: GET http://localhost:50729/downloads?get_pieces=1
CoreExceptionHandler.unhandled_error_observer(): RuntimeError: Access violation - no RTTI data!

So, I can identify two probable causes of the error:

  1. An alert from a previous pop_alerts call is being modified/accessed during the current call of pop_alerts.
  2. The information about the sessions becomes outdated during the _task_process_alerts since it caches the session list:
    def _task_process_alerts(self):
        for hops, ltsession in list(self.ltsessions.items()):   # <- here
            ...

@drew2a
Copy link
Contributor

drew2a commented Mar 27, 2024

I couldn't find a way to properly fix the error besides addressing it through #7940, which fixes potentially dangerous situations but is not the root cause of the original issue. Therefore, I'm unassigning myself from it.

@drew2a drew2a removed their assignment Mar 27, 2024
Copy link

This issue has not seen activity for 60 days. It is now marked as stale. Please provide additional information or this issue may be closed in the future. We value your contribution and would love to hear more!

@qstokkink
Copy link
Contributor

I cannot reproduce this error. If an error is raised in this location, it is only logged without crashing.

ERROR:DownloadManager:Task resulted in error: Access violation - no RTTI data!
Traceback (most recent call last):
  File "ipv8\taskmanager.py", line 153, in done_cb
    future.result()
  File "ipv8\taskmanager.py", line 28, in interval_runner
    await task(*args)
  File "ipv8\util.py", line 53, in call_async
    return func(*args, **kwargs)
  File "tribler\core\libtorrent\download_manager\download_manager.py", line 604, in _task_process_alerts
    raise RuntimeError("Access violation - no RTTI data!")
RuntimeError: Access violation - no RTTI data!

Apparently, this has already been fixed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Development

No branches or pull requests

3 participants