Changeset 2f65fb0 in mainline


Ignore:
Timestamp:
2008-06-03T15:10:17Z (17 years ago)
Author:
Martin Decky <martin@…>
Branches:
lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
Children:
536ec42
Parents:
271b540
Message:

devmap support, small fixes

File:
1 edited

Legend:

Unmodified
Added
Removed
  • uspace/srv/rd/rd.c

    r271b540 r2f65fb0  
    5252#include <async.h>
    5353#include <futex.h>
     54#include <stdio.h>
     55#include <ipc/devmap.h>
    5456#include "rd.h"
     57
     58#define NAME "rd"
    5559
    5660/** Pointer to the ramdisk's image. */
     
    105109         */
    106110        size_t size;
    107         if (ipc_share_out_receive(&callid, &size, NULL)) {
     111        int flags;
     112        if (ipc_share_out_receive(&callid, &size, &flags)) {
    108113                if (size >= BLOCK_SIZE) {
    109114                        /*
     
    150155                        }
    151156                        futex_down(&rd_futex);
    152                         memcpy(fs_va, rd_addr + offset, BLOCK_SIZE);
     157                        memcpy(fs_va, rd_addr + offset * BLOCK_SIZE, BLOCK_SIZE);
    153158                        futex_up(&rd_futex);
    154159                        retval = EOK;
     
    164169                        }
    165170                        futex_up(&rd_futex);
    166                         memcpy(rd_addr + offset, fs_va, BLOCK_SIZE);
     171                        memcpy(rd_addr + offset * BLOCK_SIZE, fs_va, BLOCK_SIZE);
    167172                        futex_down(&rd_futex);
    168173                        retval = EOK;
     
    182187}
    183188
     189static int driver_register(char *name)
     190{
     191        ipcarg_t retval;
     192        aid_t req;
     193        ipc_call_t answer;
     194        int phone;
     195        ipcarg_t callback_phonehash;
     196
     197        phone = ipc_connect_me_to(PHONE_NS, SERVICE_DEVMAP, DEVMAP_DRIVER, 0);
     198
     199        while (phone < 0) {
     200                usleep(10000);
     201                phone = ipc_connect_me_to(PHONE_NS, SERVICE_DEVMAP,
     202                    DEVMAP_DRIVER, 0);
     203        }
     204       
     205        req = async_send_2(phone, DEVMAP_DRIVER_REGISTER, 0, 0, &answer);
     206
     207        retval = ipc_data_write_start(phone, (char *) name, strlen(name) + 1);
     208
     209        if (retval != EOK) {
     210                async_wait_for(req, NULL);
     211                return -1;
     212        }
     213
     214        async_set_client_connection(rd_connection);
     215
     216        ipc_connect_to_me(phone, 0, 0, 0, &callback_phonehash);
     217        async_wait_for(req, &retval);
     218
     219        return phone;
     220}
     221
     222static int device_register(int driver_phone, char *name, int *handle)
     223{
     224        ipcarg_t retval;
     225        aid_t req;
     226        ipc_call_t answer;
     227
     228        req = async_send_2(driver_phone, DEVMAP_DEVICE_REGISTER, 0, 0, &answer);
     229
     230        retval = ipc_data_write_start(driver_phone, (char *) name, strlen(name) + 1);
     231
     232        if (retval != EOK) {
     233                async_wait_for(req, NULL);
     234                return retval;
     235        }
     236
     237        async_wait_for(req, &retval);
     238
     239        if (handle != NULL)
     240                *handle = -1;
     241       
     242        if (EOK == retval) {
     243                if (NULL != handle)
     244                        *handle = (int) IPC_GET_ARG1(answer);
     245        }
     246       
     247        return retval;
     248}
     249
    184250/** Prepare the ramdisk image for operation. */
    185251static bool rd_init(void)
    186252{
    187         int retval, flags;
    188 
    189253        rd_size = sysinfo_value("rd.size");
    190254        void *rd_ph_addr = (void *) sysinfo_value("rd.address.physical");
    191255       
    192         if (rd_size == 0)
     256        if (rd_size == 0) {
     257                printf(NAME ": No RAM disk found\n");
    193258                return false;
     259        }
    194260       
    195261        rd_addr = as_get_mappable_page(rd_size);
    196262       
    197         flags = AS_AREA_READ | AS_AREA_WRITE | AS_AREA_CACHEABLE;
    198         retval = physmem_map(rd_ph_addr, rd_addr,
     263        int flags = AS_AREA_READ | AS_AREA_WRITE | AS_AREA_CACHEABLE;
     264        int retval = physmem_map(rd_ph_addr, rd_addr,
    199265            ALIGN_UP(rd_size, PAGE_SIZE) >> PAGE_WIDTH, flags);
    200266
    201         if (retval < 0)
     267        if (retval < 0) {
     268                printf(NAME ": Error mapping RAM disk\n");
    202269                return false;
     270        }
     271       
     272        printf(NAME ": Found RAM disk at %p, %d bytes\n", rd_ph_addr, rd_size);
     273       
     274        int driver_phone = driver_register(NAME);
     275        if (driver_phone < 0) {
     276                printf(NAME ": Unable to register driver\n");
     277                return false;
     278        }
     279       
     280        int dev_handle;
     281        if (EOK != device_register(driver_phone, "initrd", &dev_handle)) {
     282                ipc_hangup(driver_phone);
     283                printf(NAME ": Unable to register device\n");
     284                return false;
     285        }
     286       
    203287        return true;
    204288}
     
    206290int main(int argc, char **argv)
    207291{
    208         if (rd_init()) {
    209                 ipcarg_t phonead;
    210                
    211                 async_set_client_connection(rd_connection);
    212                
    213                 /* Register service at nameserver */
    214                 if (ipc_connect_to_me(PHONE_NS, SERVICE_RD, 0, 0, &phonead) != 0)
    215                         return -1;
    216                
    217                 async_manager();
    218                
    219                 /* Never reached */
    220                 return 0;
    221         }
    222        
    223         return -1;
     292        printf(NAME ": HelenOS RAM disk server\n");
     293       
     294        if (!rd_init())
     295                return -1;
     296       
     297        printf(NAME ": Accepting connections\n");
     298        async_manager();
     299
     300        /* Never reached */
     301        return 0;
    224302}
    225303
Note: See TracChangeset for help on using the changeset viewer.