## cisco live!







# Working with and building for non-x86 Compute Architectures

Background - Problem - Solution(s)

Jens Depuydt – Technical Leader CX EMEAR @jensdepuydt DEVNET-3001





### Cisco Webex App

#### Questions?

Use Cisco Webex App to chat with the speaker after the session

#### How

- 1 Find this session in the Cisco Live Mobile App
- 2 Click "Join the Discussion"
- 3 Install the Webex App or go directly to the Webex space
- 4 Enter messages/questions in the Webex space

Webex spaces will be moderated by the speaker until June 17, 2022.



https://ciscolive.ciscoevents.com/ciscolivebot/#DEVNET-3001





## Agenda

- Background: Compute Architecture
- Challenge working with non-x86
- Solutions + Demos
- Summary

## Compute Architectures



## CPU - Central Processing Unit

In essence: Fetch - Decode - Execute - (Store)





#### ISA - Instruction Set Architecture

- Decode: ISA Defines the way:
  - Instructions are processed
  - Memory is accessed
  - IO is managed
- High-level programming language abstracts complexity
- Compiler translates code to lower-level instructions
- CPU further decodes into microcode operations





## Different ISAs/Compute Architectures

| he table belov           | v compares bas | ic infor | rmation about ins                        | truction sets to | be impleme            | nted in | the CPU archited                | tures:        |                          |                                   |                                    |                                                 |                |                                                                                |                                                                                  |                                      |                 |                                                                        |      |             |
|--------------------------|----------------|----------|------------------------------------------|------------------|-----------------------|---------|---------------------------------|---------------|--------------------------|-----------------------------------|------------------------------------|-------------------------------------------------|----------------|--------------------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------------------------------|-----------------|------------------------------------------------------------------------|------|-------------|
| Archi-<br>tecture        | Bits +         | Vei      | CDC Upper 3000 series                    | 48               |                       | 1963    | 3                               | Register-     |                          | 8-bit A reg., 4<br>5-bit B regist | 18-bit Q reg., 6                   | Variable (24- or                                | 48-bit)        |                                                                                | Multiple types of Rig                                                            |                                      |                 |                                                                        |      |             |
| 3502                     | 8              |          | CDC 6000<br>Central                      | 60               |                       | 1964    | Nios II                         | 32            |                          | 200x                              | 3                                  | Register-<br>Register                           | RISC           | 32                                                                             | Fixed (32-bit)                                                                   | Condition register                   | Little          | Soft processor that can<br>be instantiated on an<br>Altera FPGA device | No   | On Altera/I |
| 6809                     | 8              |          | Processor (CP)                           |                  |                       |         | NS320xx                         | 32            |                          | 1982                              | 5                                  | Memory-<br>Memory                               | CISC           | 8                                                                              | Variable Huffman coded, up to 23 bytes long                                      | Condition code                       | Little          | BitBlt instructions                                                    |      |             |
| 580x0                    | 32             |          | CDC 6000<br>Peripheral<br>Processor (PP) | 12               |                       | 1964    | OpenRISC                        | 32, 64        | 1.3[21]                  | 2010                              | 3                                  | Register-<br>Register                           | RISC           | 16 or 32                                                                       | Fixed                                                                            | ?                                    | ?               | ?                                                                      | Yes  | Yes         |
| 080                      | 8              |          | Processor (PP)                           |                  |                       |         | PA-RISC<br>(HP/PA)              | 64 (32→64)    | 2.0                      | 1986                              | 3                                  | Register-<br>Register                           | RISC           | 32                                                                             | Fixed (32-bit)                                                                   | Compare and branch                   | Big → Bi        | MAX                                                                    | No   |             |
| 8051 32 (8→32)           |                | Crusoe   | 32(13)                                   | 2000             | PDP-8 <sup>[22]</sup> | 12      |                                 | 1966          |                          | Register-<br>Memory               | CISC                               | 1 accumulator<br>1 multiplier quotient register | Fixed (12-bit) | Condition register<br>Test and branch                                          |                                                                                  | EAE (Extended Arithmetic<br>Element) |                 |                                                                        |      |             |
|                          |                |          | (native VLIW)                            |                  |                       |         | PDP-11                          | 16            |                          | 1970                              | 2                                  | Memory-<br>Memory                               | CISC           | 8 (includes stack pointer,<br>though any register can<br>act as stack pointer) | Variable (16-, 32-, or 48-bit)                                                   | Condition code                       | Little          | Floating Point,<br>Commercial Instruction<br>Set                       | No   | No          |
| x86 16, 32, 64 (16→32→64 |                |          | Elbrus<br>(native VLIW)                  | 64 Elbrus-4S     | Elbrus-4S             | 2014    | POWER,<br>PowerPC, Power<br>ISA | 32/64 (32→64) | 3.1 <sup>[23]</sup>      | 1990                              | 3                                  | Register-<br>Register                           | RISC           | 32                                                                             | Fixed (32-bit), Variable (32- or 64-bit with the 32-bit prefix <sup>(23)</sup> ) | Condition code                       | Big/Bi          | AltiVec, APU, VSX, Cell                                                | Yes  | Yes         |
| Alpha                    | 64             |          | DI V                                     |                  |                       | 4000    | RISC-V                          | 32, 64, 128   | 20191213 <sup>[24]</sup> | 2010                              | 3                                  | Register-<br>Register                           | RISC           | 32 (including "zero")                                                          | Variable                                                                         | Compare and<br>branch                | Little          | ?                                                                      | Yes  | Yes         |
|                          | 16/32/64       |          | DLX                                      | 32               |                       | 1990    | RX                              | 64/32/16      |                          | 2000                              | 3                                  | Memory-<br>Memory                               | CISC           | 4 integer + 4 address                                                          | Variable                                                                         | Compare and<br>branch                | Little          |                                                                        |      | No          |
| IRC                      | (32→64)        | ARC      | eSi-RISC                                 | 16/32            |                       | 2009    | S+core                          | 16/32         |                          | 2005                              |                                    |                                                 | RISC           |                                                                                |                                                                                  |                                      | Little          |                                                                        |      |             |
| IRM/A32                  | 32             | ARM      | Itanium                                  |                  |                       |         | SPARC                           | 64 (32-64)    | OSA2017 <sup>[25]</sup>  | 1985                              | 3                                  | Register-<br>Register                           | RISC           | 32 (including "zero")                                                          | Fixed (32-bit)                                                                   | Condition code                       | Big → Bi        | VIS                                                                    | Yes  | Yes         |
| Thumb/T32                | 32             | ARM      | (IA-64)                                  | 64               |                       | 2001    |                                 |               |                          |                                   |                                    | Register-                                       |                |                                                                                |                                                                                  |                                      |                 |                                                                        |      |             |
|                          |                | ARM      | M32R                                     | 32               |                       | 1997    | SuperH (SH)                     | 32            |                          | 1994                              | 2                                  | Register Register Memory                        | RISC           | 16                                                                             | Fixed (16- or 32-bit), Variable                                                  | Condition code<br>(single bit)       | Bi              |                                                                        | Yes  | Ye          |
| rm64/A64                 | 64             | ARM      | Mico32                                   | 32               | ?                     | 2006    |                                 |               |                          |                                   | 2 (most)                           | Register-<br>Memory                             |                | 16 general                                                                     |                                                                                  |                                      |                 |                                                                        |      |             |
| AVR                      | 8              |          | MIPS                                     | 64 (32-64)       | 6[17][18]             | 1981    | System/360<br>System/370        | 64 (32-64)    |                          | 1964                              | 3 (FMA, distinct operand facility) | Memory-<br>Memory                               | CISC           | 16 control (S/370 and later)<br>16 access (ESA/370 and                         | Variable (16-, 32-, or 48-bit)                                                   | Condition code,<br>compare and       | Big             |                                                                        | No   | No          |
|                          |                |          | MMIX                                     | 64               | ?                     | 1999    | z/Architecture                  |               |                          |                                   | 4 (some vector inst.)              | Register-<br>Register                           |                | later)                                                                         |                                                                                  | branch                               |                 |                                                                        |      |             |
|                          |                |          | Nios II                                  | 32               |                       | 200x    | Transputer                      | 32 (4→64)     |                          | 1987                              | 1                                  | Stack<br>machine                                | MISC           | 3 (as stack)                                                                   | Variable (8 ~ 120 bytes)                                                         | Compare and branch                   | Little          |                                                                        |      |             |
| VR32                     | 32             | Rev      | NOODO                                    | 00               |                       | 4000    | VAX                             | 32            |                          | 1977                              | 6                                  | Memory-<br>Memory                               | CISC           | 16                                                                             | Variable                                                                         | Compare and branch                   | Little          |                                                                        | No   |             |
|                          |                |          | NS320xx                                  | 32               |                       | 1982    | Z80                             | 8             |                          | 1976                              | 2                                  | Register-                                       | CISC           | 17                                                                             | Variable (8 to 32 bits)                                                          | Condition register                   | Little          |                                                                        |      |             |
| Blackfin                 | 32             |          | OpenRISC                                 | 32, 64           | 1.3 <sup>[21]</sup>   | 2010    | Archi-<br>tecture               | Bits          | Version                  | Intro-                            | Max #                              | Memory                                          | Design         | Registers (excluding FP/vector)                                                | Instruction encoding                                                             | Branch<br>evaluation                 | Endian-<br>ness | Extensions                                                             | Open | Royal       |



### Different ISAs/Compute Architectures

|                    | x86                                                | ARM                                                      | Power                                                                      |  |  |  |
|--------------------|----------------------------------------------------|----------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|
| Since              | 1978                                               | 1985                                                     | 1992                                                                       |  |  |  |
| # Bit              | 16/32/64                                           | 32/64                                                    | 32/64                                                                      |  |  |  |
| Instruction set    | CISC                                               | RISC                                                     | RISC                                                                       |  |  |  |
| Endianness         | Little                                             | Bi (little by default)                                   | Bi (big by default)                                                        |  |  |  |
| Power usage        | High                                               | Low                                                      | Medium                                                                     |  |  |  |
| Linux architecture | i386/amd64/x86_64                                  | arm/arm64/aarch64                                        | powerpc/ppc/ppc64                                                          |  |  |  |
| Licensing          | Strict                                             | Flexible                                                 | Semi-strict                                                                |  |  |  |
| Examples           | Intel 8086 Intel Pentium/Core/Xeon AMD (Ryzen) VIA | Cortex (A/X) Samsung Exynos Qualcomm Snapdragon Apple M1 | IBM Power (Power10) Freescale (T-series) Xenon (Xbox 360) Espresso (Wii U) |  |  |  |
| , ,                | (^60)                                              | ARM.                                                     | Power                                                                      |  |  |  |



#### Current situation: ARM vs x86

×86 VS ARM

- In essence: RISC vs. CISC
- x86 traditionally targets peak performance, ARM energy efficiency
- For workstations & servers: choice of ISA is not technical
  - With the right hardware, everything can run performant
  - Code compatibility is most important
  - Today, x86 is dominant here
- For embedded, RISC makes sense
  - Smaller, cheaper, less power
  - Today, ARM is dominant here

| CISC                 | RISC                |
|----------------------|---------------------|
| Complex instructions | Simple instructions |
| More registers       | Less Registers      |
| Microprogramming     | Complex compilers   |
| Hardware-focused     | Software-focused    |



## The problem



#### The problem - Current situation

- Mix of architectures is real today
- Developper workstation and destination on different architecure
- Compiled binary or container image: doesn't run



#### The problem - Current situation

- Mix of architectures is real today
- Developper workstation and destination on different architecure
- Compiled binary or container image: doesn't run



### The problem - In practice

- For self-written code/tools/automation/containers
- But also for common tools:
  - In theory: use package manager
  - In practice:
    - Missing packages
    - Missing dependencies
    - No package manager
    - Old/EOL version
    - Uncommon/custom distro
    - Dark site





### The problem - Relevant for Cisco?

- Where is this relevant?
  - IOx
  - App-hosting
  - Guest-shell
  - Guest-OS (GOS)
  - Open Agent Container (OAC)
- Platforms:
  - Data Center: NX-OS: x86
  - Service Provider: IOS-XR: x86, 32/64 bit ARM
  - Enterprise: IOS-XE: x86, 32/64 bit ARM, Power-PC



## Solutions



#### Solutions

- 1) Develop/Build/Test on destination
- 2) Platform independent languages
- 3) Cross compilation
  - Static linking
