Skip to content

Commit

Permalink
Merge pull request #20 from below/Chapter_13
Browse files Browse the repository at this point in the history
Chapter 13
  • Loading branch information
below authored Aug 2, 2020
2 parents 5e644d4 + f3a6fc3 commit e268e26
Show file tree
Hide file tree
Showing 3 changed files with 20 additions and 37 deletions.
31 changes: 0 additions & 31 deletions Chapter 13/debug.s

This file was deleted.

6 changes: 3 additions & 3 deletions Chapter 13/matrixmultneon.s
Original file line number Diff line number Diff line change
Expand Up @@ -34,9 +34,9 @@ main:
LDR D5, [X0]

.macro mulcol ccol bcol
MUL \ccol\().4H, V0.4H, \bcol\().4H
MLA \ccol\().4H, V1.4H, \bcol\().4H
MLA \ccol\().4H, V2.4H, \bcol\().4H
MUL.4H \ccol\(), V0, \bcol\()[0]
MLA.4H \ccol\(), V1, \bcol\()[1]
MLA.4H \ccol\(), V2, \bcol\()[2]
.endm

mulcol V6, V3 // process first column
Expand Down
20 changes: 17 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,13 @@ In this repository, I will code along with the book [Programming with 64-Bit ARM

## Latest News

Pop the Champagne! 🍾 All the code is running!

Once you found the bug, you feel stupid for not noticing it before. Only after some debugging I realized that Darwin has a different value for `AT_FDCWD`. This means: Chapter 7 is ready!

Chapter 13 stil has an open issue, though.
And after some disassembly and reading [Documentation](https://community.arm.com/developer/tools-software/oss-platforms/b/android-blog/posts/arm-neon-programming-quick-reference), Chapter 13 is ready as well.

I got a mention in Stephen Smith's [blog](https://smist08.wordpress.com/2020/07/31/is-apple-silicon-really-arm/)!
Last but not least, I got a mention in Stephen Smith's [blog](https://smist08.wordpress.com/2020/07/31/is-apple-silicon-really-arm/)!

### Prerequisites

Expand Down Expand Up @@ -283,7 +285,19 @@ Like in Chapter 11, all the chages have been introduced already. Nothing new her

## Chapter 13

This chapter is still in the works; it compiles, but the output is wrong. There is one [issue](https://github.com/below/HelloSilicon/issues/15) I'd like to fix
Once again, the Clang assembler seems to want a slightly different syntax: Where gcc accepts

```
MUL V6.4H, V0.4H, V3.4H[0]
```

the Clang assembler expects

```
MUL.4H V6, V0, V3[0]
```

All other changes to the code should be trivial at this point.

## Chapter 14

Expand Down

0 comments on commit e268e26

Please sign in to comment.