1. Trang chủ
  2. » Kinh Doanh - Tiếp Thị

Model driven engineering languages and systems 11th international conference, MoDELS 2008, toulouse, france, september 28 oc

937 201 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 937
Dung lượng 19,99 MB

Nội dung

Lecture Notes in Computer Science Commenced Publication in 1973 Founding and Former Series Editors: Gerhard Goos, Juris Hartmanis, and Jan van Leeuwen Editorial Board David Hutchison Lancaster University, UK Takeo Kanade Carnegie Mellon University, Pittsburgh, PA, USA Josef Kittler University of Surrey, Guildford, UK Jon M Kleinberg Cornell University, Ithaca, NY, USA Alfred Kobsa University of California, Irvine, CA, USA Friedemann Mattern ETH Zurich, Switzerland John C Mitchell Stanford University, CA, USA Moni Naor Weizmann Institute of Science, Rehovot, Israel Oscar Nierstrasz University of Bern, Switzerland C Pandu Rangan Indian Institute of Technology, Madras, India Bernhard Steffen University of Dortmund, Germany Madhu Sudan Massachusetts Institute of Technology, MA, USA Demetri Terzopoulos University of California, Los Angeles, CA, USA Doug Tygar University of California, Berkeley, CA, USA Gerhard Weikum Max-Planck Institute of Computer Science, Saarbruecken, Germany 5301 Krzysztof Czarnecki Ileana Ober Jean-Michel Bruel Axel Uhl Markus Völter (Eds.) Model Driven Engineering Languages and Systems 11th International Conference, MoDELS 2008 Toulouse, France, September 28 - October 3, 2008 Proceedings 13 Volume Editors Krzysztof Czarnecki University of Waterloo Department of Electrical and Computer Engineering 200 University Ave., West Waterloo, ON, N2L 3G1, Canada E-mail: czarnecki@acm.org Ileana Ober Université Paul Sabatier, IRIT - MACAO 118, route de Narbonne, 31062 Toulouse, France E-mail: ileana.ober@irit.fr Jean-Michel Bruel Université de Pau et des Pays de l’Adour Département Informatique Av de l’Université, B.P 1155, 64013 Pau, France E-mail: Jean-Michel.Bruel@univ-pau.fr Axel Uhl SAP AG, 69190 Walldorf, Germany E-mail: axel.uhl@sap.com Markus Völter Independent Consultant Grabenstrasse 4, 73033 Göppingen, Germany E-mail: voelter@acm.org Library of Congress Control Number: 2008935624 CR Subject Classification (1998): D.2, D.3, K.6, I.6 LNCS Sublibrary: SL – Programming and Software Engineering ISSN ISBN-10 ISBN-13 0302-9743 3-540-87874-2 Springer Berlin Heidelberg New York 978-3-540-87874-2 Springer Berlin Heidelberg New York This work is subject to copyright All rights are reserved, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, re-use of illustrations, recitation, broadcasting, reproduction on microfilms or in any other way, and storage in data banks Duplication of this publication or parts thereof is permitted only under the provisions of the German Copyright Law of September 9, 1965, in its current version, and permission for use must always be obtained from Springer Violations are liable to prosecution under the German Copyright Law Springer is a part of Springer Science+Business Media springer.com © Springer-Verlag Berlin Heidelberg 2008 Printed in Germany Typesetting: Camera-ready by author, data conversion by Scientific Publishing Services, Chennai, India Printed on acid-free paper SPIN: 12534548 06/3180 543210 Preface MODELS 2008 was the 11th edition of the series of conferences on Model-Driven Engineering Languages and Systems The conference was held in Toulouse, France, during the week of September 28 to October 3, 2008 The local arrangements were provided by the Institut de Recherche en Informatique de Toulouse (IRIT) The conference program included three keynote presentations, technical paper presentations, two panels, and several workshops and tutorials The invited keynote speakers were Don Batory (University of Texas, USA), Jeff Kramer (Imperial College London, UK), and Patrick Rauhut (Airbus, Germany) This volume contains the final versions of the papers accepted for presentation at the conference The papers cover a wide range of topics from the field including model transformation, model management, domain-specific modeling, modeling language semantics, model analysis, and applications We received a record number of 271 full paper submissions from 40 different countries Of these, 43 papers were submitted by authors from more than one country The top three countries submitting papers were France (40), Germany (38), and Canada (24) A total of 58 papers were accepted for inclusion in the proceedings The acceptance rate was therefore 21%, which is somewhat lower than those of the previous MODELS conferences At least three Program Committee or Expert Reviewer Panel members reviewed each paper Reviewing was thorough, and most authors received detailed comments on their submissions Conflicts of interest were taken very seriously No-one participated in any way in the decision process of any paper where a conflict of interest was identified In particular, PC members who submitted papers did not have access to information concerning the reviews of their papers We would like to thank everyone who submitted papers as well as proposals for workshops and tutorials We would also like to thank the large number of volunteers who contributed to the success of the conference Richard van de Stadt deserves special thanks for his prompt and gracious service in supporting special requests for CyberChairPRO, the conference management system used to manage papers submissions and the virtual PC meeting Finally, we would like to thank our sponsors, ACM and IEEE Computer Society, for their support of the MODELS 2008 conference October 2008 Krzysztof Czarnecki Ileana Ober Jean-Michel Bruel Axel Uhl Markus Vă olter Organization Conference Chairs Ileana Ober (IRIT, France) Jean-Michel Bruel (LIUPPA, France) Program Chair Krzysztof Czarnecki (University of Waterloo, Canada) Experience Track Chairs Axel Uhl (SAP, Germany) Markus Vă olter (Independent Consultant, Germany) Technological Track Chair Pascal Roques (Valtech Training, France) Workshop Chair Michel Chaudron (Technical University Eindhoven and Leiden University, The Netherlands) Tutorial Chair Xavier Blanc (University Pierre et Marie Curie, France) Panel Chair Sudipto Ghosh (Colorado State University, USA) Research Project Symposium Chair Iulian Ober (Toulouse University, France) Doctoral Symposium Chair Alexander Pretschner (ETH Zurich, Switzerland) VIII Organization Educators’ Symposium Chair ´ Michal Smialek (Warsaw University of Technology, Poland) Publicity Chair Benoit Baudry (IRISA, France) Web Chair Nicolas Belloir (LIUPPA, France) Organizing Committee Jean-Paul Bodeveix (France) Pierre Bazex (France) Nicolas Belloir (France) Agusti Canals (France) Maura Cerioli (Italy) Xavier Cr´egut (France) Patrick Farail (France) Louis F´eraud (France) Geri Georg (USA) Herv´e Leblanc (France) Michel Lemoine (France) Thierry Millan (France) Mario Paludetto (France) Christian Percebois (France) Program Committee Jo˜ ao Ara´ ujo (Portugal) Uwe Aßmann (Germany) Benoit Baudry (France) Xavier Blanc (France) Jean B´ezivin (France) Paulo Borba (Brazil) Lionel Briand (Norway) Betty Cheng (USA) Shigeru Chiba (Japan) Krzysztof Czarnecki (Canada) Juergen Dingel (Canada) Gregor Engels (Germany) Alexander Egyed (Austria) Jean-Marie Favre (France) Bernd Fischer (UK) Robert France (USA) Harald Gall (Switzerland) Dragan Gaˇsevi´c (Canada) Geri Georg (USA) Holger Giese (Germany) Tudor Girba (Switzerland) Martin Gogolla (Germany) Aniruddha Gokhale (USA) Orla Greevy (Switzerland) Paul Gră unbacher (Austria) John Grundy (New Zealand) ỉystein Haugen (Norway) Simon Helsen (Germany) Robert Hirschfeld (Germany) Heinrich Hussmann (Germany) Jean-Marc J´ez´equel (France) Gabor Karsai (USA) Jana Koehler (Switzerland) Rainer Koschke (Germany) Thomas Kă uhne (New Zealand) Vinay Kulkarni (India) Jochen Kă uster (Switzerland) Ralf Lă ammel (Germany) Organization Michele Lanza (Switzerland) Michael Lawley (Australia) Timothy C Lethbridge (Canada) Ed Merks (Canada) Birger Møller-Pedersen (Norway) Ana Moreira (Portugal) Pierre-Alain Muller (France) Richard Paige (UK) Alexander Pretschner (Switzerland) Gianna Reggio (Italy) Bernhard Rumpe (Germany) Andy Schă urr (Germany) Bran Selic (Canada) Perdita Stevens (UK) Eleni Stroulia (Canada) Gabriele Taentzer (Germany) Juha-Pekka Tolvanen (Finland) Laurence Tratt (UK) Axel Uhl (Germany) Hans Vangheluwe (Canada) D´ aniel Varr´ o (Hungary) Eelco Visser (The Netherlands) Markus Vă olter (Germany) Andrzej Wasowski (Denmark) Thomas Weigert (USA) Jon Whittle (UK) Expert Reviewer Panel Aditya Agrawal (USA) Jean-Michel Bruel (France) Nancy Day (Canada) Sebastian Fischmeister (Canada) S´ebastien G´erard (France) Jeff Gray (USA) Ileana Ober (France) Kasper Østerbye (Denmark) Awais Rashid (UK) Andreas Rummler (Germany) Peter Sesoft (Denmark) Steering Committee Thomas Baar (Switzerland) Jean B´ezivin (France) Lionel Briand (Norway) Steve Cook (UK) Gregor Engels (Germany) Andy Evans (UK) Robert France (USA) Geri Georg (USA) Martin Gogolla (Germany) Heinrich Hussmann (Germany) Jean-Marc J´ez´equel (France) Stuart Kent (UK) Cris Kobryn (USA) Ana Moreira (Portugal) Pierre-Alain Muller (France) Oscar Nierstrasz (Switzerland) Gianna Reggio (Italy) David Rosenblum (UK) Bernhard Rumpe (Germany) Douglas C Schmidt (USA) Bran Selic (Canada) Perdita Stevens (UK) Jon Whittle (Chair; USA) Sponsors ACM Special Interest Group on Software Engineering (www.sigsoft.org) IEEE Computer Society (www.computer.org) IX X Organization Additional Reviewers Vasco Amaral Carsten Amelunxen Malte Appeltauer Egidio Astesiano Richard Atterer Andrej Bachmann Omar Bahy Badreldin Florence Balagtas-Fernandez Andr´ as Balogh Jan-Christopher Bals Olivier Barais Bruno Barroca Thiago T Bartolomei Dominikus Baur Basil Becker Nelly Bencomo Alexej Beresnev Rodrigo Bonifacio Phil Brooke Erwan Brottier Achim D Brucker Fabian Buettner Sebastian Cech Maura Cerioli Franck Chauvel Dan Chiorean Fabian Christ Peter J Clarke Michelle Crane Arnaud Cuccuru Akshay Dabholkar Duc-Hanh Dang Vegard Dehlen Romain Delamare Deepak Dhungana Zinovy Diskin Nikos Drivalos Cedric Dumoulin Huascar Espinoza Johan Fabry Fernando Castor Filho Franck Fleurey Alexander Foerster Fr´ed´eric Fondement Istv´an Forg´ acs Andrew Forward Laszlo Gă onczy Christian Gerth Giacomo Ghezzi Thomas Goldschmidt Pieter Van Gorp Emanuel Grant Danny Groenewegen Hans Groenniger Iris Groher Lindsay Groves Roy Grứnmo Thomas Gschwind Baris Gă uldali Ulrich Hannemann Michael Haupt Zef Hemel Christoph Herrmann Anders Hessellund Thomas Hettel Mark Hibberd Stephan Hildebrandt Otmar Hilliges Berthold Hoffmann Jippe Holwerda ´ Akos Horv´ ath Michael Jackson Mikol´ aˇs Janota Cedric Jeanneret Jendrik Johannes Fr´ed´eric Jouault Christophe Jouvray Stefan Jurack Markus Kaiser Sven Karol Lennart C L Kats Nima Kaviani Amogh Kavimandan Dae-Kyoo Kim Organization Felix Klar Florian Klein Renate Klempien-Hinrichs Patrick Knab Imre Kocsis Dimitrios Kolovos M´ at´e Kov´ acs Holger Krahn Ingolf Krueger Mirco Kuhlmann Uir´ a Kulesza Sabine Kuske Elodie Legros L´aszl´o Lengyel Tiham´er Levendovszky Hongzhi Liang Jens Lincke Alexander De Luca Christoph Lueth Mass Soldal Lund Tiago Massoni Matthew J McGill Tom Mens Kirsten Mewes Gergely Mezei Milan Milanovic Dragan Milicev Parastoo Mohagheghi Brice Morin Pieter Mosterman Jean-Marie Mottu Patrick Mukherjee Freddy Munoz Gunter Mussbacher Stefan Neumann James Noble Jon Oldevik Sebastian Oster Cesare Pautasso Luis Pedro Gilles Perrouin Claas Pinkernell Eduardo Piveta Fiona Polack Ernesto Posse Christopher Power Rick Rabiser Ansgar Radermacher Oliver Radfelder Y Raghu Reddy Dirk Reiss Marko Ribaric M´ arcio de Medeiros Ribeiro Filippo Ricca Sebastian Richly Matteo Risoldi David Roethlisberger Jens Rommel Louis Rose Nilabja Roy Suman Roychoudhury Ahmad Saifan Yavuz Sancar Tim Schattkowsky Marvin Schulze-Quester Andreas Seibel Sagar Sen Steven She Carla Silva Karsten Sohr Arnor Solberg Christian Soltenborn Jean-Sebastien Sottet Jim Steel Mark Stein Matthew Stephan Gerson Sunye Eugene Syriani D´ aniel T´ oth Safouan Taha Gergely Varr´o Sander Vermolen Hendrik Voigt Steven Vă olkel Arild Waaler Ksenia Wahler Michael Wahler Ingo Weisemoeller XI XII Organization Christian Wende Bernhard Westfechtel Gerd Wierse Michael Wuersch Jochen Wuttke Andreas Wă ubbeke Vadim Zaytsev Olaf Zimmermann Steffen Zschaler Model-Based Quality Assurance of Automotive Software 869 The same applies to model-checking: Generally it is not possible to prove a 100% correctness of a model under all circumstances Only the correctness of the specifically formulated properties can be proven The coverage of the model thus depends on the number of properties that were investigated Ideally for each requirement of the specification the appropriate property is proven For safety reasons also the corresponding negated form of requirements should be investigated (and shown not to hold) to avoid system failures due to incorrect usage Thus also for model-checking revealing a bug in a complex system is simpler than the proof of its overall correctness And even showing the correctness of a property is relativized by the following possible problems: – Initially defined assumptions not hold (e.g due to hardware problems) – The textual specification is erroneous or its interpretation incorrect – The proof system is incorrect (e.g due to programming bugs) If quality assurance is performed by the developers of the software themselves, model-checking has the advantage that it forces the users to think in a way that is much different from the writing of the software, because they have to create the model and the formalized of the property under investigation In comparison to that, conventional testing, when performed by the developers themselves, is much closer to the programming itself For example, the code may have actually been constructed with a certain set of test cases in mind, so that it by construction it will satisfy these test cases, but may not satisfy others then, which however the developer may then not think of In practice, model-checking generally requires a significant effort when applied to complex projects A simplification of the model as had to be done for the DCU in AutoF OCUS to reduce the state space would pose additional problems in practice The developers are usually concerned with problems of control systems and hardware problems and normally not have the time to cope with the theoretical challenging of model checking due to a short production schedule Forcing modelling guidelines to achieve a model-checkable system by default would impair usability Therefore, similar to the necessity of separate testing groups for conventional testing verification, specialists should accompany the development process of complex projects when model-checking is used Nowadays, much of the software of electronic control units is written in a conventional programming language like C (also in systems supporting AUTOSAR (see http://www.autosar.org for more information) It includes the basic software modules (e.g operating system and diagnosis) with their hardware dependent functionality (communication bus and microcontroller interface) The use of models is more popular only on the higher application layers It is however often difficult to provide an abstract interface to these by hiding hardware aspects (e.g interrupts, workarounds for hardware bugs) In AUTOSAR, one tries to cope with this situation using a layered approach including a virtual function bus and a run-time environment Limitations for model-based development and model-checking in embedded (in particular automotive) systems in practice thus include the following: – Limitations of computing power or time – Only software components of limited complexity can be abstracted sufficiently to become model-checkable 870 J Jürjens, D Reiß, and D Trachtenherz – Model-based approaches work well only on high levels of abstraction: Time dependencies and interrupts which occur in the base software are hard to formalize in the model without compromising its usability and the feasbility of its model-checking – Memory constraints not allow generating arbitrarily complex code (unless optimized for space) – Lack of existing experiences in practice – Ongoing developments in model-checking research which make it difficult for practitioners to keep track Related Work Only few case-studies on testing or model-checking automotive or more generally embedded software are published [16] reports on a case study of an automotive network controller to assess different test suites in terms of error detection, model coverage, and implementation coverage, where the suites were generated automatically or manually in various ways Automatically and manually derived model-based test suites detected significantly more requirements errors than hand-crafted test suites directly derived from the requirements [11] appears to conclude that the significant progress in terms of productivity and quality made in recent years in automotive software development has been achieved without direct usage of formal methods This raises the question whether further improvements could be reached with the use of formal methods (to some extent suggested by our case-study, although we did not aim to perform a full empirical study on this) A comparative description of ASCET, AutoF OCUS and further CASE tools can be found in [18], with a focus on methodology There has not been much work comparing formal verification and traditional quality assurance so far [1] compares directed testing, random testing and model-checking, but treated hardware verification rather than embedded software [3] gives a detailed study on the usage of testing, runtime analysis, model checking and static analysis techniques for NASA Rover Software, although design model verification was not considered [12] reports on a controlled experiment that investigates the impact of using statecharts for testing class clusters that exhibit a state-dependent behaviour [7,14] report on experiences on UML model analysis, but not consider model-based testing [2] presents an assessment framework for symmetrical comparison and evaluation of testing and formal analysis with respect to debugging and more specifically bug detection Other experience reports on software verification include [8] (on using automated theorem provers) and [9] (on tool-supported inspections) Conclusion We performed a field study in the automotive domain to compare traditional testing with model-checking We implemented an industrial specification in two different modelbased development tools We performed quality assurance using simulation in both tools, testing in ASCET, and model-checking in AutoF OCUS We evaluated the number and type of errors that were found and compared the effort and the effectiveness of the quality assurance methods An interesting result is the effort distribution within each of Model-Based Quality Assurance of Automotive Software 871 Table Conventional testing vs model-checking Testing Examines a physical or concrete system In-the-loop-tests take place in an environment near to the real one No proof of correctness of properties possible Uses often many, superficial test cases Modelchecking Examines an abstract model Cheap and early verification (without setting up complex in-the-loop-test environments) Proof of correctness of properties possible Uses selected user specific properties the two methods: while in the case of testing the evaluation of the test results required the largest part of the effort needed, in the case of model-checking the formulation of properties to be checked turned out to be most time-consuming Note that it was not our goal to compare ASCET and AutoFOCUS regarding the relative effort they require compared to each other (in particular, the two modelling phases were performed subsequently which means that the second modelling task using AutoFOCUS may have been facilitated by insights gained during the first using ASCET) The presented comparison does not aim to be complete or statistically significant as we did not perform a comprehensive empirical study with a high number of experiment participants The result is thus mostly a qualitative assessment of the effort and results of traditional and formal verification Our outcome was that model-checking needs some more time effort compared with testing, but was worth the effort because some types of errors could rather be found by model-checking than by testing, especially errors that developers may not look out for specifically during testing (such as synchronization error or boundary conditions) A combination of both methods might be optimal because both of them have their strengths in finding different types of errors Table compares general aspects of the examined quality assurance methods We could show that there exists no overall winner and that each verification methods has its own specialties: One deficit of the model-checking method is the problem of the state space explosion However, model-checkers are still subject to ongoing improvements, and at least in the case of event-controlled systems at a higher abstraction level, they are already applicable Regarding automotive applications, the use of formal verification techniques should not mean the absence of conventional test procedures Rather, formal verification provides complementary quality assurance techniques which could lead to synergy effects if applied along with conventional testing methods For example, a base model for successive development steps and test procedures could be created by providing verified models for generating test cases for Back-to-Back tests Note that “complementary” here does not necessarily mean that certain errors can be found only with one of the two techniques (except of course errors that cannot be found using model-checking because that works on a higher level of abstraction) Instead, it means that to detect large classes of simple errors, testing is more time-effective, while modelchecking is more effective to find specific classes of particularly intricate errors Although some of the results that were found during the case-study may confirm existing intuitions (e.g that model-checking may find additional bugs but takes more time to learn than testing), we are not aware of any other literature comparing modelchecking and model-based testing, in particular not regarding embedded or automotive software Although we target our discussion e.g in Sect mostly to the automotive 872 J Jürjens, D Reiß, and D Trachtenherz domain, we believe that it generalizes to other embedded domains that are both safetycritical (which justifies the use of sophisticated assurance techniques such as modelchecking) and at the same time are characterized by large product numbers (forcing hardware cost reduction and therefore optimized code) as well as a relatively short development cycle (which presents time pressure in the development) Lessons learned regarding the experimental setup include that it may have been beneficial to have the two QA techniques applied by two different users in parallel, rather than by the same sequentially Disadvantages would however include that this will be comparable only if the two users have the same expertise, and that this would significantly increase the effort needed for performing the experiment Since the person performing the study did not have any prior knowledge in the two tools that were used, we however believe the experiment to be repeatable by others Details of experimental results omitted for space reasons can be found at [10] Acknowledgements Constructive feedback from the anonymous referees that led to a significant improvement in the presentation of the paper is gratefully acknowledged References Bartley, M.G., Galpin, D., Blackmore, T.: A Comparison of Three Verification Techniques In: DAC, pp 819–823 ACM, New York (2002) Bradbury, J.S., Cordy, J.R., Dingel, J.: An empirical framework for comparing effectiveness of testing and property-based formal analysis In: PASTE, pp 2–5 (2005) Brat, G., Drusinsky, D., Giannakopoulou, D., et al.: Experimental Evaluation of Verification and Validation Tools on Martian Rover Software Formal Methods in System Design 25(2-3), 167–198 (2004) Broy, M.: Challenges in automotive software engineering In: ICSE, pp 33–42 ACM, New York (2006) Broy, M., Stolen, K.: Specification and Development of Interactive Systems Springer, Heidelberg (2001) Cheng, B., Houdek, F., Kawana, S (eds.): Workshop on Automotive Requirements Engineering (AuRE) IEEE, Los Alamitos (2006) Cheng, B.H.C., Stephenson, R., Berenbach, B.: Lessons learned from automated analysis of industrial UML class models (an experience report) In: MoDELS, pp 324–338 (2005) Denney, E., Fischer, B., Schumann, J.: An empirical evaluation of automated theorem provers in software certification Int J on Artif Intell Tools 15(1), 81–108 (2006) Halling, M., Biffl, S., Grünbacher, P.: An experiment family to investigate the defect detection effect of tool-support for requirements inspection In: IEEE METRICS, pp 278–285 (2003) 10 Jürjens, J., Reiss, D., Trachtenherz, D.: Model-based quality assurance of automotive software: Experimental data (April 2008), http://mcs.open.ac.uk/jj2924/publications/experiments/autoqa 11 Kropf, T.: Software bugs seen from an industrial perspective or can formal methods help on automotive software development? In: Damm, W., Hermanns, H (eds.) CAV 2007 LNCS, vol 4590 Springer, Heidelberg (2007) 12 Mouchawrab, S., Briand, L.C., Labiche, Y.: Assessing, comparing, and combining statechartbased testing and structural testing: An experiment In: ESEM, pp 41–50 (2007) 13 Paech, B., Houdek, F.: The door controller unit – an example specification Technical Report 002.02/D, Fraunhofer IESE (2002) Model-Based Quality Assurance of Automotive Software 873 14 Pilskalns, O., Andrews, A.A., Knight, A., Ghosh, S., France, R.B.: Testing UML designs Information & Software Technology 49(8), 892–912 (2007) 15 Pretschner, A., Broy, M., Krüger, I., Stauner, T.: Software engineering for automotive systems: A roadmap In: ICSE, Future of Softw Engin., pp 33–42 ACM, New York (2007) 16 Pretschner, A., Prenninger, W., Wagner, S., Kühnel, C., Baumgartner, M., Sostawa, B., Zölch, R., Stauner, T.: One evaluation of model-based testing and its automation In: ICSE, pp 392– 401 ACM, New York (2005) 17 Pretschner, A., Salzmann, C., Schätz, B., Stauner, T.: ICSE Workshop on Software Engineering for Automotive Systems In: ICSE Companion, p 146 IEEE, Los Alamitos (2007) 18 Schätz, B., Hain, T., Houdek, F., Prenninger, W., Rappl, M., Romberg, J., Slotosch, O., Strecker, M., Wißpeintner, A.: CASE Tools for Embedded Systems Technical Report I0309, TU Munich (2003) Ontology Guided Evolution of Complex Embedded Systems Projects in the Direction of MDA Lars Pareto1, Miroslaw Staron1, and Peter Eriksson2 IT University of Göteborg, 412 96 Göteborg, Sweden {lars.pareto,miroslaw.staron}@ituniv.se Ericsson Software Research, Ericsson AB, Sweden peter.r.eriksson@ericsson.com Abstract Implementation of MDA in large, product developing organizations involves changing processes, practices, tools, and communication infrastructures The paper presents a case study, in which modeling related needs of a unit within Ericsson were compared to features of current and envisioned MDA tools, using qualitative methods The paper’s main contribution is an ontology defining areas and sub-areas of improvement associated with the introduction of MDA in complex embedded systems projects The ontology is grounded in interviews with senior modellers at Ericsson and in survey publications from within the field of MDA It identifies 26 improvement areas concerned with model content, modeling activities, and the management of modeling projects The ontology has been presented to stakeholders within the unit studied, with positive feedback: appreciated were its groundedness, traceability, holistic scope, and potential as platform and checklist for several recurrent analysis and communication tasks related to software process improvement within Ericsson Introduction To implement MDA in a large organization with products on the market is, in many senses, a wicked problem [1]: required changes are plentiful and interrelated; data on which to base estimates of costs, benefits and risks are scarce; the implementation target is moving Yet, many companies realize that their future software development requires better utilization of modeling technologies—they are just unsure about the path The purpose of this paper is to support organisations in this situation—large, product developing companies that strive to increase their use of modeling in the direction of the MDA vision, but whose decision making regarding this stutter because of too many risks and constraints The paper approaches this problem from the perspective of practicing software engineers in commercial, complex embedded systems projects, already using UML for informal modeling Our view of such projects is captured by the conceptual framework in Fig 1: we view software as produced by engineers in specialized roles (Requirement engineer, etc.), who are steered by processes (defining who should produce what when for whom), and who communicate under the constraints of a communications infrastructure (consisting of model repositories and tools); the project is steered by business goals (such as reducing the time to market for new products) and subject K Czarnecki et al (Eds.): MoDELS 2008, LNCS 5301, pp 874–888, 2008 © Springer-Verlag Berlin Heidelberg 2008 Ontology Guided Evolution of Complex Embedded Systems Projects 875 to business constraints (such as bounds on development costs) We view project improvement as the matter of engineering features of internal processes and infrastructure towards several requirement sources (needs of every role, business goals, and business constraints), utilizing features of modeling technologies and process frameworks developed outside the project By complex embedded system we mean a large, special purpose, real-time, multiple processor, computer system that is part of a larger, technical system Fig Improvement variables in complex embedded systems projects The research question addressed in this paper is which improvement areas projects of this kind face when implementing MDA Put precisely: which areas of improvement requirement engineers, system engineers, architects, designers, developers, and test engineers, developing and maintaining complex embedded systems, need to be concerned with when proceeding from informal UML-based software development to MDA? By MDA, we mean the use of domain specific UML dialects and model transformations for specification and realization of software (Stahl [2] gives an overview.) The paper addresses this question by an exploratory, holistic, single case, case study [3] The unit of study is a subproject within Ericsson developing embedded software for a constituent part of a mobile-communications-network product The main outcome of the study is an ontology defining improvement areas associated with the introduction of MDA in complex embedded systems projects The paper is organised as follows: we describe our research design (Sec 2), our case (Sec 3), our study of this case (Sec 4–5), the ontology resulting from this study (Sec 6), and the use of it in process evolution (Sec 7); we discuss limitations of our study (Sec 8), and related work (Sec 9); finally, we summarize or findings and draw conclusions about the approach (Sec 10) 876 L Pareto, M Staron, and P Eriksson Research Design Our epistemological position is interpretative research [4]; our research strategy is qualitative research [5]; our data analysis method is grounded theory in the tradition of Strauss [6] The research design is outline in Fig Data collection has proceeded by semi-structured interviews and selection of written sources from within the modeling research community Data analysis techniques used are open coding (conceptualization of data sources using descriptive codes), categorization (grouping of codes with commonalities into categories), and axial coding (relating categories to subcategories) Our application of these techniques has been guided by technology roadmapping [7] (that emphasizes the modeling of needs and technological options in a common framework) The analysis outcome is a simple, informal ontology with inclusion hierarchy [8] (also known as a taxonomy) characterizing areas and sub-areas of improvement associated with the introduction of MDA in complex embedded systems projects Analytic generalization [3] has been used to obtain an ontology presumably useful for complex embedded systems projects in general The ontology’s validity relies on the grounded approach and feedback from practitioners Fig Research design Research has been collaborative [9], and involved three Ericsson insiders (a senior technical specialist, a software architect, and a project manager), and two outsiders (one software engineering researcher with a background in stereotype-based language customization, and another with a background in software quality and programming language semantics) Insiders have facilitated the study, defined the problem, set the scope, selected informants, and given recurring feedback on the study’s development; outsiders have designed the study, conducted data collection and analysis, framed the study, and communicated the results Our choice of a single case case-study is partly due to the revelatory nature [3] of our research question (we seek to elicit areas of software process improvement in a certain situation, rather to confirm or refute an hypothesis), and partly due to our use of enquiry based qualitative research (which is limited to small samples): distributing available resources over the study of several cases had been at the cost of penetration of individual level needs and inconsistent with our choice of method The particular unit was chosen because the Ericsson insiders were familiar with, and had a direct stake in improving this unit: this improves the quality of sampling, the data analysis, and eases the validation results (compared to the choice of some unfamiliar unit) Ontology Guided Evolution of Complex Embedded Systems Projects 877 The Case and Its Context Ericsson has a long tradition in model driven development: the use of software models with associated semantics dates back to 1967, with the AKE switch, first delivered in 1971, built using such [10] Ericsson contributed to development of SDL [11] during the 70s, and applied SDL extensively during the 80s; use case based modeling was pioneered by Ericsson in the 80s [12]; in the 90s, Ericsson was an early adopter of RUP [13]; today, MDD plays a central role in several Ericsson product lines, and model based software engineering is recognized as a prioritized area of improvement The project, to which the unit belongs, uses UML for requirements modelling, system design, systems architecture work, software architecture-work, detailed software design, and software implementation Other notations are also used: requirement engineers also use textual use cases and supplementary requirements specifications; hardware designers use block diagrams, and Mealy/Moore state machines (of their trade) Where UML is used, it is often complemented with text based notations, e.g., for signal and protocol specification, and with informal text-based specification documents for aspects not easily expressed in standard UML, e.g., non-functional requirements or configurations The unit operates in the following technical context: it develops the software part of a subsystem; the software runs on in-house developed, multi-processor hardware (involving digital signal processors, field programmable gate arrays, and ordinary processors); it is subject to real-time constraints (response time, throughput, and space bounds), compatibility constraints (RTOSes and in-house developed platforms), and special run-time requirements (monitoring, configuration, upgrading, and rollbacks) The project has a conventional line organisation The unit itself has approximately 100 engineers situated on a single location; the whole project is much larger and distributed over several locations The unit is divided into six sub-units: two responsible for software specification, three for software implementation and maintenance, and one for integration and validation The Unit’s Needs 4.1 Interviews with Engineers Informants were selected by the insiders, using the following criteria: the scope of their experience should be wide; they should have worked with model driven development in their daily work, they should understand model driven development from the perspective of several roles (and those of architects and designers in particular) The enquiries were semi-structured interviews revolving around the following set of questions: What, you think, Ericsson hopes to achieve by model driven development? Do you believe in this for Ericsson as a whole / for your project / for your role? What improvements of your project you spontaneously associate with model driven developments? Which deteriorations you associate? Is there some slavework / double work, you think, that could be automated/eliminated? Do you see 878 L Pareto, M Staron, and P Eriksson any obviously inefficient practices that ought to be improvable? What’s your view on the use of modelling for the activities in this list: requirements work, architecture work, detailed design, estimation, function testing, subsystem testing, documentation work, maintenance, code generation, configuration/run-time-use, change request handling, defect handling? How could modelling be used in the near future? Do you have any vision for your own, work/for the work of others? Are you aware of any modelling success stories inside or outside Ericsson? Questions were designed to, in an non-leading way, bring out the personal attitude and perceived goals of model driven development, to trigger an open-ended exploration of the informants perceived own needs, those of others, and company objectives To avoid discussions on the differences between MDA and model driven development, questions purposely referred to the latter The need for MDA was probed for indirectly, through questions to reveal a need for automation Interviews lasted 1-2h each, and the resulting transcriptions amounted to 60 pages of 10 pt, singly spaced text files A summary of the interviews is given in Table In addition to the interview transcripts (S1, ,S4), notes from a preparatory meeting, in which four designers discussed what to bring forward in an upcoming meeting with a tool vendor, was added as a supplementary data sources for needs (S5) 4.2 Interpretation of Interviews Interview transcripts were coded in search for needs—a concept prevalent in technology roadmapping—in a broad sense: we included direct needs expressed by the informants themselves and indirect needs inferred from their descriptions of situations or problems; in addition to unsatisfied needs, we included satisfied needs, not to be overlooked in process change; we included realistic needs whose satisfaction seemed plausible as well as wishful needs whose satisfaction seemed to require advances beyond state of the art The scope of the identified needs was model based software engineering and management, which is a larger scope than MDA technologies, but necessary to consider when implementing MDA To make the set of needs intellectually manageable and to facilitate communication of our results to non-analysts within Ericsson, interpretation was subject to the following principles, which emerged during the interpretation: each need should be (1) abstract enough to fit on a single line, but (2) concrete enough to suggest a specific improvement (or a set of specific improvements); (3) needs shall be distinct, by which we mean that all passages in the data sources referring to the same phenomenon are represented by a single need; (4) unless is violated, similar needs should be coalesced into one more abstract needs; (5) needs that apply to several roles should be generalized into such We illustrate the interpretation process and these principles through the need Subsystem level cohesion analysis which is the analysts interpretation of the following two passages of text (in their contexts): “It’s like, should I introduce a new component, or should I put the function into this old one” “we really tried to understand the problem [ ] to avoid the solution from being too scattered” Ontology Guided Evolution of Complex Embedded Systems Projects 879 This need is indirect: from a particular work situation, the analyst has recognized that engineers are concerned with component cohesion, concluded that analytic tools for reasoning about cohesion would be helpful, and phrased this as a need; later, the phenomenon has reappeared in a slightly different work context, similar enough to be an instance of the same need (possibly along with other needs) The need is unsatisfied: the unit’s engineers not use tools for cohesion analysis in their daily work The need is realistic: several theories and tools for cohesion analysis of models are available Further, the need satisfies principles 1–5: it is short, it points into a concrete domain, i.e., model quality metrics, it represents several instances of the phenomenon in the text, and it entails needs of architects and designers The need could be further improved with respect to principle by removing the restriction to subsystem level, as cohesion analysis is a likely concern at the system and implementation levels too In all, 269 distinct needs were identified in 36254 words originating from engineers in roles, at system (S) and subsystem (SS) level The number of inferred needs and examples of needs for each data source are given in Table (Some needs were mentioned by several informants, and one informant represented in two data sources, which is why summing columns and results in larger numbers than those above.) Table Some of the Unit's needs and the underlying data sources S1 May 14, 2007 Architect (SS) 14 588 words; 20 pages 143 needs Subsystem design- and implementation models shall be distinct E-sketching using UML UML for use case analysis UML for reverse engineering UML for refactoring OO framework design supported by workflow Deployment modeling Implementation modeling should be optional … S2 May 16, 2007 System Eng (SS) 297 words; 11 pages 67 needs Open formats for models Tool integration flexible Vendor independence Documentation globally searchable Documentation should be structured for large information volumes Baseline handling for reading users should be simple Requirements tracing from model Model oriented description at system level Text search into model database should be global S3 May 16, 2007 Developer (SS) 11 994 words; 17 pages 85 needs Subsystem level analysis modelling Subsystem level cohesion analysis Subsystem level architecture knowledge among designers Analysis modeling and implementation modeling shall be distinct Education in work-task specific modelling Clear separation between specification and white box interface synchronization S4 July 7, 2007 Architect (S,SS) 845 words; pages 18 needs Better definition which elements are in diagrams Overview mechanisms for complex models Links between information in legacy elements and system model Improved inspections of models Guidelines for managing documentation update Auto-generation of documents from design models Guidelines for model walkthroughs Specifications written at the same level of abstraction Single point of adding information in model System model is the primary source of information S5 April 27, 2007 Sys., Dev (SS) 510 words, pages 22 Needs Better definition which elements are in diagrams Overview mechanisms for complex models Links between information in legacy elements and system model Improved inspections of models Guidelines for managing documentation update Auto-generation of documents from design models Guidelines for model walkthroughs Specifications written at the same level of abstraction Single point of adding information in model System model is the primary source of information Requirements modeling using deployment diagrams System model is the primary source of information Align legacy documents and new tooling 880 L Pareto, M Staron, and P Eriksson Fig Categorization process (left) and outcome (right) 4.3 Categorization of Needs The categorization of the needs was iterative, incremental, and interleaved with the interpretation of needs and the categorization of features (left part of Fig 3): codes resulting from an initial interpretation of the transcripts (leftmost grey arrow) were grouped into areas of improvement (leftmost black arrow) and named; categories were then restructured and renamed (leftmost circulation-symbol) for consistency with those emerging from the analysis of the survey publication, which was conducted in parallel; categorisation and restructuring were repeated several times, when new data sources were interpreted or old data sources re-interpreted To make the category system suited for process improvement work (i.e., comprehensible, credible, maintainable, and usable) categorization was subject to the following principles: (1) categories should have concrete, suggestive names capturing the underlying phenomena (rather than abstract names capturing too much); (2) categories should be given meaning by characterizing definitions along with traceable connection to the underlying data sources; (3) categories should be coarse enough to allow quick classification of needs; (4) within categories, sub-categories should be used to group elements with closer relationships to each other; (5) categories should be general enough to serve as containers for both needs and features (thereby making needs and features easier to compare); (6) deep-hierarchies should be used sparingly (as an overuse makes category system difficult to comprehend and maintain); (7) categories should be role centric (to make the responsibility for satisfying needs more clear) The categorization process involved (in addition to the grouping of needs and introduction of names and characterizing definitions) coalescing, subdividing, widening, narrowing, and renaming categories; it involved re-categorization and renaming of codes to better realize interpretation and categorization principles The process eventually resulted in the ontology outlined in the right part of Fig (and which is further described in Section 6) Improvement areas are found at four levels of abstraction: general areas, 26 areas, 80 subareas, and 269 needs Ontology Guided Evolution of Complex Embedded Systems Projects 881 Features of MDA Technologies and Processes 5.1 Literature Search The literature study addressed the following main question: Which are the features of current and envisioned MDA processes and tools? Sampling was restricted to survey publications; these were selected to cover both technical and managerial aspects from the perspectives of modeling researchers, modellers in industry, and suppliers of modeling tools An overview of the publications used in our analysis is given in Table 5.2 Interpretation of Survey Publications Interpretation of survey publications used the following principles: (1-5) principles similar to the five used in the interpretation of transcripts; (6) process features with no other distinct phenomena than the use of a technology feature, should be implicitly defined by the latter; (7) process and technology features should not be kept apart We motivate by the following example of two possible features: “Automated model metrics is used” “Automated model metrics” (Process feature) (Technology feature) Any technology feature has an obvious corresponding process feature, whose presence would clutter the ontology through redundance We motivate by the following process feature: “Software product lines” (Process feature and technology feature) This feature comes with certain commitments to both process (configuration is done by compilers rather than people) and technology (feature diagrams, connected to model to model transformations, and composition infrastructure in certain ways), thus it is a compact carrier of both concerns Encouraging analysts to view all codes from both angles gives a more compact representation better coverage, and quicker classification compared to keeping process and technology features apart Interpretation of the survey publications, along these principles, resulted in 214 features, some of which are given in Table Table Process- and technology features and the underlying data sources S6 MDD practices within Mototorola [14] 39 features Data reuse between design and testing activities Testing by co-simulation Automatic test generation Automatic code generation Standardized and non-proprietary modeling languages S7 MDD research roadmap [15] 61 features Models describe the system at multiple levels of abstraction Formal semantics Generation of configuration files Synchronization transformation (Model-Code) Verification by simulation modelling S8-10 Modelware Metrics, Projects, Frameworks [16-21] 69 features Maturity levels definition Models used for production of documentation Platform independent and platform specific models separate Generation of implementation infrastructure S11 MDD technologies and tools [2] Aspect models Bidirectional transformation Code and document generation automated Config by feature models Domain specific modeling M2C weaving 30 features 882 L Pareto, M Staron, and P Eriksson 5.3 Categorization of Features Categorization of features followed the same steps as, and was interleaved with, the categorization of needs Initially, separate category system were maintained, but during the course of analysis the two were merged, for the following reasons: there was a large overlap in concepts; a common system eliminated the task of relating the two system and that of keeping them consistent; viewing needs and feature as members of the same category had analytic power (it enabled the analyses describe in Section 7.2, and simplified identification of sub-categories) Ontology of MDA Implementation Improvement Areas 6.1 General Areas and Areas The ontology is a hierarchy, in which general areas and areas form a tree, but in which sub-areas crosscut (technically a graph) Each node consists of a name and characterizing definition and is associated with a subset of all features and needs There is a strict inclusion order: any need or feature that belongs to a sub-area also belongs to the ancestors of this node The topmost two levels of the ontology, the general areas and areas, are given in Table on next page: the three general areas Fig Histogram showing the distribution of the needs and features over modeling areas Ontology Guided Evolution of Complex Embedded Systems Projects 883 (Content, Activity, Management) are subdivided into 26 areas (Artefact content, etc.) each with a characterizing definition of the areas concern The number of needs and features associated with each of these areas are given by the histogram in Fig 4: the area Artefact Content contains 31 needs and 32 features, etc Table Improvement areas when implementing MDA in complex embedded systems projects Content Activity Management Information in models Operations on models Socio-technical aspects of modeling Artefact content Editing Infrastructure The syntax and semantics of the artefact kinds, and their use Reading, writing, modifying models Servers and tools for producing using/sharing/reusing/distributing/archiving models/artifacts and the integration of these Artefact linkage How artefacts (models, code, interface files, scripts, metamodels, ) at different levels of modeling (requirements level, system level, subsystem level, implementation level) in different activities (specification, implementation, testing, documentation) should be linked Artefact versioning Information related to the evolution of models Viewing Navigating and searching own models and those of others Code generation Automatic production of programming code in text based languages from models Report Generation Automatic production of documentation, and specifications from models Test Data Generation Automatic generation of test scripts or test data from models Model Transformation Process Who should produce what model when for whom Strategies Tactics for introducing, executing, and optimizing the use of modeling Knowledge development Education (in tools, practices, abstract thinking) and internal knowledge transfer (of technologies, architectural principles, design rules) Automatic transformation of models from one kind or use to another kind or use Communication Round Trip Engineering Commitment Co-existing manual development of models and code Compiling/linking/tracing code Integration of models with their target system incarnations Reverse Engineering Creation of model from source code Reuse Exchange of information between roles Managers and engineers engagement in the introduction and improvement of modeling Culture Relative values of artefacts, roles, and tasks among managers and engineers External Relations The technology suppliers’ responsiveness to organization’s needs; negotiation position Libraries of models and patterns Business drivers Verification - rule checking Economical incentives for using model driven development instead of something else Well-formedness of models wrt rules Verification - metrics analysis Computation of model metrics Verification – simulation Off-line execution of models Model based analysis Use of models to reason about the system built or the project building it ... Uhl Markus Völter (Eds.) Model Driven Engineering Languages and Systems 11th International Conference, MoDELS 2008 Toulouse, France, September 28 - October 3, 2008 Proceedings 13 Volume Editors... oller and Andy Schă urr Interfaces and Metainterfaces for Models and Metamodels Anders Hessellund and Andrzej Wasowski Model& Metamodel, Metadata and Document Repository for Software and. .. Preface MODELS 2008 was the 11th edition of the series of conferences on Model- Driven Engineering Languages and Systems The conference was held in Toulouse, France, during the week of September 28

Ngày đăng: 02/03/2020, 11:25

Nguồn tham khảo

Tài liệu tham khảo Loại Chi tiết
1. Firesmith, D.G.: Engineering Safety Requirements, Safety Constraints, and Safety-Critical Requirements. Journal of Object Technology, 3, 27–42 (2004) Khác
2. McDermott, J., Fox, C.: Using Abuse Case Models for Security Requirements Analysis. In: 15th Annual Computer Security Applications Conference (ACSAC 1999). IEEE Com- puter Soceity Press, Los Alamitos (1999) Khác
3. Leveson, N.G.: Safeware: System Safety and Computers. Addison-Wesley, Boston (1995) 4. Lutz, R.R.: Software Engineering for Safety: A Roadmap. In: Finkelstein, A. (ed.) The Fu-ture of Software Engineering, pp. 213–226. ACM Press, New York (2000) Khác
5. Sindre, G., Opdahl, A.L.: Eliciting Security Requirements with Misuse Cases. Require- ments Engineering 10, 34–44 (2005) Khác
6. Alexander, I.F.: Initial Industrial Experience of Misuse Cases in Trade-Off Analysis. In: Pohl, K. (ed.) 10th Anniversary IEEE Joint International Requirements Engineering Con- ference (RE 2002), Essen, Germany, 9-13 September. IEEE, Los Alamitos (2002) Khác
7. Alexander, I.F.: Misuse Cases, Use Cases with Hostile Intent. IEEE Software 20, 58–66 (2003) Khác
8. Sindre, G.: A look at misuse cases for safety concerns. In: ME 2007, Geneva, Switzerland. IFIP. Springer, Heidelberg (2007) Khác
9. Stồlhane, T., Sindre, G.: A comparison of two approaches to safety analysis based on use cases. In: ER 2007, Auckland, New Zealand. LNCS. Springer, Heidelberg (2007) Khác
10. Stamatis, D.H.: Failure Mode and Effect Analysis: FMEA from theory to execution. American Society fbor Quality (ASQ), Milwaukee, Wisconsin (1995) Khác
11. Achour-Salinesi, C.B., Rolland, C., Maiden, N.A.M., Souveyet, C.: Guiding Use Case Au- thoring: Results from an Empirical Study. In: 4th International Symposium on Require- ments Engineering (RE 1999), 7-11 June, pp. 36–43. IEEE, Los Alamitos (1999) Khác
12. Cox, K., Phalp, K.: Replicating the CREWS Use Case Authoring Guidelines Experiment. Empirical Software Engineering 5, 245–267 (2000) Khác
13. Anda, B., Sjứberg, D.I.K., Jứrgensen, M.: Quality and Understandability of Use Case Models. In: Knudsen, J.L. (ed.) ECOOP 2001. LNCS, vol. 2072, pp. 402–428. Springer, Heidelberg (2001) Khác
14. Anda, B., Sjứberg, D.I.K.: Investigating the Role of Use Cases in the Construction of Class Diagrams. Empirical Software Engineering 10, 285–309 (2005) Khác
15. Thelin, T., Runeson, P., Regnell, B.: Usage-based reading: an experiment to guide review- ers with use cases. Information & Software Technology 43, 925–938 (2001) Khác
16. Cox, K., Aurum, A., Jeffery, D.R.: An Experiment in Inspecting the Quality of Use Case Descriptions. Journal of Research and Practice in Information Technology 36, 211–229 (2004) Khác
17. Bernardez, B., Genero, M., Duran, A., Toro, M.: A Controlled Experiment for Evaluating a Metric-Based Reading Technique for Requirements Inspection. In: 10th International Symposium on Software Metrics (METRICS 2004), 11-17 September, pp. 257–268. IEEE, Los Alamitos (2004) Khác
18. Batra, D., Hoffer, J.A., Bostrom, R.P.: Comparing Representations with Relational and EER Models. Communications of the ACM 33, 126–139 (1990) Khác
19. Cheng, P.C.-H.: Why Diagrams Are (Sometimes) Six Times Easier than Words: Benefits beyond Locational Indexing. In: Blackwell, A.F., Marriott, K., Shimojima, A. (eds.) Dia- grams 2004. LNCS (LNAI), vol. 2980, pp. 242–254. Springer, Heidelberg (2004) Khác
20. Larkin, J.H., Simon, H.A.: Why a Diagram is (Sometimes) Worth Ten Thousand Words. Cognitive Science 11 (1987) Khác
21. Boekelder, A., Steehouder, M.: Selecting and Switching: Some Advantages of Diagrams over Tables and Lists for Presenting Instructions. IEEE Transactions on Professional Communication 41, 229–241 (1998) Khác

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN