Added initialization of SharedStruct

This commit is contained in:
TriantaTV 2022-10-15 16:06:55 -05:00
parent 26011d7d74
commit 0395a88a63
5 changed files with 39 additions and 19 deletions

View File

@ -12,5 +12,6 @@ typedef struct SharedStruct
sem_t semProducer; sem_t semProducer;
} SharedStruct; } SharedStruct;
void SharedStructInit(SharedStruct* sharedMem);
#endif #endif

View File

@ -4,9 +4,9 @@
#include <unistd.h> #include <unistd.h>
#include "shared.h" #include "shared.h"
void* Consumer(void* arg); void Consumer(SharedStruct* sharedMem);
void consume_item(int item); void consume_item(int item, SharedStruct* sharedMem);
int remove_item(void); int remove_item(SharedStruct* sharedMem);
int main(int argc, char* argv[]) int main(int argc, char* argv[])
{ {
@ -17,38 +17,43 @@ int main(int argc, char* argv[])
} }
int sharedID = StringToNumber(argv[1]); int sharedID = StringToNumber(argv[1]);
SharedStruct* sharedMem = shmat(sharedID, NULL, 0); SharedStruct* sharedMem = shmat(sharedID, NULL, 0);
sem_wait(&sharedMem->semConsumer); Consumer(sharedMem);
// TODO: Fix buffer not printing correctly // TODO: Fix buffer not printing correctly
printf("%d\n", sharedMem->buffer[0]);
return 0; return 0;
} }
// Consumer main function // Consumer main function
// TODO: Add waiting for one consumer at a time // TODO: Add waiting for one consumer at a time
// Add ability to use shared memory // Add ability to use shared memory
void* Consumer(void* arg) void Consumer(SharedStruct* sharedMem)
{ {
int consumeNum; int consumeNum;
while (1) while (1)
{ {
sem_wait(&sharedMem->semConsumer);
// down(&full); // down(&full);
// down(&mutex); // down(&mutex);
consumeNum = remove_item(); consumeNum = remove_item(sharedMem);
printf("%d was consumed.\n", consumeNum);
// up(&mutex); // up(&mutex);
// up(&empty); // up(&empty);
consume_item(consumeNum); consume_item(consumeNum, sharedMem);
sem_post(&sharedMem->semProducer);
break; break;
} }
} }
// Manage item taken from shared memory // Manage item taken from shared memory
void consume_item(int item) void consume_item(int item, SharedStruct* sharedMem)
{ {
; sharedMem->count[item]++;
return;
} }
// Take item out of shared memory // Take item out of shared memory
int remove_item(void) int remove_item(SharedStruct* sharedMem)
{ {
; int item = sharedMem->buffer[0];
sharedMem->buffer[0] = -1;
return item;
} }

View File

@ -14,14 +14,14 @@ int main(int argc, char* argv[])
{ {
int producerAmount = GetSplitAmount(argc, argv, 0); int producerAmount = GetSplitAmount(argc, argv, 0);
int consumerAmount = GetSplitAmount(argc, argv, 1); int consumerAmount = GetSplitAmount(argc, argv, 1);
int sharedID; int sharedID = shmget(IPC_CREAT | (key_t)1243, sizeof(SharedStruct), IPC_CREAT | 0666);
SharedStruct* sharedMem;
sharedID = shmget(IPC_CREAT | (key_t)1243, sizeof(SharedStruct), IPC_CREAT | 0666);
if (sharedID < 0) if (sharedID < 0)
{ {
fprintf(stderr, "Shmget failed\n"); fprintf(stderr, "Shmget failed\n");
exit(1); exit(1);
} }
SharedStruct* sharedMem = shmat(sharedID, NULL, 0);
SharedStructInit(sharedMem);
// Create child forks // Create child forks
// TODO: Add creating consumers and producers instead of general forks // TODO: Add creating consumers and producers instead of general forks
CreateChildForks(producerAmount, 0, sharedID); CreateChildForks(producerAmount, 0, sharedID);

View File

@ -22,7 +22,7 @@ int main(int argc, char* argv[])
int sharedID = StringToNumber(argv[1]); int sharedID = StringToNumber(argv[1]);
SharedStruct* sharedMem = shmat(sharedID, NULL, 0); SharedStruct* sharedMem = shmat(sharedID, NULL, 0);
Producer(sharedMem); Producer(sharedMem);
sem_post(&sharedMem->semConsumer); printf("Producer finished.\n");
return 0; return 0;
} }
@ -49,6 +49,7 @@ void Producer(SharedStruct* sharedMem)
// TODO: For testing purposes, revert max to 100 // TODO: For testing purposes, revert max to 100
for (int i = 0; i < 5; i++) for (int i = 0; i < 5; i++)
{ {
sem_wait(&sharedMem->semProducer);
insertNum = produce_item(); insertNum = produce_item();
printf("%d is inserted.\n", insertNum); printf("%d is inserted.\n", insertNum);
// sem_wait(&semProducer); // sem_wait(&semProducer);
@ -56,6 +57,7 @@ void Producer(SharedStruct* sharedMem)
// down(&mutex); // down(&mutex);
// if (insert_item(insertNum, sharedMem) == 0) // if (insert_item(insertNum, sharedMem) == 0)
insert_item(insertNum, sharedMem); insert_item(insertNum, sharedMem);
sem_post(&sharedMem->semConsumer);
// { // {
// --i; // --i;
// continue; // continue;
@ -75,9 +77,10 @@ int produce_item(void)
// Insert a number into the shared memory // Insert a number into the shared memory
int insert_item(int item, SharedStruct* sharedMem) int insert_item(int item, SharedStruct* sharedMem)
{ {
int slot = GetNextFreeSlot(sharedMem); // int slot = GetNextFreeSlot(sharedMem);
if (slot == -1) // while (slot < 0)
return 0; // slot = GetNextFreeSlot(sharedMem);
// sharedMem->buffer[slot] = item;
sharedMem->buffer[0] = item; sharedMem->buffer[0] = item;
return 1; return 1;
} }

View File

@ -1,6 +1,17 @@
#include <stdio.h> #include <stdio.h>
#include "shared.h" #include "shared.h"
void SharedStructInit(SharedStruct* sharedMem)
{
for (int i = 0; i < 10; i++)
{
sharedMem->buffer[i] = -1;
sharedMem->count[i] = 0;
}
sem_init(&sharedMem->semConsumer, 1, 1);
sem_init(&sharedMem->semProducer, 1, 1);
}
int StringToNumber(char* argv) int StringToNumber(char* argv)
{ {
int splitAmount; int splitAmount;