summaryrefslogtreecommitdiff
path: root/src/drivers/driver.c
diff options
context:
space:
mode:
authorAndreas Baumann <mail@andreasbaumann.cc>2017-06-10 21:26:24 +0200
committerAndreas Baumann <mail@andreasbaumann.cc>2017-06-10 21:26:24 +0200
commitd6d1bdfefafff50b7b6d15d218c0a188570be541 (patch)
tree15ee8de727d0be5d126efda146b2879de0a72773 /src/drivers/driver.c
parenteea5bf4b859eb56c5772c58ca54937a90a10e7ee (diff)
downloadabaos-d6d1bdfefafff50b7b6d15d218c0a188570be541.tar.gz
abaos-d6d1bdfefafff50b7b6d15d218c0a188570be541.tar.bz2
some big renames into subdirs of aspects
updated README removed size_t in sys/types.h and sys/types.h itself, size_t is in stddef.h
Diffstat (limited to 'src/drivers/driver.c')
-rw-r--r--src/drivers/driver.c65
1 files changed, 65 insertions, 0 deletions
diff --git a/src/drivers/driver.c b/src/drivers/driver.c
new file mode 100644
index 0000000..5a1a479
--- /dev/null
+++ b/src/drivers/driver.c
@@ -0,0 +1,65 @@
+#include "driver.h"
+
+#include "kernel.h"
+#include "string.h"
+
+void driver_manager_init( driver_manager_t *manager )
+{
+ memset( manager, 0, sizeof( driver_manager_t ) );
+
+ manager->nof_drivers = 0;
+}
+
+void driver_manager_add_driver( driver_manager_t *manager, driver_t *driver )
+{
+ if( manager->nof_drivers >= MAX_NOF_DRIVERS - 1 ) {
+ kernel_panic( "Allocating more than %d drivers.. increase kernel constant", MAX_NOF_DRIVERS );
+ }
+
+ manager->driver[manager->nof_drivers] = driver;
+ manager->nof_drivers++;
+}
+
+void driver_manager_activate_all( driver_manager_t *manager )
+{
+ for( int i = 0; i < manager->nof_drivers; i++ ) {
+ driver_t *driver = (driver_t *)manager->driver[i];
+ driver_vtable_t *driver_vtable = driver->vtable;
+ driver_vtable->activate( driver );
+ }
+}
+
+void driver_manager_deactivate_all( driver_manager_t *manager )
+{
+ if( manager->nof_drivers == 0 ) {
+ return;
+ }
+
+ for( int i = manager->nof_drivers - 1; i >= 0; i-- ) {
+ driver_t *driver = (driver_t *)manager->driver[i];
+ driver_vtable_t *driver_vtable = driver->vtable;
+ driver_vtable->deactivate( driver );
+ }
+}
+
+void driver_manager_deinit( driver_manager_t *manager )
+{
+ if( manager->nof_drivers == 0 ) {
+ return;
+ }
+
+ for( int i = manager->nof_drivers - 1; i >= 0; i-- ) {
+ driver_t *driver = (driver_t *)manager->driver[i];
+ driver_vtable_t *driver_vtable = driver->vtable;
+ driver_vtable->deinit( driver );
+ }
+}
+
+void driver_manager_print_info_all( driver_manager_t *manager )
+{
+ for( int i = 0; i < manager->nof_drivers; i++ ) {
+ driver_t *driver = (driver_t *)manager->driver[i];
+ driver_vtable_t *driver_vtable = driver->vtable;
+ driver_vtable->print_info( driver );
+ }
+}