Skip to content

Commit

Permalink
Merge pull request #4 from NoMore201/feature/gdb
Browse files Browse the repository at this point in the history
Update tricore-binutils-gdb with LD crash fix
  • Loading branch information
NoMore201 authored Dec 12, 2024
2 parents a184ad6 + dcf178e commit e621360
Show file tree
Hide file tree
Showing 5 changed files with 115 additions and 5 deletions.
5 changes: 4 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -3,4 +3,7 @@ autom4te.cache
configure~

# IDE config folders
.vscode
.vscode

# Python venv
.venv
101 changes: 101 additions & 0 deletions docs/building.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,101 @@
# Build instructions

## GCC Toolchain

### Native build

This chapter refers to building the Tricore cross-compiler directly from the
host architecture.

Instructions showed here are tested on Ubuntu 22.04 (see
[Github Actions script](https://github.com/NoMore201/tricore-gcc-toolchain/blob/main/.github/workflows/build.yml)), but should ideally
work on other Linux distributions and also MSYS2 Windows environment.

Clone the repository:

```sh
git clone --recursive [email protected]:EEESlab/tricore-gcc-toolchain-11.3.0.git
```

Install build dependencies:

```sh
sudo ./scripts/install-gcc-deps
```

Create a temporary build directory and call the `configure` script

```sh
mkdir build && cd build
../configure --prefix=/path/to/prefix
make -j$(nproc) stamps/build-gcc-stage2
```

This will build and install everything into `/path/to/prefix`.

It is also possible to compile single components of the toolchain. For further information on the available options, refer to `configure` script help page and
the [Makefile](https://github.com/NoMore201/tricore-gcc-toolchain/blob/main/Makefile.in).

### MinGW canadian cross build

Sometimes it may be useful to build a cross-compiler from architecture B to architecture C, by performing the build on a third architecture A. The reason
is that setting up architecture B for cross-compilation may be not as easy as
on architecture A. This is called a
[canadian cross](https://en.wikipedia.org/wiki/Cross_compiler#Canadian_Cross).

In this case, the idea is to build Win32 tricore-elf-gcc (cross-compiler from
Win32 to `tricore-elf`) directly on Linux due to easier setup and the
reproducibility of the environment.

You can see an example of a canadian cross build in the
[Github Actions script](https://github.com/NoMore201/tricore-gcc-toolchain/blob/main/.github/workflows/build.yml). First clone the
toolchain repository:

```sh
git clone --recursive [email protected]:EEESlab/tricore-gcc-toolchain-11.3.0.git
```

Install build dependencies, including MinGW cross-compiler:

```sh
sudo ./scripts/install-gcc-deps
```

First we need to build the linux -> tricore cross-compiler. Refer to the
[Native build](#native-build) chapter on how to do so.

When linux -> tricore cross-compiler is ready, we need to install the newlib
also into the final Win32 prefix. To do so, switch to the linux build directory
and call make by swapping the prefix variable:

```sh
cd build-linux/build-newlib
make install prefix=/path/to/win32-prefix
```

Now modify `PATH` environment variable with the PATH to linux cross-compiler:

```sh
export PATH="/path/to/linux-prefix:$PATH"
```

Finally we configure and build the missing components with the following
commands

```sh
mkdir build-win32 && cd build-win32
../configure --prefix /path/to/win32-prefix --with-host=x86_64-w64-mingw32
make -j$(nproc) stamps/build-binutils-tc
export PATH="/opt/gcc/linux/bin:$PATH"
make -j$(nproc) stamps/build-gcc-stage2-only
```

## QEMU

### Native build

> WIP
### MinGW canadian cross build

> WIP
7 changes: 4 additions & 3 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,10 @@ includes the following software:
## Install

Grab the latest release from
Grab the latest pre-compiled toolchain from
[GitHub releases](https://github.com/NoMore201/tricore-gcc-toolchain/releases).
To build the toolchain manually from sources, please refer to the main
[README.md](https://github.com/NoMore201/tricore-gcc-toolchain/blob/main/README.md).

To build the toolchain manually from sources, please refer to the
[build page](./building.md).


5 changes: 5 additions & 0 deletions mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,15 @@ repo_url: https://github.com/NoMore201/tricore-gcc-toolchain
repo_name: tricore-gcc-toolchain
theme:
name: material
features:
- navigation.tabs
- navigation.top
- toc.integrate

plugins: []

nav:
- Home: index.md
- Build: building.md
- Changelog: changelog.md
- Debuggin with QEMU: qemu-debug.md
2 changes: 1 addition & 1 deletion tricore-binutils-gdb

0 comments on commit e621360

Please sign in to comment.