

# CS & IT ENGINEERING

COMPUTER ORGANIZATION  
AND ARCHITECTURE



Disk

Lecture No.- 1

By- Vishvadeep Gothi sir



# Recap of Previous Lecture



**Topic**

Array Access with Cache

**Topic**

Multilevel Cache

# Topics to be Covered

P  
W



Topic

Magnetic Disk

#Q. In the three-level memory hierarchy shown in the following table,  $p_i$  denotes the probability that an access request will refer to  $M_i$ .

| Hierarchy Level ( $M_i$ ) | Access Time ( $t_i$ ) | Probability of Access ( $p_i$ ) | Page Transfer Time ( $T_i$ ) |
|---------------------------|-----------------------|---------------------------------|------------------------------|
| $M_1$                     | $10^{-6}$             | 0.99000                         | 0.001 sec                    |
| $M_2$                     | $10^{-5}$             | 0.00998                         | 0.1 sec                      |
| $M_3$                     | $10^{-4}$             | 0.00002                         | ---                          |

If a miss occurs at level  $M_i$ , a page transfer occurs from  $M_{i+1}$  to  $M_i$  and the average time required for such a page swap is  $T_i$ .

Calculate the average time  $t_A$  required for a processor to read one word from this memory system.

$$\begin{aligned}
 &= 0.99 * 10^{-6} + \\
 &0.00988 * (10^{-6} + 10^{-5} + 0.001) + \\
 &0.00002 * (10^{-6} + 10^{-5} + 10^{-4} + 0.1 + 0.001)
 \end{aligned}$$

$$\begin{aligned}
 &= 10^{-6} \left[ 0.99 + 0.00988 * (1 + 10 + 1000) \right. \\
 &\quad \left. + 0.00002 * (1 + 10 + 100 + 10^5 + 10^3) \right] \text{ sec} \\
 &= 10^{-6} * (13.0009) \text{ sec} \\
 &= \underline{\underline{13.0009 \text{ usec}}}
 \end{aligned}$$

4.72 Ans.

#Q. The read access times and the hit ratios for different caches in a memory hierarchy are as given below:

| Cache    | Read access time (in nanoseconds) | Hit Ratio |
|----------|-----------------------------------|-----------|
| I-cache  | 2                                 | 0.8       |
| D-cache  | 2                                 | 0.9       |
| L2-cache | 8                                 | 0.9       |

The read access time of main memory is 90nanoseconds. Assume that the caches use the referred-word-first read policy and the write-back policy. Assume that all the caches are direct mapped caches. Assume that the dirty bit is always 0 for all the blocks in the caches. In execution of a program, 60% of memory reads are for instruction fetch and 40% are for memory operand fetch. The average read access time in nanoseconds (up to 2 decimal places) is \_\_\_\_\_?

#Q. Assume a two-level inclusive cache hierarchy, L1 and L2, where L2 is the larger of the two. Consider the following statements.

S1: Read misses in a write through L1 cache do not result in writebacks of dirty lines to the L2  $\Rightarrow$  True

S2: Write allocate policy must be used in conjunction with write through caches and no-write allocate policy is used with writeback caches.  $\Rightarrow$  False

Which of the following statements is correct?

- (A) ✓ S1 is true and S2 is false
- (B) S1 is false and S2 is true
- (C) S1 is true and S2 is true
- (D) S1 is false and S2 is false

#Q. A computer system has an L1 cache, an L2 cache, and a main memory unit connected as shown below. The block size in L1 cache is 4 words. The block size in L2 cache is 16 words. The memory access times are 2 nanoseconds, 20 nanoseconds and 200 nanoseconds for L1 cache, L2 cache and the main memory unit respectively.



When there is a miss in L1 cache and a hit in L2 cache, a block is transferred from L2 cache to L1 cache. What is the time taken for this transfer?

A

2 nanoseconds

B

20 nanoseconds

C

✓22 nanoseconds

D

88 nanoseconds

read block from L2  $\Rightarrow$  20ns

write ————— in L1  $\Rightarrow$  2  
22 ns

#Q. A computer system has an L1 cache, an L2 cache, and a main memory unit connected as shown below. The block size in L1 cache is 4 words. The block size in L2 cache is 16 words. The memory access times are 2 nanoseconds, 20 nanoseconds and 200 nanoseconds for L1 cache, L2 cache and the main memory unit respectively.



When there is a miss in both L1 cache and L2 cache, first a block is transferred from main memory to L2 cache, and then a block is transferred from L2 cache to L1 cache. What is the total time taken for these transfers?

A

222 nanoseconds

C

✓ 902 nanoseconds

B

888 nanoseconds

D

968 nanoseconds

$$4 * \left[ 200 + 20 \right]$$
$$\begin{array}{r} + 22 \\ \hline 902 \end{array}$$

**[Question]**

#Q. Consider a computer with the following features:

- 90% of all memory accesses are found in the cache (hit ratio = 0.9)
- The block size is 2 words and the whole block is read on any miss
- The CPU sends references to the cache at the rate of  $10^7$  words per second
- 25% of the above references are writes (writes = 25%, reads = 75%)
- The bus can support  $10^7$  words per second, read or writes (total bus bandwidth =  $10^7$ )
- The bus reads or writes a single word at a time
- Assume at any one time, 30% of the block frames in the cache have been modified