- 4) Emulation
  - QEMU/binfmt
- Automation
  - · CI/CD
  - Docker BuildX





### 1) Develop/Build/Test on destination architecture

- Build native:
  - Remote device on destination architecture
  - Remote Docker
  - Cloud-based solution:
    - AWS Gravitron
    - · Custom Silicon with Neoverse
    - OCI Ampere A1
    - Ampere Altra
    - MS Azure (Preview)
    - · Ampere Altra





## 2) Platform Independent Languages

- Interpreted programming language:
  - Compile (at runtime) into platform indepent bytecode
  - Architecture-specific Virtual Machine runs bytecode
- Popular examples:
  - Java
  - Python
  - PHP
  - Bash



#### Platform Independent Languages - Simple Demo

```
jensd@Macbook ~ % cat test.py
#!/usr/bin/python3

import os
arch = os.uname().machine
print("Hello Devnet!")
print("This code is running on:", arch)
```

#### Run on x86:

Source code:

```
jensd@deb1:~$ uname -m
x86_64
jensd@deb1:~$ ./test.py
Hello Devnet!
This code is running on: x86_64
```

#### Run on ARM:

```
jensd@deb2:~$ uname -m
aarch64
jensd@deb2:~$ ./test.py
Hello Devnet!
This code is running on: aarch64
```



