24
CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Embed Size (px)

Citation preview

Page 1: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

CSC469 Tutorial2Inline assembly, cycle counters,

Gnuplot, LaTeX

Bogdan Simion

Page 2: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Today’s tutorial

• Three things you’ll need for the first assignment– Inline assembly for cycle counters (get data)– Using Gnuplot (plot data)– LaTeX (report)

Page 3: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Measuring cycles

• Idea:– Get current value of cycle counter– Compute something– Get new value of cycle counter– Get elapsed time (in cycles) by subtraction

Page 4: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Measurement Codestatic u_int64_t start = 0;void access_counter(unsigned* hi, unsigned* low);

void start_counter(){ unsigned hi, lo; access_counter(&hi, &lo); start = ((u_int64_t)hi << 32) | lo;}

u_int64_t get_counter(){ unsigned ncyc_hi, ncyc_lo; access_counter(&ncyc_hi, &ncyc_lo); return (((u_int64_t)ncyc_hi << 32) | ncyc_lo) - start;}

We need inline assembly to implement access_counter.

Page 5: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Inline Assembly

• Needed for accessing cycle counters• Key point: there is no magic• asm() directive tells GCC “emit this assembly

code here”• You give it a template– Same idea as printf() format strings

Page 6: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Accessing the Cycle Countervoid access_counter(unsigned *hi, unsigned *lo){ asm volatile ("rdtsc; movl %%edx, %0; movl %%eax, %1" /* Format string */ : "=r" (*hi), "=r" (*lo) /* Output list */ : /* No inputs */ : "%edx", "%eax"); /* Clobber list */}

• Code only works on an x86 machine compiling with GCC• Emits rdtsc and two movl instructions• GCC automatically adds instructions to move symbolic register

value %0 into *hi and %1 into *lo.• GCC also adds instructions to save and restore the registers that

rdtsc clobbers.• Careful with newer processors and out-of-order execution: see

cpuid, rdtscp instructions.

Page 7: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

For more information

• More information about inline assembly available online:

http://www.cs.virginia.edu/~clc5q/gcc-inline-asm.pdfhttp://www.ibiblio.org/gferg/ldp/GCC-Inline-Assembly-HOWTO.html#ss5.3

Page 8: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Timing with Cycle Counter• Need to convert cycles into time

– determine clock rate of processor– count number of cycles required for some fixed number of seconds– Naïve version:

• This is a bit too simple– Assumes sleep() actually sleeps for 10 seconds– May be less (if interrupted) or more (if heavy load)– See “mhz: Anatomy of a micro-benchmark”, Staelin & McVoy,

Usenix Technical Conference 1998

double MHz;int sleep_time = 10;start_counter();sleep(sleep_time);MHz = get_counter() / (sleep_time * 1e6);

Page 9: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Gnuplot

• A graphing tool• Advantages– Scriptable– Makes pretty pictures– Easy to learn by example– Good documentation:• http://www.gnuplot.info/

Page 10: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Using Gnuplot

Page 11: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Gnuplot example#!/bin/shgnuplot << ---EOF---set title "Activity periods, load = 2"set xlabel "Time (ms)"set nokeyset noyticsset term postscript eps 10set size 0.45,0.35set output "bars.eps"set object 1 rect from 0, 1 to 8.76, 2 fs emptyset object 2 rect from 8.76, 1 to 11, 2 fc rgb "black" fs solidset object 3 rect from 11, 1 to 13, 2 fs emptyset object 4 rect from 13, 1 to 14, 2 fc rgb "black" fs solidset object 5 rect from 14, 1 to 19, 2 fs emptyset object 6 rect from 19, 1 to 31, 2 fc rgb "black" fs solidset object 7 rect from 31, 1 to 33, 2 fs emptyset object 8 rect from 33, 1 to 34, 2 fc rgb "black" fs solidplot [0:40] [0:3] 0---EOF---

Page 12: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Title, Key, etc.

• title - the main title• xlabel - the label of the x-axis• nokey - no legend• noytics - don’t print numbers on the y-axis,

since we aren’t using it

set title “Activity periods, load = 2”set xlabel “Time (ms)”set nokeyset noytics

Page 13: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Output

• Produce a postscript file called “bars.eps”• size - width and height of chart• More options: landscape/portrait, color, font, etc.

set term postscript eps 10set size 0.45, 0.35set output “bars.eps”

Page 14: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Drawing Rectangles

• Solid rectangle, <fill> is: fc rgb “black” fs solid

• Empty rectangle, <fill> is: fs empty

set object N rect from x0, y0 to x1, y1 <fill>

Page 15: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

So …

• Write your program with cycle counters• Print active and inactive times to a log file• Write a script to read your logs• Scale the time durations• Output a sequence of rectangles• Write the rectangles into boilerplate• Gnuplot script

Page 16: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Gnuplot examplehttp://www.cdf.toronto.edu/~csc469h/winter/tutorials/t2/t2.tgz

• A contrived example of automating running an experiment, parsing the output, and generating a plot.

• See README.txt for details.

Page 17: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX• A markup language, like HTML

• Easiest to learn by example

• There’s lots of online documentation:http://www.ctan.org/

http://tug.ctan.org/info/lshort/english/lshort.pdf

http://www.cdf.toronto.edu/~csc469h/winter/tutorials/t2/latex_template.tgz

Page 18: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX – General Structure

\documentclass[options]{class}\usepackage[pkgs]definitions\begin{document}text\end{document}

Page 19: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX - Figure

\begin{figure}\centering command optional required\includegraphics[scale=1.25]{random.eps}\caption{Random periods (red).}\label{fig:random}\end{figure}

Page 20: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX - Compiling

• Commonly:$ latex report.tex$ latex report.tex$ dvips -o report.ps report.dvi$ ps2pdf report.ps

TWICE !

Page 21: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX: Compiling• BibTex for bibliography:

$ latex report.tex$ bibtex report$ latex report.tex$ latex report.tex

1. LaTeX: finds all bib references (\cite), figure entries, sections, etc. => aux file2. BibTeX: creates an initial set of text for the bib entries => bbl3. LaTeX: populates the document with bib refs + update aux4. LaTeX: knows what the correct labels are now and includes them in the final document.

Page 22: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

LaTeX: Compiling

• OR directly using pdflatex:

$ pdflatex report.tex$ bibtex report$ pdflatex report.tex

Page 23: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

GUI Alternatives

• LyX (Cross-platform):– http://www.lyx.org/

• TexnicCenter (Windows)– http://www.texniccenter.org/– needs MikTex or TexLive distributions of Latex:• http://miktex.org/• http://www.tug.org/texlive/

Page 24: CSC469 Tutorial2 Inline assembly, cycle counters, Gnuplot, LaTeX Bogdan Simion

Questions?