Up | Home

Challenge 9

Table of Contents

1. Original assembly

Original challenge link: Click me.

Even the author says that this challenge is quite easy, so I won’t make any assembly notes for this one.

This challenge only included the used labels, so I only had to make some minor changes to fit the nasm syntax.

.LC0:
    .string "error!"
func:
    sub   rsp, 8
    movzx eax, BYTE [rdi]
    cmp   al, 89
    je    .L3
    jle   .L21
    cmp   al, 110
    je    .L6
    cmp   al, 121
    jne   .L2
.L3:
    mov   eax, 1
    add   rsp, 8
    ret
.L21:
    cmp   al, 78
    je    .L6
.L2:
    mov   edi, .LC0
    call  puts
    xor   edi, edi
    call  exit
.L6:
    xor   eax, eax
    add   rsp, 8
    ret

2. C translation

Literal translation preserving the branching.

int func(char* str) {
    if (*str == 'Y') {
        /* .L3 */
        return 1;
    } else if (*str < 'Y') {
        /* .L21 */
        if (*str == 'N') {
            /* .L6 */
            return 0;
        }
    } else if (*str == 'n') {
        /* .L6 */
        return 0;
    } else if (*str != 'y') {
        /* .L2 */
        puts("error!");
        exit(0);
    } else {
        /* .L3 */
        return 1;
    }
}

Simplified into this.

bool func(char* str) {
    if (*str == 'Y' || *str == 'y')
        return true;

    if (*str == 'N' || *str == 'n')
        return false;

    puts("error!");
    exit(0);
}