## 3) Cross Compiling

- Compiled language: C/C++/Go/Rust/...
- Build for platform X on platform Y
- Terminology:
  - Build platform: Architecture of build machine
  - Host platform: Architecture you are building for
  - Target platform: When building compiler tools
- Build platform can't run resulting binary





## Cross Compiling - Demo - Prepare machine

For 64 bit ARM (aarch64):

```
jensd@deb1:~$ sudo apt install gcc make gcc-aarch64-linux-gnu
binutils-aarch64-linux-gnu
Reading package lists... Done
Building dependency tree... Done
                                                  cross-compiler
Processing triggers for man-db (2.8.5-2) ...
Processing triggers for libc-bin (2.28-10) ...
```

```
ARM (arm):
```

```
jensd@deb1:~$ sudo apt install gcc make gcc-arm-linux-gnueabi
For 32 bit binutils-arm-linux-gnueabi
          Reading package lists... Done
          Building dependency tree... Done
```

assembler (as), linker (ld) and binary tools

(2.8.5-2) ... oin (2.28-10) ...



## Cross Compiling - Simple Demo 1/2 - Build

```
jensd@deb1:~$ cat helloworld.c
                      #include<stdio.h>
                      int main()
       Source code:
                               printf("Hello Devnet!\n");
                               return 0;
Build on x86:
                         cross-compiler
jensd@deb1:~$ uname -m
x86 64
jensd@deb1:~$ aarch64-linux-gnu-gcc helloworld.c -o helloworld-aarch64 --static
jensd@deb1:~$ file helloworld-aarch64
helloworld-aarch64: ELF 64-bit LSB executable, ARM aarch64, version 1
(GNU/Linux), statically linked,
BuildID[sha1]=eeb6cee92dd8cce1832cee6a3fb236cf659996b8, for GNU/Linux 3.7.0,
not stripped
                                                        output (binary)
```

