Skip to main content

read only mounters for qnx filesystems

Project description

QNX Filesystems Mounter

Project Discription

This project contains code to parse and mount (read only) QNX filesystems in non-standard images (HDD / SSD / eMMC).

Existing tools were not able to handle the exotic configurations of some of the filesystems that we encountered in vehicle forensics, for instance on blocksizes greater than 4K on qnx6 filesystems, or non-standard allignment on qnx efs filesystems.

The description of the binary data structure of these filesystems is done with kaitai and this description can be found in the .ksy files in the folders for each respective qnx filesystem (qnx6, etfs, and efs). With Kaitai, a Python based parser was generated. Mounting with these parsers is based on fuse.

This project is only tested on Linux machines.

Getting started

Set up your Python virtual environment and activate the environment:

python3 -m venv venv
source ./venv/bin/activate

Install qnxmount and fuse in the virtual environment:

pip install qnxmount
sudo apt install fuse

Usage

General use of the module is as follows:

python3 -m qnxmount {fs_type} [options] /image /mountpoint

where fs_type is the filesystem type (qnx6, etfs, or efs) and options are the options for that filesystem type.

The options are different for each filesystem type. An overview is given below. For more information use the help option.

python3 -m qnxmount qnx6 [-o OFFSET] /image /mountpoint
python3 -m qnxmount etfs [-o OFFSET] [-s PAGE_SIZE] /image /mountpoint
python3 -m qnxmount efs /image /mountpoint

Note that the offset and page size can be entered in decimal, octal, binary, or hexadecimal format. For example, we can mount an image with a qnx6 filesystem at offset 0x1000 with:

python3 -m qnxmount qnx6 -o 0x1000 /image /mountpoint 

Using the option -o 4096 would give the same result.

If mounting succeeds you will see the log message "Mounting image /image on mount point /mountpoint" appear and the process will hang. Navigate to the given mount point with another terminal session or a file browser to access the file system.

Unmounting can be done from the terminal with:

sudo umount /mountpoint

The logs will show show that the image was successfully unmounted and qnxmount will exit.

Contributing and Testing

If you want develop the tool and run tests, first fork the repository. Contributions can be submitted as a merge request.

To get started clone the forked repository and create a virtual environment. Install the test dependencies and fuse into the environment.

pip install .[test]
sudo apt install fuse

The folder tests contains functional tests to test the different parsers. To run these tests you need a file system image and an accompanying tar archive. The tests run are functional tests that check whether the parsed data from the test image is equal to the data stored in the archive. Default test_images are located in the folders test_data. If you want to test your own image replace the files test_image.bin and test_image.tar.gz with your own.

A test image can be created by running the script make_test_fs.sh inside a QNX Virtual Machine. Update the script with the (edge) cases you want to check and run the command below. This should create an image.bin and image.tar.gz into the specified directory. These can be used as test files.

make_test_fs.sh /path/to/output/directory

To run the tests in this repo navigate to the main directory of the repo and run:

pytest

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

qnxmount-0.1.7.tar.gz (26.1 kB view details)

Uploaded Source

Built Distribution

qnxmount-0.1.7-py3-none-any.whl (30.0 kB view details)

Uploaded Python 3

File details

Details for the file qnxmount-0.1.7.tar.gz.

File metadata

  • Download URL: qnxmount-0.1.7.tar.gz
  • Upload date:
  • Size: 26.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.11.7 Linux/6.6.16-2-MANJARO

File hashes

Hashes for qnxmount-0.1.7.tar.gz
Algorithm Hash digest
SHA256 1d16524720254d894527449728171e9ce18475fa6dafb2906e1eb11db9a2cc28
MD5 702afa1f2e57ed7bddc7a79f683c697b
BLAKE2b-256 bf8db7d10f6e06738448acaf056cf20503e672148b1f10fc55738321e64b351c

See more details on using hashes here.

File details

Details for the file qnxmount-0.1.7-py3-none-any.whl.

File metadata

  • Download URL: qnxmount-0.1.7-py3-none-any.whl
  • Upload date:
  • Size: 30.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.11.7 Linux/6.6.16-2-MANJARO

File hashes

Hashes for qnxmount-0.1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 07e92f07c61fb373e324b87981314f90f7eeb213fc991e229dc5ec4d0a8a1c0c
MD5 602ca2325649ce579591767f4869c0d7
BLAKE2b-256 5ff8eb3a34f0a294a159494f11bde9c63df3f15cc3ccb882303faf6ac28d2d5f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page