mirror of
				https://github.com/kata-containers/kata-containers.git
				synced 2025-10-21 20:08:54 +00:00 
			
		
		
		
	git-subtree-dir: tools/packaging git-subtree-mainline:f818b46a41git-subtree-split:1f22d72d5dSigned-off-by: Peng Tao <bergwolf@hyper.sh>
		
			
				
	
	
		
			99 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			99 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 894a8ae5524fff4ad9d3551c515788c5650e1fc7 Mon Sep 17 00:00:00 2001
 | |
| From: Yang Zhong <yang.zhong@intel.com>
 | |
| Date: Wed, 28 Mar 2018 20:14:53 +0800
 | |
| Subject: [PATCH 1/2] 9p: removing coroutines of 9p to increase the I/O
 | |
|  performance
 | |
| 
 | |
| This is a quick workaround, need to be fixed.
 | |
| 
 | |
| Signed-off-by: Chao Peng <chao.p.peng@linux.intel.com>
 | |
| ---
 | |
|  hw/9pfs/9p.c   | 12 +++++-------
 | |
|  hw/9pfs/9p.h   |  6 +++---
 | |
|  hw/9pfs/coth.h |  3 +++
 | |
|  3 files changed, 11 insertions(+), 10 deletions(-)
 | |
| 
 | |
| diff --git a/hw/9pfs/9p.c b/hw/9pfs/9p.c
 | |
| index 55821343e5..c5f089860d 100644
 | |
| --- a/hw/9pfs/9p.c
 | |
| +++ b/hw/9pfs/9p.c
 | |
| @@ -690,10 +690,7 @@ static void coroutine_fn pdu_complete(V9fsPDU *pdu, ssize_t len)
 | |
|  out_notify:
 | |
|      pdu->s->transport->push_and_notify(pdu);
 | |
|  
 | |
| -    /* Now wakeup anybody waiting in flush for this request */
 | |
| -    if (!qemu_co_queue_next(&pdu->complete)) {
 | |
| -        pdu_free(pdu);
 | |
| -    }
 | |
| +    pdu_free(pdu);
 | |
|  }
 | |
|  
 | |
|  static mode_t v9mode_to_mode(uint32_t mode, V9fsString *extension)
 | |
| @@ -3525,7 +3522,7 @@ static inline bool is_read_only_op(V9fsPDU *pdu)
 | |
|  
 | |
|  void pdu_submit(V9fsPDU *pdu, P9MsgHeader *hdr)
 | |
|  {
 | |
| -    Coroutine *co;
 | |
| +//    Coroutine *co;
 | |
|      CoroutineEntry *handler;
 | |
|      V9fsState *s = pdu->s;
 | |
|  
 | |
| @@ -3543,8 +3540,9 @@ void pdu_submit(V9fsPDU *pdu, P9MsgHeader *hdr)
 | |
|      }
 | |
|  
 | |
|      qemu_co_queue_init(&pdu->complete);
 | |
| -    co = qemu_coroutine_create(handler, pdu);
 | |
| -    qemu_coroutine_enter(co);
 | |
| +    handler(pdu);
 | |
| +    //co = qemu_coroutine_create(handler, pdu);
 | |
| +    //qemu_coroutine_enter(co);
 | |
|  }
 | |
|  
 | |
|  /* Returns 0 on success, 1 on failure. */
 | |
| diff --git a/hw/9pfs/9p.h b/hw/9pfs/9p.h
 | |
| index 8883761b2c..24aeba03f7 100644
 | |
| --- a/hw/9pfs/9p.h
 | |
| +++ b/hw/9pfs/9p.h
 | |
| @@ -320,21 +320,21 @@ extern int total_open_fd;
 | |
|  static inline void v9fs_path_write_lock(V9fsState *s)
 | |
|  {
 | |
|      if (s->ctx.export_flags & V9FS_PATHNAME_FSCONTEXT) {
 | |
| -        qemu_co_rwlock_wrlock(&s->rename_lock);
 | |
| +    //    qemu_co_rwlock_wrlock(&s->rename_lock);
 | |
|      }
 | |
|  }
 | |
|  
 | |
|  static inline void v9fs_path_read_lock(V9fsState *s)
 | |
|  {
 | |
|      if (s->ctx.export_flags & V9FS_PATHNAME_FSCONTEXT) {
 | |
| -        qemu_co_rwlock_rdlock(&s->rename_lock);
 | |
| +     //   qemu_co_rwlock_rdlock(&s->rename_lock);
 | |
|      }
 | |
|  }
 | |
|  
 | |
|  static inline void v9fs_path_unlock(V9fsState *s)
 | |
|  {
 | |
|      if (s->ctx.export_flags & V9FS_PATHNAME_FSCONTEXT) {
 | |
| -        qemu_co_rwlock_unlock(&s->rename_lock);
 | |
| +     //   qemu_co_rwlock_unlock(&s->rename_lock);
 | |
|      }
 | |
|  }
 | |
|  
 | |
| diff --git a/hw/9pfs/coth.h b/hw/9pfs/coth.h
 | |
| index 19e4d9287e..728a25865d 100644
 | |
| --- a/hw/9pfs/coth.h
 | |
| +++ b/hw/9pfs/coth.h
 | |
| @@ -47,6 +47,9 @@
 | |
|          qemu_coroutine_yield();                                         \
 | |
|      } while (0)
 | |
|  
 | |
| +#undef v9fs_co_run_in_worker
 | |
| +#define v9fs_co_run_in_worker(code_block) do {code_block} while(0);
 | |
| +
 | |
|  void co_run_in_worker_bh(void *);
 | |
|  int coroutine_fn v9fs_co_readlink(V9fsPDU *, V9fsPath *, V9fsString *);
 | |
|  int coroutine_fn v9fs_co_readdir(V9fsPDU *, V9fsFidState *, struct dirent **);
 | |
| -- 
 | |
| 2.17.2
 | |
| 
 |