### Cross Compiling - Simple Demo 2/2 - Run

• Run on x86:

```
jensd@deb1:~$ uname -m
x86_64
jensd@deb1:~$ ./helloworld-aarch64
-bash: ./helloworld-aarch64: cannot execute binary file: Exec format error
```

Run on ARM:

```
jensd@deb2:~$ uname -m
aarch64
jensd@deb2:~$ ./helloworld-aarch64
Hello Devnet!
```



## Cross Compiling - Dependencies

- What about dependencies?
- By default and recommended: Dynamic Linking
- Dependencies are external libs and architecture specific





## Cross Compiling - Static Linking

- Static linking: include dependencies in binary
- Not recommended\*
  - Unsecure: no patches/updates in included libs
  - Incompatibility: conflicting libraries that do lower level system calls
  - Larger resulting binary
  - Can be difficult, especially with libc/glibc



Program X (statically linked)

Program specific

Program data

Lib (dependency)

Lib (dependency)

\*It works for me ©



DEVNET-3001

## Cross Compiling - Static Linking - Demo 1/3

Build open source tool: tcpdump on x86\_64 to use on aarch64



#### Get source code:

```
jensd@deb1:~$ wget https://www.tcpdump.org/release/libpcap-1.10.1.tar.gz
jensd@deb1:~$ tar -xvzf libpcap-1.10.1.tar.gz
jensd@deb1:~$ wget https://www.tcpdump.org/release/tcpdump-4.99.1.tar.gz
jensd@deb1:~$ tar -xvzf tcpdump-4.99.1.tar.gz
jensd@deb1:~$ cd libpcap-1.10.1/
jensd@deb1:~/libpcap-1.10.1$
```



