ICS 312 TA Homepage Fall 2009

General Information

TA:Jade Cheng  成玉  (yucheng@hawaii.edu)
Instructor:David Pager (pager@hawaii.edu)
Course:Machine-Level and Systems Programming
TA Office:POST Building Room 303-3 (cubicle 3)
TA Hours:Tuesday 11:00 to 12:00
Thursday 11:00 to 12:00

Course Requirements

TBD

Homework Assignments

If you do not complete homework assignments sufficently, you would automatically fail the course. Otherwise, homework does not affect your grades. Homework submissions will be recorded and posted on this site using the student codes provided by the TA.

Please submit your homework assignments by 11:59 pm on the posted due date. Homework received on time will receive 10 points. One point will be deducted for late submissions. After one week homework will not be accepted.

To facilitate the grading process, please try to follow the following guidelines when submitting assignments.

  1. Email submissions

    Assignments should be submitted via email using your UH UNIX email account. The TA will not accept any other form of submissions.

  2. “To” field of email

    Assignments should be submitted to yucheng@hawaii.edu. Please do not send the assignments to the professor.

  3. “Cc” field of e-mail

    Please cc the email to youself. That way, if the TA doesn’t get your email for some reason, you have proof that it was sent.

  4. Subject of email

    Please use the following pattern for the subject of your email.

    [312] homework number

    For example: [312] homework 1

  5. Body of email

    Please copy and paste the contents of the homework in the email body. That way, the TA will receive your work even if the attachment is rejected.

  6. Attachments

    Plain text files are preferred. PDF, JPG, and PNG files are also accepted. Please do not send Microsoft Office documents.

  7. Multiple submissions

    You may submit an assignment more than one time. Only the most recent assignment submitted will be evaluated.

Grades

The grades for homework assignments, programming projects, in-class quizzes, and the exams will be posted using the student codes provided by the TA. If you lose or forget your code, please contact the TA.

Click your student ID to view your grades.

Homework and Quiz Solutions

The solutions of some of the homework assignments and the in-class quizzes will be posted in this section. Since late submmisions are allowed, the solutions will not be available until a couple of weeks after the due date.

hw-11-1-code.asm

;; program5-1 -- This program calls a subroutine to return the larger digit of
;; two.  The subroutine employ a call by value with the subroutine fixing up
;; the stack
        .model small
        .stack 100

        .data
prompt1 db          0dh, 0ah, 'Please enter a digit: $'
prompt2 db          0dh, 0ah, 'The larger of the two digits is: $'

        .code
main1   proc
        mov         ax, @data
        mov         ds, ax

        lea         dx, prompt1             ; prompt the first user input num.
        mov         ah, 9h
        int         21h
        mov         ah, 1h
        int         21h
        cwd
        push        ax                      ; push the first num onto the stack.
        lea         dx, prompt1             ; prompt the second user input num.
        mov         ah, 9h
        int         21h
        mov         ah, 1h
        int         21h
        cwd
        push        ax                      ; push the second num onto the stack.
        lea         dx, prompt2             ; print out result message.
        mov         ah, 9h
        int         21h
        call        choose1                 ; call subroutine.
        mov         dl, al                  ; print out al, which contains the
        mov         ah, 2h                  ; return value.
        int         21h

        mov         al, 0                   ; return code of 0
        mov         ah, 4ch                 ; function code for exit to os
        int         21h
main1   endp

choose1 proc
        push        bp                      ; save bp
        mov         bp, sp                  ; let bp points to the stack top
        push        bx                      ; save bx
        mov         bx, [bp+6]              ; move X to bx
        cmp         bx, [bp+4]              ; compare X with Y
        jg          Xlarger                 ; if X is larger, set ax = X.
        mov         ax, [bp+4]              ; otherwise set ax = Y.
        jmp         done
Xlarger:
        mov         ax, bx
done:
        pop         bx                      ; restore bx
        pop         bp                      ; restore bp
        ret         4                       ; pop IP and add 4 bytes to sp.
choose1 endp
end     main1

Links

Valid HTML 4.01 Valid CSS