Lines Matching refs:jr

78 	struct jobring *jr = &jr0[sec_idx];  in jr_initregs()  local
79 phys_addr_t ip_base = virt_to_phys((void *)jr->input_ring); in jr_initregs()
80 phys_addr_t op_base = virt_to_phys((void *)jr->output_ring); in jr_initregs()
97 if (!jr->irq) in jr_initregs()
103 struct jobring *jr = &jr0[sec_idx]; in jr_init() local
105 memset(jr, 0, sizeof(struct jobring)); in jr_init()
107 jr->jq_id = DEFAULT_JR_ID; in jr_init()
108 jr->irq = DEFAULT_IRQ; in jr_init()
111 jr->liodn = DEFAULT_JR_LIODN; in jr_init()
113 jr->size = JR_SIZE; in jr_init()
114 jr->input_ring = (dma_addr_t *)memalign(ARCH_DMA_MINALIGN, in jr_init()
116 if (!jr->input_ring) in jr_init()
119 jr->op_size = roundup(JR_SIZE * sizeof(struct op_ring), in jr_init()
121 jr->output_ring = in jr_init()
122 (struct op_ring *)memalign(ARCH_DMA_MINALIGN, jr->op_size); in jr_init()
123 if (!jr->output_ring) in jr_init()
126 memset(jr->input_ring, 0, JR_SIZE * sizeof(dma_addr_t)); in jr_init()
127 memset(jr->output_ring, 0, jr->op_size); in jr_init()
138 struct jobring *jr = &jr0[sec_idx]; in jr_sw_cleanup() local
140 jr->head = 0; in jr_sw_cleanup()
141 jr->tail = 0; in jr_sw_cleanup()
142 jr->read_idx = 0; in jr_sw_cleanup()
143 jr->write_idx = 0; in jr_sw_cleanup()
144 memset(jr->info, 0, sizeof(jr->info)); in jr_sw_cleanup()
145 memset(jr->input_ring, 0, jr->size * sizeof(dma_addr_t)); in jr_sw_cleanup()
146 memset(jr->output_ring, 0, jr->size * sizeof(struct op_ring)); in jr_sw_cleanup()
186 struct jobring *jr = &jr0[sec_idx]; in jr_enqueue() local
187 int head = jr->head; in jr_enqueue()
207 jr->info[head].desc_phys_addr = desc_phys_addr; in jr_enqueue()
208 jr->info[head].callback = (void *)callback; in jr_enqueue()
209 jr->info[head].arg = arg; in jr_enqueue()
210 jr->info[head].op_done = 0; in jr_enqueue()
212 unsigned long start = (unsigned long)&jr->info[head] & in jr_enqueue()
214 unsigned long end = ALIGN((unsigned long)&jr->info[head] + in jr_enqueue()
224 addr_lo = (uint32_t *)(&jr->input_ring[head]); in jr_enqueue()
225 addr_hi = (uint32_t *)(&jr->input_ring[head]) + 1; in jr_enqueue()
227 addr_hi = (uint32_t *)(&jr->input_ring[head]); in jr_enqueue()
228 addr_lo = (uint32_t *)(&jr->input_ring[head]) + 1; in jr_enqueue()
236 sec_out32(&jr->input_ring[head], desc_phys_addr); in jr_enqueue()
239 start = (unsigned long)&jr->input_ring[head] & ~(ARCH_DMA_MINALIGN - 1); in jr_enqueue()
240 end = ALIGN((unsigned long)&jr->input_ring[head] + in jr_enqueue()
244 jr->head = (head + 1) & (jr->size - 1); in jr_enqueue()
247 start = (unsigned long)jr->output_ring & in jr_enqueue()
249 end = ALIGN((unsigned long)jr->output_ring + jr->op_size, in jr_enqueue()
261 struct jobring *jr = &jr0[sec_idx]; in jr_dequeue() local
262 int head = jr->head; in jr_dequeue()
263 int tail = jr->tail; in jr_dequeue()
273 while (sec_in32(&regs->orsf) && CIRC_CNT(jr->head, jr->tail, in jr_dequeue()
274 jr->size)) { in jr_dequeue()
285 addr_lo = (uint32_t *)(&jr->output_ring[jr->tail].desc); in jr_dequeue()
286 addr_hi = (uint32_t *)(&jr->output_ring[jr->tail].desc) + 1; in jr_dequeue()
288 addr_hi = (uint32_t *)(&jr->output_ring[jr->tail].desc); in jr_dequeue()
289 addr_lo = (uint32_t *)(&jr->output_ring[jr->tail].desc) + 1; in jr_dequeue()
297 addr = (uint32_t *)&jr->output_ring[jr->tail].desc; in jr_dequeue()
301 uint32_t status = sec_in32(&jr->output_ring[jr->tail].status); in jr_dequeue()
303 for (i = 0; CIRC_CNT(head, tail + i, jr->size) >= 1; i++) { in jr_dequeue()
304 idx = (tail + i) & (jr->size - 1); in jr_dequeue()
305 if (op_desc == jr->info[idx].desc_phys_addr) { in jr_dequeue()
315 jr->info[idx].op_done = 1; in jr_dequeue()
316 callback = (void *)jr->info[idx].callback; in jr_dequeue()
317 arg = jr->info[idx].arg; in jr_dequeue()
325 tail = (tail + 1) & (jr->size - 1); in jr_dequeue()
326 } while (jr->info[tail].op_done); in jr_dequeue()
328 jr->tail = tail; in jr_dequeue()
329 jr->read_idx = (jr->read_idx + 1) & (jr->size - 1); in jr_dequeue()
332 jr->info[idx].op_done = 0; in jr_dequeue()