## Cross Compiling - Static Linking - Demo 2/3

Build libpcap and tcpdump for aarch64 on x86\_64 using musl

```
jensd@deb1:~/libpcap-1.10.1$ CC=aarch64-linux-musl-qcc
      jensd@deb1:~/libpcap-1.10.1$ ./configure --build x86 64-pc-linux-gnu --host
      aarch64-linux-gnu LDFLAGS="-static"
      checking build system type... x86 64-pc-linux-gnu
      checking host system type... aarch64-unknown-linux-gnu
                                                                 build-architecture
host-architecture ibpcap-1.10.1$ make
                                            static linking
      jensd@deb1:~/libpcap-1.10.0$ cd ../tcpdump-4.99.1
      jensd@deb1:~/tcpdump-4.99.0$./configure --build x86 64-pc-linux-gnu --host
      aarch64-linux-qnu LDFLAGS="-static"
      jensd@deb1:~/tcpdump-4.99.0$ make
      jensd@deb1:~/tcpdump-4.99.1$ file tcpdump
      tcpdump: ELF 64-bit LSB pie executable, ARM aarch64, version 1 (SYSV), statically
      linked, with debug info, not stripped
```



### Cross Compiling - Static Linking - Demo 3/3

• Run on x86:

```
jensd@deb1:~/tcpdump-4.99.1$ ldd tcpdump
    not a dynamic executable
jensd@deb1:~/tcpdump-4.99.1$ ./tcpdump
-bash: ./tcpdump: cannot execute binary file: Exec format error
```

Run on ARM:

```
jensd@deb2:~$ uname -m
aarch64
jensd@deb2:~$ sudo ./tcpdump -i enp0s9
tcpdump: verbose output suppressed, use -v[v]... for full protocol decode
listening on enp0s9, link-type EN10MB (Ethernet), snapshot length 262144
bytes
...
```



#### 4) Emulation - QEMU - Virtualization

- QEMU: Generic and open source machine emulator and virtualizer
- Supports many CPU architectures
  - For example: ARM, alpha, MIPS, PowerPC, SPARC, s390x, ...

- Option 1: Virtualization
  - · Run virtual machine
  - Build/Test on VM as on native platform





PEMU

#### 5) Emulation - QEMU - User mode emulation

- Option 2: QEMU User mode emulation: Run processes compiled for one architecture on another
- Binfmt: Kernel Support for miscellaneous Binary Formats
  - Capability of Linux kernel
  - Instructs kernel to run non-x86 binaries with QEMU
- Build/Run Docker image/container for different arch
- Test binaries as on native

User mode emulation:

Process for CPU arch Y

User space: emulated

Kernel: native

CPU arch X: native



## Emulation - Demo - Prepare Developer machine

- Install OS/Docker
- Install QEMU emulation binaries and binfmt

jensd@deb1:~\$ sudo apt-get install qemu-user qemu-user-static binfmt-support

User mode emulation binaries:

