Skip to content

Mounting

Joachim Metz edited this page Jan 1, 2020 · 5 revisions

Introduction

To mount an Object Linking and Embedding (OLE) Compound File (CF) you can use olecfmount.

There is support for the following back-ends:

  • Dokan library
  • fuse
  • OSXFuse

To build olecfmount see Building.

Mounting

To mount an OLECF file:

olecfmount Text.doc /mnt/fuse

This will expose directories and files that provide the items contained in the OLECF file.

/mnt/fuse/\x05SummaryInformation

If you get the error:

No sub system to mount OLECF.

That means fuse was not detected when building the olecftools, check if you have fuse-dev installed and if ./configure is able to detect it. The last part of the ./configure output shows you this in an overview.

Why is /mnt/fuse not accessible as root

By default fuse prevents root access to the mount point when an OLECF file is mounted. To enable this functionality first check the fuse documentation.

Make sure the fuse configuration file:

/etc/fuse.conf

Contains:

user_allow_other

Pass "allow_root" to the fuse sub system using the olecfmount -X option:

olecfmount -X allow_root Text.doc /mnt/fuse

Windows

To mount an OLECF file on Windows:

olecfmount Text.doc x:

At the moment the olecfmount keeps a hold on the console.

This will expose directories and files that provide the items contained in the OLECF file.

X:\^x05SummaryInformation

Unmounting

You can unmount /mnt/fuse using umount:

umount /mnt/fuse

Or fusermount:

fusermount -u /mnt/fuse

Windows

At the moment terminate the process running in the console.

Troubleshooting

First of all make sure to check the output of configure. If you're seeing something like the following output configure was unable to detect an usable fuse.

Building:
   ...
   FUSE support:                                    no

On Mac OS X:

  • make sure that you only have OSXFuse installed and not another variant, like MacFuse, besides it.
  • try adding the C pre processor flags that set the fuse API version, e.g.
CPPFLAGS=-DFUSE_USE_VERSION=26 ./configure
  • if all else fails; file a support issue and attach config.log

On Ubuntu:

fusermount – failed to open /etc/fuse.conf – Permission denied

Make sure you're part of the group fuse:

sudo addgroup <username> fuse

If fusermount keeps complaining it cannot open fuse.conf:

sudo chmod o+r /etc/fuse.conf
Clone this wiki locally