Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8357097
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 9, 20262026-06-09T10:22:34+00:00 2026-06-09T10:22:34+00:00

When I use Subversion in Cygwin to update some repository, some directories update with

  • 0

When I use Subversion in Cygwin to update some repository, some directories update with success, while some other one gets a failure with the error message:

svn: E200030: sqlite: disk I/O error

When doing svn update again for the same repository, a different directory can get the same error. Sometimes, there is a SVN instruction after the above error message.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-09T10:22:37+00:00Added an answer on June 9, 2026 at 10:22 am

    This happened due to a change someone wanted in Cygwin’s SQLite package. I was the maintainer of that package when this question was asked, and I made the change that caused this symptom.

    The change was released as Cygwin SQLite version 3.7.12.1-1, and it fixed that one person’s problem, but it had this bad side effect of preventing Cygwin’s Subversion package from cooperating with native Windows Subversion implementations.

    What Happened?

    The core issue here is that Subversion 1.7 changed the working copy on-disk format. Part of that change involves a new SQLite database file, .svn/wc.db. Now, in order to implement SQLite’s concurrency guarantees, SQLite locks the database file while it is accessing it.

    That’s all fine and sensible, but you run into a problem when you try to mix Windows native and POSIX file locking semantics. On Windows, file locking almost always means mandatory locking, but on Linux systems — which Cygwin is trying to emulate — locking usually means advisory locking instead.

    That helps understand where the “disk I/O error” comes from.

    The Cygwin SQLite 3.7.12.1-1 change was to build the library in “Unix mode” instead of “Cygwin mode.” In Cygwin mode, the library uses Windows native file locking, which goes against the philosophy of Cygwin: where possible, Cygwin packages call POSIX functions instead of direct to the Windows API, so that cygwin1.dll can provide the proper POSIX semantics.

    POSIX advisory file locking is exactly what you want with SQLite when all the programs accessing the SQLite DBs in question are built with Cygwin, which is the default assumption within Cygwin. But, when you run a Windows native Subversion program like TortoiseSVN alongside a pure POSIX Cygwin svn, you get a conflict. When the TortoiseSVN Windows Explorer shell extension has the .svn/wc.db file locked with a mandatory lock and Cygwin svn comes along and tries an advisory lock on it, it fails immediately. Cygwin svn assumes a lock attempt will either succeed immediately or block until it can succeed, so it incorrectly interprets the lock failure as a disk I/O error.

    How Did We Solve This Dilemma?

    Within Cygwin, we always try to play nice with Windows native programs where possible. The trick was to find a way to do that, while still playing nice with Cygwin programs, too.

    Not everyone agreed that we should attempt this. “Cygwin SQLite is part of Cygwin, so it only needs to work well with other Cygwin programs,” one group would say. The counterpartisans would reply, “Cygwin runs on Windows, so it has to perform well with other Windows programs.”

    Fortunately, we came up with a way to make both groups happy.

    As part of the Cygwin SQLite 3.7.17-x packaging effort, I tested a new feature that Corinna Vinschen added to cygwin1.dll version 1.7.19. It allowed a program to request mandatory file locking through the BSD file locking APIs. My part of the change was to make Cygwin SQLite turn this feature on and off at the user’s direction, allowing the same package to meet the needs of both the Cygwin-centric and Windows-native camps.

    This Cygwin DLL feature was further improved in 1.7.20, and I released Cygwin SQLite 3.7.13-3 using the finalized locking semantics. This version allowed a choice of three locking strategies: POSIX advisory locking, BSD advisory locking, and BSD/Cygwin mandatory locking. So far, the latter strategy has proven to be completely compatible with native Windows locking.

    Later, when Jan Nijtmans took over maintenance of Cygwin SQLite, he further enhanced this mechanism by fully integrating it with the SQLite VFS layer. This allowed a fourth option: the native Windows locking that Cygwin SQLite used to use before we started on this journey. This is mostly a hedge against the possibility that the BSD/Windows locking strategy doesn’t cooperate cleanly with a native Windows SQLite program. So far as I know, no one has ever needed to use this option, but it’s nice to know it’s there.

    Alternate Remedy

    If the conflict you’re having is between Cygwin’s command line svn and the TortoiseSVN Windows Explorer shell extension, there’s another option to fix it. TortoiseSVN ships with native Windows Subversion command-line programs as well. If you put these in your PATH ahead of Cygwin’s bin directory, you shouldn’t run into this problem at all.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

while coding a little iPhone App with a friend, we decided to use Subversion
we are a small startup company, starting from scratch. We use Subversion, the repository
I'm developing some class libraries with a distributed team. We use Subversion for our
Do you use Subversion while developing a website with drupal ? I'm not talking
I have a subversion repository under /var/svn/ I am trying to use subversion to
I have a repository that is currently using Subversion, but I'd like to use
I am just starting to use Subversion with Tortoise SVN client for one of
We use Subversion for version control and Jira for tickets. All our commit messages
We use Subversion locally, and we're working on a project that uses a fork
I use subversion to manage my yii website (php framework) and have separate backend

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.