```
jensd@deb1:~$ ls /usr/bin/qemu-*static
/usr/bin/gemu-aarch64-static
                                    /usr/bin/gemu-mips64-static
                                                                     /usr/bin/gemu-s390x-static
/usr/bin/gemu-alpha-static
                                    /usr/bin/gemu-mipsel-static
                                                                     /usr/bin/gemu-sh4eb-static
                                                                     /usr/bin/qemu-sh4-static
/usr/bin/gemu-armeb-static
                                    /usr/bin/gemu-mipsn32el-static
/usr/bin/gemu-arm-static
                                    /usr/bin/gemu-mipsn32-static
                                                                     /usr/bin/gemu-sparc32-static
/usr/bin/gemu-cris-static
                                    /usr/bin/gemu-mips-static
                                                                     /usr/bin/gemu-sparc64-static
/usr/bin/gemu-i386-static
                                    /usr/bin/gemu-or32-static
                                                                     /usr/bin/gemu-sparc-static
/usr/bin/gemu-m68k-static
                                    /usr/bin/gemu-ppc64abi32-static
                                                                     /usr/bin/gemu-tilegx-static
/usr/bin/gemu-microblazeel-static
                                    /usr/bin/gemu-ppc64le-static
                                                                     /usr/bin/gemu-x86 64-static
/usr/bin/gemu-microblaze-static
                                    /usr/bin/gemu-ppc64-static
/usr/bin/gemu-mips64el-static
                                    /usr/bin/qemu-ppc-static
```



#### Emulation - Demo - Test User mode emulation

• On x86:

```
jensd@deb1:~$ uname -m
x86_64
jensd@deb1:~$ docker run -v /usr/bin/qemu-aarch64-static:/usr/bin/qemu-
aarch64-static -i -t arm64v8/alpine
/ # uname -m
aarch64
Container needs emulation binary
```

In the background:

```
jensd@deb1-x86-64:~$ ps aux | grep qemu
jensd     508680     0.6     0.8 1201160 47844 pts/1     Sl+ 16:45     0:00
docker run -v /usr/bin/qemu-aarch64-static:/usr/bin/qemu-aarch64-
static -it --rm arm64v8/alpine
root     508741     0.6     0.1 226092     7700 pts/0     Ssl+ 16:45     0:00
/usr/libexec/qemu-binfmt/aarch64-binfmt-P /bin/sh /bin/sh
```



## Emulation - Demo - non-x86 Docker image 1/2

1) Dockerfile & Node.js source:

```
COPY qemu-aarch64-static /usr/bin
RUN apk add --no-cache nodejs npm
COPY server.js .
EXPOSE 1337
CMD ["node", "server.js"]
```

jensd@deb1-x86-64:~\$ cat server.js
var http = require('http');
var os = require('os');

Ir kernel=os.release();
Ir arch=process.arch;

Ir server = http.createServer(function (request, response) {
 response.writeHead(200, {"Content-Type": "text/html"});
 response.end("<h1>Node & Docker Running <br /> Kernel:
 kernel+"<br />Arch:"+arch+"<h1>");
;

server.listen(1337);
console.log("Node HTTP Server started at port 1337");

2) Build on x86

```
jensd@deb1:~$ docker build -t devnetjs .
```

2) Run

```
jensd@deb1:~$ docker run -ti --rm -p 1337:1337 devnetjs
Node HTTP Server started at port 1337
```





## Emulation - Demo - non-x86 Docker image 2/2





#### **Emulation - Testing**

- Remember the cross-compiled tools we could not run?
- After installing QEMU and binfmt:

```
jensd@deb1:~$ uname -m
x86_64
jensd@deb1:~$ file helloworld-aarch64
helloworld-aarch64: ELF 64-bit LSB executable, ARM aarch64, version 1
(GNU/Linux), statically linked,
BuildID[sha1]=eeb6cee92dd8cce1832cee6a3fb236cf659996b8, for GNU/Linux
3.7.0, not stripped
jensd@deb1:~$ ./helloworld-aarch64
Hello Devnet!
```



#### **Automation**

- Integrate in CI/CD pipeline
  - · Cross Compile, Emulation, Testing, ...
  - Gitlab runners for each arch
- Docker BuildX:
  - Using QEMU emulation support in the kernel
  - Building on multiple native nodes using same builder instance
  - Using stage in Dockerfile to crosscompile to different architectures







## Summary

Situation today: mix of x86 and ARM

Code platform independent

Use Cross Compilation for compiled languages

