Find Jobs
Hire Freelancers

Write some Software

$30-250 USD

Tamamlandı
İlan edilme: 6 yıldan fazla önce

$30-250 USD

Teslimde ödenir
Your task is to implement a semaphore-based solution to the problem stated below. Consider a system with N blocks of storage, each of which holds one unit of information (e.g. an integer, character, or employee record). Initially, these blocks are empty and are linked onto a list called freelist. Three processes communicate using shared memory in the following manner: Shared Variables: freelist, list-1, list-2: block (where block is some data type to hold items) Using the appropriate libraries, rewrite the pseudo-code as actual Unix/Linux processes, using semaphores to implement the necessary mutual exclusion and synchronization. The solution must be deadlock-free and concurrency should not be unnecessarily restricted. Further, you will have to implement a correct representation of the three lists so that access to them is shared among the processes. Deliverables: You must submit a working solution that compiles without errors on the CSE computers. Further, you must submit a detailed description of the approach you have used to solve the problem. Grading: Your project will be graded on program correctness, particularly whether it is avoiding deadlocks and its ability to maximize concurrency among the three processes. Further, the detailed description of your approach regarding shared list implementation and the synchronization mechanisms used will weigh in the final project grade. PROCESS #1 var b: pointer to type block; while (1) { b:= unlink(freelist); produce_information_in_block(b); link(b, list1); } PROCESS #2 var x,y: pointer to type block; while (1) { x:=unlink(list-1); y:=unlink(freelist); use_block_x_to_produce info_in_y(x, y); link(x, freelist); link(y, list-2); } PROCESS #3 var c: pointer to type block; while(1) { c:=unlink(list-2); consume_information_in_block(c); link(c, freelist); } Using the appropriate libraries, rewrite the pseudo-code as actual Unix/Linux processes, using semaphores to implement the necessary mutual exclusion and synchronization. The solution must be deadlock-free and concurrency should not be unnecessarily restricted. Further, you will have to implement a correct representation of the three lists so that access to them is shared among the processes
Proje No: 15408790

Proje hakkında

7 teklif
Uzaktan proje
Son aktiviteden bu yana geçen zaman 7 yıl önce

Biraz para mı kazanmak istiyorsunuz?

Freelancer'da teklif vermenin faydaları

Bütçenizi ve zaman çerçevenizi belirleyin
Çalışmanız için ödeme alın
Teklifinizin ana hatlarını belirleyin
Kaydolmak ve işlere teklif vermek ücretsizdir
Seçilen:
Kullanıcı Avatarı
I have worked with producer/consumer models in Linux, using C. Relevant Skills and Experience C, Linuxm synchronization, semaphores Proposed Milestones $80 USD - final milestone
$80 USD 1 gün içinde
4,9 (430 değerlendirme)
7,2
7,2
7 freelancer bu proje için ortalama $139 USD teklif veriyor
Kullanıcı Avatarı
please ignore the bid amount we will discuss the price later in the chat after we have discussed the project thoroughly Relevant Skills and Experience: . Proposed Milestones: 190 - . Hi varmaraobujji! Please drop a message to discuss more about the project
$190 USD 2 gün içinde
5,0 (65 değerlendirme)
7,2
7,2
Kullanıcı Avatarı
Hi, i have understood the project. i can easily complete it for you. we can have a chat thanks Relevant Skills and Experience c programming Proposed Milestones $140 USD - all
$140 USD 2 gün içinde
4,9 (389 değerlendirme)
7,3
7,3
Kullanıcı Avatarı
Hi! Dear if you have any work for a programmer to do some applications,then I will do this task.i have a good typing and also work on turbo C++.
$155 USD 2 gün içinde
0,0 (0 değerlendirme)
0,0
0,0

Müşteri hakkında

   UNITED STATES bayrağı
denton, United States
5,0
1
Ödeme yöntemi onaylandı
Eki 16, 2017 tarihinden bu yana üye

Müşteri Doğrulaması

Bu müşterinin diğer işleri

write a code using c programming
$30-250 USD
Teşekkürler! Ücretsiz kredinizi talep etmeniz için size bir bağlantı gönderdik.
E-postanız gönderilirken bir şeyler yanlış gitti. Lütfen tekrar deneyin.
Kayıtlı Kullanıcı İlan Edlien Toplam İş
Freelancer ® is a registered Trademark of Freelancer Technology Pty Limited (ACN 142 189 759)
Copyright © 2024 Freelancer Technology Pty Limited (ACN 142 189 759)
Ön izleme yükleniyor
Coğrafik konum için izin verildi.
Giriş oturumunuzun süresi doldu ve çıkış yaptınız. Lütfen tekrar giriş yapın.