Calculate the percentage of the bus bandwidth used on the average when:

1. Cache is write through with no write allocate =  $\frac{0.4 * 10^7}{10^7} = 0.4 = 40\%$
2. Cache is write back with write allocate

$$\hookrightarrow \frac{0.26 * 10^7}{10^7} = 0.26 = 26\%$$

## for write through cache

| Case       | Bus used                                                                                                 |
|------------|----------------------------------------------------------------------------------------------------------|
| Read hit   | 0                                                                                                        |
| Read miss  | $10^7 * 0.75 * 0.1 * \frac{2}{\pi}$ block from mm to cm                                                  |
| write hit  | $10^7 * 0.25 * 0.9 * \frac{1}{\pi}$ write word in mm                                                     |
| write miss | $10^7 * 0.25 * 0.1 * \frac{1}{\pi}$                                                                      |
| Total      | $10^7 * (0.15 + 0.225 + 0.25)$<br>$= \frac{10^7}{\pi} * 0.4$ no. of words transfers through bus per sec. |

for write back cache

| Case       | Bus used                                    |
|------------|---------------------------------------------|
| read hit   | $10^7 * 0.75 * 0.1 * [2 + 0.3 * 2]$         |
| Read miss  | 0                                           |
| write hit  | $10^7 * 0.25 * 0.1 * [2 + 0.3 * 2]$         |
| write miss |                                             |
| Total      | $10^7 * (0.195 + 0.065)$<br>$= 0.26 * 10^7$ |

block from mm-to  
cache

write back



## Topic : Magnetic Disk





## Topic : Magnetic Disk





## Topic : Magnetic Disk





sector is the smallest unit of the disk which can be read or written at once.

Each sector gets an address in disk



## Topic : Magnetic Disk

Number of ~~surfaces~~<sup>sectors</sup> in disk:

$$= 2 * \text{no. of platters} * \text{no. of tracks per surface} * \text{no. of sectors per track}$$

$$= 2 * 3 * 8 * 8$$

$$= 384$$



## Topic : Sector Capacity

Disk

P  
W

Constant sector capacity

or

Variable storage density

or

Constant angular velocity

variable sector capacity

or

Constant storage density

or

constant linear velocity

#Q. Consider a disk with 32 platters each with 2 recording surfaces. There are 128 tracks per surface and 32 sectors per track. Each sector has equal capacity of 1KBytes.

Calculate:

1. Number of surfaces in disk:  $2 * 32 = 64$
2. Number of tracks on disk:  $64 * 128 = 2^{13}$
3. Number of sectors in disk:  $2^{13} * 32 = 2^{18}$
4. Number of bytes on disk:  $2^{18} * 1KB = 256MB$
5. Number of bits for disk addressing: 18 bits



# Topic : Magnetic Disk



Disk access time :-

$$= \text{seek time} + \text{rotational delay or latency} + \text{1 sector transfer time} + \text{additional delay}$$

Note:-

In one rotation of disk, one track can be transferred





## Topic : Disk Access Time

Seek Time: Time required to position the arm over the desired track

Rotational Latency: time required to rotate desired sector under R/W head

Transfer Time: Time required to read or write 1 sector

$$\text{avg. rotational latency} = \frac{1 \text{ rotation time}}{2}$$

$$1 \text{ sector transfer time} = \frac{1 \text{ rotation time}}{\text{no. of sectors per track}}$$

Ex:-

$$1 \text{ rotation time} = 20 \text{ msec}$$

$$\text{no. of sectors per track} = 10$$



Target sector  $\Rightarrow 4^{\text{th}}$  sector

$\downarrow$   
no. of sectors to be rotated = 3

$$\begin{aligned} \text{rotational latency} &= 3 * 2 \text{ ns} \\ &= 6 \text{ ns} \end{aligned}$$

Ques)

$$\text{current position} = 6$$

$$\text{target sector} = 3$$

$$\text{rotational latency} = 7 * 2 = 14 \text{ ms}$$

$\downarrow$   
7 sectors to rotate

Avg. seek time :-

50 tracks

time needed to move arm to next adjacent track = 1 ms

avg. seek time = — ?



Speed to time :-

10000 rotations per minute (RPM)

for 10000 rotations, time = 1 min = 60 sec =  $60 * 1000$  ms

$$\text{for } \frac{1}{10000} \text{ rotation} = \frac{60000 \text{ ms}}{10000}$$
$$= 6 \text{ ms}$$

#Q. Consider a disk with 16 platters, 2 surfaces per platter, 2K tracks per surface, 4K sectors per track and 4096 Bytes per sector. Disk rotates with 6000 rpm. Seek time is 5ms. Find disk access time?



$$1 \text{ rotation time} = 10 \text{ ms}$$

$$\begin{aligned}\text{Disk access time} &= 5 \text{ ms} + \frac{10 \text{ ms}}{2} + \frac{10 \text{ ms}}{4 \text{ K}} \\ &= 10.0025 \text{ ms}\end{aligned}$$



## 2 mins Summary



Topic

Magnetic Disk



# Happy Learning

## THANK - YOU