Use Emulation to build containers and testing

Combine everything with automation



## **Technical Session Surveys**

- Attendees who fill out a minimum of four session surveys and the overall event survey will get Cisco Live branded socks!
- Attendees will also earn 100 points in the Cisco Live Game for every survey completed.
- These points help you get on the leaderboard and increase your chances of winning daily and grand prizes.





## Cisco Learning and Certifications

From technology training and team development to Cisco certifications and learning plans, let us help you empower your business and career. www.cisco.com/go/certs

#### Pay for Learning with Cisco Learning Credits

(CLCs) are prepaid training vouchers redeemed directly with Cisco.



#### Learn



#### Train



#### Certify



#### Cisco U.

IT learning hub that guides teams and learners toward their goals

#### Cisco Digital Learning

Subscription-based product, technology, and certification training

#### Cisco Modeling Labs

Network simulation platform for design, testing, and troubleshooting

#### **Cisco Learning Network**

Resource community portal for certifications and learning



#### **Cisco Training Bootcamps**

Intensive team & individual automation and technology training programs

#### **Cisco Learning Partner Program**

Authorized training partners supporting Cisco technology and career certifications

#### Cisco Instructor-led and Virtual Instructor-led training

Accelerated curriculum of product, technology, and certification courses



#### Cisco Certifications and Specialist Certifications

Award-winning certification program empowers students and IT Professionals to advance their technical careers

#### Cisco Guided Study Groups

180-day certification prep program with learning and support

#### Cisco Continuing Education Program

Recertification training options for Cisco certified individuals

Here at the event? Visit us at The Learning and Certifications lounge at the World of Solutions





## Continue your education

- Visit the Cisco Showcase for related demos
- Book your one-on-one Meet the Engineer meeting
- Attend the interactive education with DevNet, Capture the Flag, and Walk-in Labs
- Visit the On-Demand Library for more sessions at www.CiscoLive.com/on-demand



## Thank you



## cisco Live!





## Additional Examples



### Cross Compiling - Demo with make 1/3 - Source

Build open source tool: strace on x86\_64 to use on aarch64



#### Get source code:

```
jensd@deb1:~$ wget https://github.com/strace/.../v5.17/strace-5.17.tar.xz
...
strace-5.17.tar.xz 100%[================]] 2.17M 11.6MB/s in 0.2s
2022-04-22 17:22:46 (11.6 MB/s) - 'strace-5.17.tar.xz' saved [2281220/2281220]
jensd@deb1:~$ tar -xf strace-5.17.tar.xz
jensd@deb1:~$ cd strace-5.17/
jensd@deb1:~/strace-5.17$
```

DEVNET-3001

#### Cross Compiling - Demo with make 2/3 - Build

#### Building on x86: build-architecture host-architecture jensd@deb1:~\$ uname -m x86 64 jensd@deb1:~\$ ./configure --build x86 64-pc-linux-gnu --host aarch64-linuxgnu LDFLAGS="-static -pthread" --enable-mpers=check checking for a BSD-compatible install... /usr/bin/install -c checking for aarch64-linux-gnu-strip... aarch64-linux-gnu-strip jensd@deb1:~/strace-5.17\$ make aarch64-linux-qnu-qcc -E -P -DHAVE CONFIG H \ make[1]: Leaving directory '/home/jensd/strace-5.17' jensd@deb1:~/strace-5.17\$ file ./src/strace ./src/strace: ELF 64-bit LSB executable, ARM aarch64, version 1 (GNU/Linux), statically linked, BuildID[sha1]=c198971f9db07df7b05eb195a8ef9cc9f16657fe, for GNU/Linux 3.7.0, with debug info, not stripped

#### Cross Compiling - Demo with make 3/3 - Run

#### • Run on x86:

```
jensd@deb1:~$ uname -m
x86_64
jensd@deb1:~$ ./strace -V
-bash: ./strace: cannot execute binary file: Exec format error
```

#### Run on ARM:

```
jensd@deb2:~$ uname -m
aarch64
jensd@deb2:~$ ./strace -V
strace -- version 5.17
Copyright (c) 1991-2022 The strace developers <a href="https://strace.io">https://strace.io</a>.
This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
```

