Starting from:

$30

CS361-Homework 1 The ELF Format Solved

git, personal and public repositories
The primary objective of this homework is to get you familiarized with the ELF file format and the process of linking executables. The secondary goal of this assignment is to give you some experience using the Gradescope autograder and turnin system.

We covered using git in the first lab, but if you’re still not that familiar with it, this assignment is a second chance to get up to speed. Remember: git gives you warnings and errors for good reason, if it complains at the command line when you run a command, don’t just assume it’s completed correctly!

Setting git to the simple push is a helpful quality of life improvement, this is recommended but not required:

git config --global push.default simple

You should also tell git who you are, otherwise it will complain that you are some anonymous coder. Do this, but use your own name and email. Note that if you do not change your username and email properly, you won’t get credit.

$ git config --global user.name "Copypasting Carol"

$ git config --global user.email copypasta@domain.invalid

The skeleton code for this assignment is available at this link. You must use GitHub classroom to manage your code (the repository created through that link). You will need to submit the code via Gradescope.

         CS 361 Summer 2020                             Home       Schedule                          Homeworks

Now that you have the skeleton code, you can start coding. You should commit early and often, and push to your remote repository whenever is convenient to back up your work!

Programming environment
This assignment was created in a Debian-derived Linux environment. This assignment is simple enough that any Linux environment with an up to date gcc will be sufficient, including systems1.cs.uic.edu. The autograder is written to the correct specification for the autograding environment. Feel free to complete this on a lab machine, a local Linux VM, or elsewhere.

The Programming Part!

This part will give you a quick introduction to using readelf to better understand the linking process.

In this assignment, you must fill hw1.c and hw1.h with code which will:

1.  cause your UIC netID (and nothing else) to be printed on the first line of output when the program is run.

2.  cause gcc -Wall hw1.c to issue zero warnings and zero errors.

3.  cause the output of readelf -s hw1.o to have an identical number of symbol table entries as shown below (25 entries).

4.  cause the output of readelf -s hw1.o to have identical values in the bold sections of the output below:

You can perform the symbol table check by running make test within the hw1 directory. A full credit solution will have output that looks like:

Symbol table ‘.symtab’ contains 25 entries:

Num: Value            Size Type     Bind   Vis     Ndx Name

0:   0000000000000000 0    NOTYPE   LOCAL  DEFAULT UND

1:   0000000000000000 0    FILE     LOCAL  DEFAULT ABS hw1.c

2:   0000000000000000 0    SECTION  LOCAL  DEFAULT 1

3:   0000000000000000 0    SECTION  LOCAL  DEFAULT 3

4:   0000000000000000 0    SECTION  LOCAL  DEFAULT 4

5:   0000000000000000 11   FUNC     LOCAL  DEFAULT 1   I_have_written

 6:   0000000000000000 12   OBJECT   LOCAL  DEFAULT 3   the_code

7: 000000000000000b 26 FUNC LOCAL DEFAULT 1 that you needed 7:   000000000000000b 26   FUNC     LOCAL  DEFAULT 1   that_you_needed

8:   0000000000000018 4    OBJECT   LOCAL  DEFAULT 3   to_compile.2213

                    CS 361 Summer 2020                             Home       Schedule                          Homeworks

9:   0000000000000000 0    SECTION  LOCAL  DEFAULT 5

10:  0000000000000058 78   FUNC     LOCAL  DEFAULT 1   and_which

11:  000000000000001c 4    OBJECT   LOCAL  DEFAULT 3   

has_a_bunch_of.2220

12:  0000000000000020 4    OBJECT   LOCAL  DEFAULT 3   ridiculous.2221 13:  0000000000000000 8    OBJECT   LOCAL  DEFAULT 4   symbols.2222

14:  0000000000000000 0    SECTION  LOCAL  DEFAULT 7

15:  0000000000000000 0    SECTION  LOCAL  DEFAULT 8

16:  0000000000000000 0    SECTION  LOCAL  DEFAULT 6

17:  0000000000000000 7    FUNC     GLOBAL DEFAULT 1   sides_and

18:  0000000000000025 61   FUNC     GLOBAL DEFAULT 1   main

19:  0000000000000000 0    NOTYPE   GLOBAL DEFAULT UND 

__GLOBAL__OFFSET__TABLE__

20:  0000000000000000 0    NOTYPE   GLOBAL DEFAULT UND printf

21:  00000000000000a6 47   FUNC     GLOBAL DEFAULT 1   Forgive_me

22:  0000000000000004 4    OBJECT   GLOBAL DEFAULT COM they_are_arbitrary

23:  0000000000000010 8    OBJECT   GLOBAL DEFAULT 3   so_random

24:  00000000000000d5 41   FUNC     GLOBAL DEFAULT 1   and_so_varied

Hints:

  Are you seeing puts instead of printf? Check the man pages for what the difference is, and make sure that the compiler can’t optimize away your call to printf. Remember, requirement #1 only mentions the first line of output.

  The four digit numbers do not need to made identical, but you do need to make them show up. Keep experimenting with different variable types until you find how to create variables with periods and numbers on them.

  Function lengths are very difficult to reproduce - note that for every FUNC, you do not have to duplicate the length (the length is the number of bytes of assembly code chosen by the compiler to execute the body of each function).

More products